我有一个列表列表,我需要比较所有元素的项目0和项目2.如果这些项目相等,我想总结第1项和第3项.更清楚:
list1 = [['diez.hn','Arts','Austria','8'], ['diez.hn','Entertainment','Austria','12']]
element 0 of list1: ['diez.hn','Arts','Austria','8']
element 1 of list1: ['diez.hn','Entertainment','Austria','12']
Run Code Online (Sandbox Code Playgroud)
我需要的:
list_ok = [['diez.hn','Arts - Entertainment','Austria','20']]
Run Code Online (Sandbox Code Playgroud)
我尝试过这样的事情:
reader = [['diez.hn','Arts','Austria','8'], ['diez.hn','Entertainment','Austria','12']]
reader2 = [['diez.hn','Arts','Austria','8'], ['diez.hn','Entertainment','Austria','12']]
for item in reader:
for item2 in reader2:
if item[0] and item[2] == item2[0] and item2[2]:
item[1] = item[1] + item2[1]
item[3] = item[3] + item2[3]
Run Code Online (Sandbox Code Playgroud)
此方法对列表进行排序,然后用于itertools.groupby()对位置0和2中具有相同元素的子列表进行分组:
import itertools
import operator
list1.sort(key=operator.itemgetter(0, 2))
list_ok = []
for k, group in itertools.groupby(list1, key=operator.itemgetter(0, 2)):
group = list(group)
list_ok.append([
k[0],
' - '.join(item[1] for item in group),
k[1],
str(sum(int(item[3]) for item in group)),
])
Run Code Online (Sandbox Code Playgroud)