Yanıtlar:
Deneyin:
>>> t = ((1, 'a'),(2, 'b'))
>>> dict((y, x) for x, y in t)
{'a': 1, 'b': 2}
dict((x, y) for x, y, z in t)
veya dict((x, (y, z)) for x, y, z in t)
ikinci ve üçüncü değerleri bir demet olarak almak için.
Biraz daha basit bir yöntem:
>>> t = ((1, 'a'),(2, 'b'))
>>> dict(map(reversed, t))
{'a': 1, 'b': 2}
reverse
açıkça dile getirdim .
map
eşlenen şeyin başka bir yerleşik işlev ( ör.) olduğu zaman bir anlamadan daha hızlı olduğunu gösterir reversed
; diğer çoğu durumda, tam tersi doğrudur. Ama tahmin etmek profil yapmak daha iyi :)
Python 2.7 kullanıyorsanız daha da özlü:
>>> t = ((1,'a'),(2,'b'))
>>> {y:x for x,y in t}
{'a':1, 'b':2}
>>> dict([('hi','goodbye')])
{'hi': 'goodbye'}
Veya:
>>> [ dict([i]) for i in (('CSCO', 21.14), ('CSCO', 21.14), ('CSCO', 21.14), ('CSCO', 21.14)) ]
[{'CSCO': 21.14}, {'CSCO': 21.14}, {'CSCO': 21.14}, {'CSCO': 21.14}]
İşte bunu yapmanın birkaç yolu:
>>> t = ((1, 'a'), (2, 'b'))
>>> # using reversed function
>>> dict(reversed(i) for i in t)
{'a': 1, 'b': 2}
>>> # using slice operator
>>> dict(i[::-1] for i in t)
{'a': 1, 'b': 2}
dict(zip(*zip(*t)[::-1]))
. Bu daha yavaş, daha çirkin ve daha fazla bellek kullanıyor.