python 字典比较
问题描述
一个列表当中有一个日期的值,我想求这个日期里面当天最大时间的那一条,大神们如何写呢?原始列表`
[{ 'count': 0, 'create_time': '2017-03-22 22:00:00', 'level': '1' }, { 'count': 5, 'create_time': '2017-03-22 22:00:00', 'level': '0' }, { 'count': 5, 'create_time': '2017-03-22 22:00:00', 'level': '2' }, { 'count': 5, 'create_time': '2017-03-22 23:00:00', 'level': '0' }, { 'count': 0, 'create_time': '2017-03-22 23:00:00', 'level': '1' }, { 'count': 5, 'create_time': '2017-03-22 23:00:00', 'level': '2' }]`
想要输出的列表
[{'count': 5,'create_time': '2017-03-22 23:00:00','level': '0' }, {'count': 0,'create_time': '2017-03-22 23:00:00','level': '1' }, {'count': 5,'create_time': '2017-03-22 23:00:00','level': '2' }]
问题解答
回答1:在上次问的问题里改sum成max:
from collections import defaultdictgrouped = defaultdict(list)for d in s: grouped[(d[’create_time’].split()[0], d[’level’])].append((d[’create_time’], d[’count’]))summed = {k : max(grouped[k]) for k in grouped}s = [{’count’: summed[k][1], ’create_time’: summed[k][0], ’level’: k[1]} for k in summed]回答2:
像这类问题都可以用groupby来解决
# coding: utf-8from itertools import groupbydata = [...]fun_group = lambda x: x[’level’]fun_max = lambda x: x[’create_time’]lst = [max(list(g), key=fun_max) for k, g in groupby(sorted(data, key=fun_group), fun_group)]print lst回答3:
思路就是先排序,再过滤
ls = [{ 'count': 0, 'create_time': '2017-03-22 22:00:00', 'level': '1' }, { 'count': 5, 'create_time': '2017-03-22 22:00:00', 'level': '0' }, { 'count': 5, 'create_time': '2017-03-22 22:00:00', 'level': '2' }, { 'count': 5, 'create_time': '2017-03-22 23:00:00', 'level': '0' }, { 'count': 0, 'create_time': '2017-03-22 23:00:00', 'level': '1' }, { 'count': 5, 'create_time': '2017-03-22 23:00:00', 'level': '2' }]import timels.sort(key = lambda x: time.strptime(x['create_time'], '%Y-%m-%d %H:%M:%S'))ret = filter(lambda x: x[’create_time’] == ls[-1][’create_time’], ls)print ret'''[{’count’: 5, ’create_time’: ’2017-03-22 23:00:00’, ’level’: ’0’}, {’count’: 0, ’create_time’: ’2017-03-22 23:00:00’, ’level’: ’1’}, {’count’: 5, ’create_time’: ’2017-03-22 23:00:00’, ’level’: ’2’}]'''
相关文章:
1. css3 - 请问一下在移动端CSS布局布局中通常需要用到哪些元素,属性?2. PHP能实现百度网盘的自动化么?3. 网页爬虫 - python requests爬虫,如何post payload4. android - 使用vue.js进行原生开发如何进行Class绑定5. node.js - vue服务端渲染如何部署到线上6. node.js - 微信的自动回复问题7. MySQL 水平拆分之后,自动增长的ID有什么好的解决办法?8. javascript - 百度图片切换图片时url会改变,但无刷新,没用hash,IE8也支持,请问是用了什么技术?9. 我正在使用jsp / jstl / spring动态生成css和js。如何将此结果放置在头部的链接标签中。不在头部的脚本标签中10. angular.js - 各位大神们,你们混合开发,web方式中更推荐用什么框架呀? react?vue?angular?谢谢~
