按标识符计算每列中的值。请看例子。(我很难解释:()
像这样:
tdata = [
('column 1', [
(1, 5), (2, 10), (3, 200)
]
),
('column 2', [
(1, 20), (2, 300), (3, 100)
]
),
('column 3', [
(1, 2), (2, 300), (3, 2000)
]
)
]
从这个数据集中,我需要找到一种 Python 方法来仅计算内部元组的第一个值匹配的元组的子值。
所以我会做 Col1 = 5+20+2, Col2 = 10+300+300, Col3 = 200+100+2000。
我可以像这样以真正的代码密集型方式完成此任务:
col1 = []
col2 = []
col3 = []
data = []
for (column_name, column_values) in tdata:
for (key, value) in column_values:
if key == 1:
col1.append(value)
elif key == 2:
col2.append(value)
elif key == 3:
col3.append(value)
data = [('Column 1', sum(col1)), ('Column 2', sum(col2)), ('Column 3', sum(col3))]
显然,这是很多代码,而不是最有效的方法。任何见解将不胜感激。