我有两次不同的考试成绩。我将两个测试存储在一个单独的列表中。我如何合并这两个列表并获得最终结果?
returnn = sorted(returnscore, key=itemgetter('score'), reverse=True)
for rij in returnn:
print rij输出:
{'E-mail': 'tim@gmail.com', 'score': 10}
{'E-mail': 'tim@gmail.com', 'score': 10}
{'E-mail': 'tim@gmail.com', 'score': 10}
{'E-mail': 'tim@gmail.com', 'score': 10}
{'E-mail': 'hihallo@gmail.com', 'score': 5}
{'E-mail': 'noreply@com', 'score': 5}
{'E-mail': 'marketing@nl', 'score': 5}
spff = sorted(spfscore, key=itemgetter('score'), reverse=True)
for rij in spff:
print rij输出:
{'E-mail': 'tim@gmail.com', 'score': 3}
{'E-mail': 'tim@gmail.com', 'score': 0}
{'E-mail': 'tim@gmail.com', 'score': 7}
{'E-mail': 'tim@gmail.com', 'score': 0}
{'E-mail': 'hihallo@gmail.com', 'score': 0}
{'E-mail': 'noreply@com', 'score': 0}
{'E-mail': 'arketing@nl', 'score': 1}我想要的输出是:
{'E-mail': 'tim@gmail.com', 'score': 50}
{'E-mail': 'hihallo@gmail.com', 'score': 5}
{'E-mail': 'noreply@com', 'score': 5}
{'E-mail': 'arketing@nl', 'score': 6}我已经想了几个小时了。我只是不明白我怎么能数分数,然后去掉复本。
发布于 2017-10-09 11:55:50
一种简单的方法是简单地创建一个新的dict对象,其中包含电子邮件地址作为其(唯一)键,然后迭代列表,如果元素已经在列表中,则增加分数计数,或者如果电子邮件地址尚未在dict中,则创建带有分数计数的dict条目。
scores_raw = [{'E-mail': 'tim@gmail.com', 'score': 10},
{'E-mail': 'tim@gmail.com', 'score': 10},
{'E-mail': 'tim@gmail.com', 'score': 10},
{'E-mail': 'tim@gmail.com', 'score': 10},
{'E-mail': 'hihallo@gmail.com', 'score': 5},
{'E-mail': 'noreply@com', 'score': 5},
{'E-mail': 'marketing@nl', 'score': 5}]
scores_unique = {}
for item in scores_raw:
if item['E-mail'] not in scores_unique:
scores_unique.update({item['E-mail']: item['score']})
else:
scores_unique[item['E-mail']] += item['score']
print (scores_unique)输出:{'tim@gmail.com': 40, 'hihallo@gmail.com': 5, 'noreply@com': 5, 'marketing@nl': 5}
发布于 2017-10-09 12:39:25
从迭代工具中使用groupby的另一种方法
from itertools import groupby
scores_raw = [
{'E-mail': 'tim@gmail.com', 'score': 10},
{'E-mail': 'tim@gmail.com', 'score': 10},
{'E-mail': 'tim@gmail.com', 'score': 10},
{'E-mail': 'tim@gmail.com', 'score': 10},
{'E-mail': 'hihallo@gmail.com', 'score': 5},
{'E-mail': 'noreply@com', 'score': 5},
{'E-mail': 'marketing@nl', 'score': 5}
]
scores_unique=[]
for _key, _items in groupby(sorted(scores_raw),key=lambda x: x['E-mail']):
scores_unique.append({
'E-mail':_key,
'score':sum(item['score'] for item in _items)
})
print (scores_unique)结果:
[{'E-mail': 'hihallo@gmail.com', 'score': 5}, {'E-mail': 'marketing@nl', 'score': 5}, {'E-mail': 'noreply@com', 'score': 5}, {'E-mail': 'tim@gmail.com', 'score': 40}]https://stackoverflow.com/questions/46645753
复制相似问题