18

我有以下字典

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' 的总和。

请问您对此有什么建议吗??

4

3 回答 3

29

您可以使用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"))
于 2013-08-12T06:33:24.087 回答
8

首先,您需要对该字典列表进行排序..使用以下代码.. 例如。

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)
得到以下结果后...
大 [{'name': 'cow', 'size': 'large'}, {'name': 'pony', 'size':'large'}]
中等 [{'name': 'rabbit', 'size': 'medium'}, {'name': 'squirrel', 'size':'medium'}, {'name': 'fox', 'size' : '中等的'}]
小 [{'name': '鸟', 'size': 'small'}, {'name': 'fish', 'size': 'small'}]
于 2016-04-28T11:05:47.217 回答
2

这是一个不需要按键mylist排序的代码:"mc_no"

from collections import defaultdict

sums = defaultdict(int)  # key -> sum
for d in mylist:
    sums[d["mc_no"]] += d["tmst"]
于 2016-04-28T11:25:27.357 回答