msa*_*kya 9 python dictionary tuples python-2.7
我有一个以下格式的元组:
(639283, 298290710, 1385)
(639283, 298290712, 1389)
(639283, 298290715, 1395)
(745310, 470212995, 2061)
(745310, 470213821, 3713)
(745310, 470215360, 6791)
(745310, 470215361, 6793)
(745310, 470215363, 6797)
(911045, 374330803, 4905)
(911045, 374330804, 4907)
(911045, 374330807, 4913)
(911045, 374330808, 4915)
(911045, 374330809, 4917)
Run Code Online (Sandbox Code Playgroud)
我想转换成这样的嵌套字典:
{639283:{298290710:1385, 298290712:1389, 298290715:1395},745310:{470212995:2061,470213821:3713}............}
Run Code Online (Sandbox Code Playgroud)
有这样做的pythonic方式吗?看起来很简单,但我似乎无法弄清楚这一点.
Hen*_*ter 10
您可以结合使用元组拆包collections.defaultdict来让您的生活更轻松.
defaultdict使用dict默认值创建外部.然后,您只需循环遍历元组列表一次,随时设置适当的值.
from collections import defaultdict
d = defaultdict(dict) # dict where the default values are dicts.
for a, b, c in list_of_tuples: # Each tuple is "key1, key2, value"
d[a][b] = c
Run Code Online (Sandbox Code Playgroud)
当然,你大概知道更多关于这些值实际上代表了,所以你可以给你的字典,以及个别项目,不是更好,更具描述性的名称a,b,c,和d.
您可以使用itertools.groupby基于第一个项目对元组进行分组,然后在dict-comprehension中迭代这些组以获得所需的结果.
>>> from operator import itemgetter
>>> from pprint import pprint
>>> from itertools import groupby
>>> d = {k: dict(x[1:] for x in g) for k, g in groupby(data, key=itemgetter(0))}
>>> pprint(d)
{639283: {298290710: 1385, 298290712: 1389, 298290715: 1395},
745310: {470212995: 2061,
470213821: 3713,
470215360: 6791,
470215361: 6793,
470215363: 6797},
911045: {374330803: 4905,
374330804: 4907,
374330807: 4913,
374330808: 4915,
374330809: 4917}}
Run Code Online (Sandbox Code Playgroud)
data你的元组或元组元组列表在哪里.