我有以下字典
mylist = [{'tpdt': '0.00', 'tmst': 45.0, 'tmdt': 45.0, 'pbc': 30, 'remarks': False, 'shift': 1, 'ebct': '0.00', 'tmcdt': '0.00', 'mc_no': 'KA20'},
{'tpdt': '0.00', 'tmst': 45.0, 'tmdt': 45.0, 'pbc': 30, 'remarks': False, 'shift': 1, 'ebct': '0.00', 'tmcdt': '0.00', 'mc_no': 'KA20'},
{'tpdt': '0.00', 'tmst': 55.0, 'tmdt': 55.0, 'pbc': 30, 'remarks': False, 'shift': 1, 'ebct': '0.00', 'tmcdt': '0.00', 'mc_no': 'KA23'},
{'tpdt': '0.00', 'tmst': 55.0, 'tmdt': 55.0, 'pbc': 30, 'remarks': False, 'shift': 1, 'ebct': '0.00', 'tmcdt': '0.00', 'mc_no': 'KA23'}]
我希望得到字典列表中每个字典值'KA20'和'KA23'的键'tmst'的总和。
请你就此提出建议吗?
答案 0 :(得分:21)
您可以使用itertools.groupby
:
>>> for key, group in itertools.groupby(mylist, lambda item: item["mc_no"]):
... print key, sum([item["tmst"] for item in group])
...
KA20 90.0
KA23 110.0
请注意,要使groupby
正常工作,mylist
必须按分组键排序:
from operator import itemgetter
mylist.sort(key=itemgetter("mc_no"))
答案 1 :(得分:5)
首先,您需要对该词典列表进行排序。使用以下代码。 实施例
animals = [{'name':'cow', 'size':'large'},{'name':'bird', 'size':'small'},{'name':'fish', 'size':'small'},{'name':'rabbit', 'size':'medium'},{'name':'pony', 'size':'large'},{'name':'squirrel', 'size':'medium'},{'name':'fox', 'size':'medium'}] import itertools from operator import itemgetter sorted_animals = sorted(animals, key=itemgetter('size'))
然后使用以下代码
for key, group in itertools.groupby(sorted_animals, key=lambda x:x['size']): print key, print list(group)
您将获得以下结果......
large [{'name': 'cow', 'size': 'large'}, {'name': 'pony', 'size':'large'}] medium [{'name': 'rabbit', 'size': 'medium'}, {'name': 'squirrel', 'size':'medium'}, {'name': 'fox', 'size': 'medium'}] small [{'name': 'bird', 'size': 'small'}, {'name': 'fish', 'size': 'small'}]
答案 2 :(得分:2)
这是一个代码,不需要mylist
按"mc_no"
键排序:
from collections import defaultdict
sums = defaultdict(int) # key -> sum
for d in mylist:
sums[d["mc_no"]] += d["tmst"]