我有字典列表,每个字典都有属性person_id。
[{'person_id': 1, 'something..': 'else'}, {'person_id': 3, 'something..': 'else'}, {'person_id': 1, 'something..': 'else'}]
如何将具有相同“person_id”的所有字典分组为列表,并将以前的字典列表拆分为字典列表(内部列表仅包含具有相同“person_id”的字典)。
[[{'person_id': 1, 'something..': 'else'}, {'person_id': 1, 'something..': 'else'}], [{'person_id': 3, 'something..': 'else'}]]
我通过简单的迭代完成了这一工作,并且这些字典已经列出了检查,但是在Python中有有效的方法吗?
发布于 2014-01-21 16:34:46
您的输入不是按person_id
排序的,所以使用带有循环的collections.defaultdict()
方法:
from collections import defaultdict
grouped = defaultdict(list)
for person in inputlist:
grouped[person['person_id']].append(person)
grouped = grouped.values()
这将输入列表排序为存储桶,然后将所有存储桶重新放到外部列表中。如果需要按id对输出进行排序,可以使用:
grouped = [grouped['pid'] for pid in sorted(grouped)]
如果需要按排序顺序排列的原始列表,或者可以按排序顺序生成列表,也可以使用itertools.groupby()
进行分组:
from itertools import groupby
from operator import itemgetter
grouped = [list(g) for p, g in groupby(inputlist, key=itemgetter('person_id'))]
但这确实需要首先对inputlist
进行排序。
https://stackoverflow.com/questions/21263766
复制相似问题