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
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
宣传栏