python多个字典合并包含同样key的字典项?

有一个列表中包括多个字典,例如:list1=[{'name':'yyy',score:78},{'name':'www',score:78},{'name':'yyy',score:22}],如何将该list中name相同的人的成绩汇总,最后变为:list1=[{'name':'yyy',score:100},{'name':'www',score:78}]?求大神解答

阅读 11k
1 个回答

先提一下你问题中的语法错误

{'name':'yyy', score:78}     // score应和name一样是字符串
{'name':'yyy', 'score':78}     // Correct

然后回答问题。
标准库范围内因本人能力有限,想不到特别Pythonic的方法。
我这里用的是pandas:

import pandas as pd

list1 = [{'name':'yyy', 'score':78}, {'name':'www', 'score':78}, {'name':'yyy', 'score':22}]
df = pd.DataFrame(list1)
result = df.groupby(['name']).sum()

print result

输出结果:

name   score
www      78
yyy     100

其中df值为:

  name  score
0  yyy     78
1  www     78
2  yyy     22
宣传栏