2014-09-02 18:03:04 +08:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
# -*- encoding: utf-8 -*-
|
|
|
|
|
"""
|
|
|
|
|
Topic: 分组迭代
|
|
|
|
|
Desc :
|
|
|
|
|
"""
|
2014-09-03 00:17:10 +08:00
|
|
|
from operator import itemgetter
|
|
|
|
|
from itertools import groupby
|
2014-09-02 18:03:04 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def group_iter():
|
|
|
|
|
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'},
|
|
|
|
|
]
|
|
|
|
|
|
2014-09-03 00:17:10 +08:00
|
|
|
# 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)
|
2014-09-02 18:03:04 +08:00
|
|
|
|
2014-09-03 00:17:10 +08:00
|
|
|
# defaultdict使用
|
|
|
|
|
from collections import defaultdict
|
|
|
|
|
rows_by_date = defaultdict(list)
|
|
|
|
|
for row in rows:
|
|
|
|
|
rows_by_date[row['date']].append(row)
|
2014-09-02 18:03:04 +08:00
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
|
group_iter()
|