2016-05-01 12 views

Antwort

8

Verwenden Sie ein 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

Das ist genau das, was ich will. Vielen Dank! – Malgi

5

setdefault ist dein Freund:

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

Wenn Sie es in einem (ziemlich langen) Linie tun möchten, können Sie itertools.groupby verwenden, aber denken Sie daran, dass die Liste muss sorted mit dem Schlüssel sein, damit dies funktioniert:

>>> 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

Lustige Tatsache: '{v [1]: v [2] für v in vals}' ist genau so lang wie 'dict (zip (* zip (* vals) [1:])) '(aber wahrscheinlich viel performanter und lesbar: D) – schwobaseggl

Verwandte Themen