Si potrebbe provare questo:
In [9]: l = [[3,7,2],[1,4,5],[9,8,7]]
In [10]: [sum(i) for i in zip(*l)]
Out[10]: [13, 19, 14]
Questo utilizza una combinazione di zip
e *
per decomprimere la lista e poi zip gli elementi in base al loro indice. Quindi usi una list comprehension per iterare attraverso i gruppi di indici simili, sommandoli e ritornando nella loro posizione 'originale'.
Per rendere spero che un po 'più chiaro, qui è ciò che accade quando si scorrere attraverso zip(*l)
:
In [13]: for i in zip(*l):
....: print i
....:
....:
(3, 1, 9)
(7, 4, 8)
(2, 5, 7)
Nel caso di liste che sono di lunghezza diversa, è possibile utilizzare itertools.izip_longest
con una fillvalue
di 0
- questo riempie fondamentalmente indici mancanti con 0
, che consente di sommare tutti 'colonne':
In [1]: import itertools
In [2]: l = [[3,7,2],[1,4],[9,8,7,10]]
In [3]: [sum(i) for i in itertools.izip_longest(*l, fillvalue=0)]
Out[3]: [13, 19, 9, 10]
In questo caso, qui è che cosa l'iterazione su izip_longest
sarà simile:
In [4]: for i in itertools.izip_longest(*l, fillvalue=0):
...: print i
...:
(3, 1, 9)
(7, 4, 8)
(2, 0, 7)
(0, 0, 10)
[Cosa hai provato?] (Http://whathaveyoutried.com/) –