如何在python中将元组转换为多嵌套字典?

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.

  • 我认为这两种反应都很棒,但这似乎相当直观和干净。所以,我接受这个:) (2认同)

Ash*_*ary 8

您可以使用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你的元组或元组元组列表在哪里.