2016-05-01 18 views

risposta

8

Utilizzare un defaultdict:

from collections import defaultdict 

l = [(1, 'a', 22), (2, 'b', 56), (1, 'b', 34), (2, 'c', 78), (3, 'd', 47)] 

d = defaultdict(dict) 
for x, y, z in l: 
    d[x][y] = z 
+0

Questo è esattamente quello che voglio. Grazie! – Malgi

5

setdefault è tuo amico:

d = {} 
for t in l: 
    d.setdefault(t[0],{})[t[1]]=t[2] 
4

Se si vuole fare in una linea (piuttosto lungo), è possibile utilizzare itertools.groupby, ma ricordate che la l'elenco deve essere sorted tramite la chiave affinché funzioni:

>>> lst = [(1, 'a', 22), (2, 'b', 56), (1, 'b', 34), (2, 'c', 78), (3, 'd', 47)] 
>>> {key: {v[1]: v[2] for v in vals} for key, vals in itertools.groupby(sorted(lst), key=operator.itemgetter(0))} 
{1: {'a': 22, 'b': 34}, 2: {'b': 56, 'c': 78}, 3: {'d': 47}} 
+0

Fatto divertente: '{v [1]: v [2] per v in vals}' è esattamente il tempo di 'dict (zip (* zip (* vals) [1:])) (ma probabilmente molto più performante e leggibile: D) – schwobaseggl

Problemi correlati