Python: 字典列表: 通过某个字段将记录分组
问题:有一个字典或者实例的序列,想根据某个特定的字段比如date 来分组迭代访问。
answer: itertools.groupby函数对于这样的数据分组操作非常实用
eg:
rows = [
{'address': '5412 N CLARK', 'date': '07/01/2012'},
{'address': '5148 N CLARK', 'date': '07/04/2012'},
{'address': '5800 E 58TH', 'date': '07/02/2012'},
{'address': '2122 N CLARK', 'date': '07/03/2012'},
{'address': '5645 N RAVENSWOOD', 'date': '07/02/2012'},
{'address': '1060 W ADDISON', 'date': '07/02/2012'},
{'address': '4801 N BROADWAY', 'date': '07/01/2012'},
{'address': '1039 W GRANVILLE', 'date': '07/04/2012'},
]
>>>from operator import itemgetter
>>>from itertools import groupby
# Sort by the desired field first
>>>rows.sort(key=itemgetter('date'))
# Iterate in groups
>>>for date, items in groupby(rows, key=itemgetter('date')):
....... print(date)
....... for i in items:
....... print(' ', i)
运行结果:
07/01/2012
{'date': '07/01/2012', 'address': '5412 N CLARK'}
{'date': '07/01/2012', 'address': '4801 N BROADWAY'}
07/02/2012
{'date': '07/02/2012', 'address': '5800 E 58TH'}
{'date': '07/02/2012', 'address': '5645 N RAVENSWOOD'}
{'date': '07/02/2012', 'address': '1060 W ADDISON'}
07/03/2012
{'date': '07/03/2012', 'address': '2122 N CLARK'}
07/04/2012
{'date': '07/04/2012', 'address': '5148 N CLARK'}
{'date': '07/04/2012', 'address': '1039 W GRANVILLE'}
groupby()函数扫描整个序列并且查找连续相同值的元素序列,
在每次迭代的时候它会返回一个值和一个迭代器对象,
这个迭代器对象可以生成元素值全部等于上面那个值的组中所有对象,
要根据指定的字段将数据排序,因为groupby() 仅仅检查连续的元素,如果事先并没有排序完成的话,分组函数将得不到想要的结果。
- python通过某个字段将记录分组
- 获取分组后取某字段最大一条记录(求每个类别中最大的值的列表)
- 获取分组后取某字段最大一条记录(求每个类别中最大的值的列表)
- oracle通过表中2个字段分组查询取数量最大的所有记录,有条件的去重
- python通过对字典的排序,对json字段进行排序
- python字典列表通过某个关键字排序一个字典列表
- Dive Into Python 学习记录1-函数/模块导入/字典/列表/元组/字符串分割、连接、格式化/映射list/
- 获取分组后取某字段最大的一条记录(求每个类别中最大的值的列表)
- [00015]通过某个字段将记录分组
- 获取分组后取某字段最大一条记录(求每个类别中最大的值的列表)
- Python cookbook(数据结构与算法)通过公共键对字典列表排序算法示例
- Python cookbook(数据结构与算法)根据字段将记录分组操作示例
- Python3.5入门学习记录-列表、元组、字典
- Python边学边记录之2-常用的集合(列表、原组、字典)
- Python: 字典列表: itemgetter 函数: 根据某个或某几个字典字段来排序列表
- python学习记录 — (7)列表、元组、字典
- Python3基础 记录列表中元素访问的次数 定制不可变序列,__len__,__getitem__,下标字典
- Python数据分析中Groupby用法之通过字典或Series进行分组的实例
- 获取分组后取某字段最大一条记录(求每个类别中最大的值的列表)
- 获取分组后取某字段最大一条记录(求每个类别中最大的值的列表)