繁体   English   中英

在Python中汇总列表 - 在元组和另一个列表中

[英]Summing a list in Python - within a tuple and another list

不确定它是否是重复 - 如果是这样将删除,只是没有为此特定方案找到一个。 我有一个包含字符串和列表的复杂列表,其中包含元组。

我需要用int值替换最深的列表,这些值是这些列表的总和。 我已经尝试了六个循环组合来解决它 - 似乎没有任何效果。

[('MED', [1, 1]), ('COP', [3, 1]), ('GRO', [1, 5]), ('RRE', [5, 3]), ('PRO', [4, 6])]

需要成为:

[('MED', 2), ('COP', 4), ('GRO', 6), ('RRE', 8), ('PRO', 10)]

这样我就可以返回按汇总列表的值排序的新列表组合。

您可以使用以下内容进行简明易懂的理解:

[(abbr, sum(t)) for abbr, t in l]

结果:

[('MED', 2), ('COP', 4), ('GRO', 6), ('RRE', 8), ('PRO', 10)]

使用map

例如:

lst = [('MED', [1, 1]), ('COP', [3, 1]), ('GRO', [1, 5]), ('RRE', [5, 3]), ('PRO', [4, 6])]
print(list(map(lambda x: (x[0], sum(x[1])), lst)))

list comprehension

例如:

print([(i[0], sum(i[1])) for i in lst])

输出:

[('MED', 2), ('COP', 4), ('GRO', 6), ('RRE', 8), ('PRO', 10)]
oldlst = [('MED', [1, 1]), ('COP', [3, 1]), ('GRO', [1, 5]), ('RRE', [5, 3]), ('PRO', [4, 6])]

newlst = list([(i[0], sum(i[1])) for i in oldlst])

点击这里

让我们使用列表推导来解决它 -

myList = [('MED', [1, 1]), ('COP', [3, 1]), ('GRO', [1, 5]), ('RRE', [5, 3]), ('PRO', [4, 6])]
myList_out = [(i[0],sum(i[1])) for i in myList]
myList_out
    [('MED', 2), ('COP', 4), ('GRO', 6), ('RRE', 8), ('PRO', 10)]

通过使用collections.defaultdict。

from collections import defaultdict
xList = [('MED', [1, 1]), ('COP', [3, 1]), ('GRO', [1, 5]), ('RRE', [5, 3]), ('PRO', [4, 6])]
testDict = defaultdict(int)
for key, val in xList:           
        testDict[key] = val[0] + val[1]

print(testDict.items())

OUTPUT: 出

lst = [('MED', [1, 1]),('COP', [3, 1]),('GRO', [1, 5]),('RRE', [5, 3]),('PRO', [4, 6])]

print [(text, sum(num)) for text, num in lst]

结果:

[('MED', 2), ('COP', 4), ('GRO', 6), ('RRE', 8), ('PRO', 10)]

尝试这个:

l1 = [('MED', [1, 1]), ('COP', [3, 1]), ('GRO', [1, 5]), ('RRE', [5, 3]), ('PRO', [4, 6])]

mod_l1 = [(abbr, sum(t)) for abbr, t in l1]

required_l1 = sorted(mod_l1, key=lambda order: order[1])

结果:

[('MED', 2), ('COP', 4), ('GRO', 6), ('RRE', 8), ('PRO', 10)]

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM