有一个列表中包括多个字典,例如:list1=[{'name':'yyy',score:78},{'name':'www',score:78},{'name':'yyy',score:22}],如何将该list中name相同的人的成绩汇总,最后变为:list1=[{'name':'yyy',score:100},{'name':'www',score:78}]?求大神解答
先提一下你问题中的语法错误
:
{'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