我有一个名字,角色,多年经验的csv。我想为所有employess创建一个集合列表(name, role1, total_exp_inthisRole)
。 到目前为止,我能够用defaultdict做以下有效使用python groupby或defaultdict?
import csv, urllib2
from collections import defaultdict
response = urllib2.urlopen(url)
cr = csv.reader(response)
parsed = ((row[0],row[1],int(row[2])) for row in cr)
employees =[]
for item in parsed:
employees.append(tuple(item))
employeeExp = defaultdict(int)
for x,y,z in employees: # variable unpacking
employeeExp[x] += z
employeeExp.items()
输出:[('Ken', 15), ('Buckky', 5), ('Tina', 10)]
但我如何使用第二个栏也能达到我想要的结果。我可以尝试通过groupby
解决多个键或更简单的方法吗?感谢所有提前。
你可以给一个例子你想要的结果多少?我的意思是你想如何聚合这些列? – Kasramvd
是的! ('Ken','engineer',5),('ken,'sr。engineer',6),...]或[('Ken',('engineer',5),''sr。工程师',6)),...] – user6384905