我有一个迭代器,可以产生N个元组,但这里我假装只有3个。它们的长度都是偶数。
t1 = (a1, b1, c1)
t2 = (a2, b2, c2)
t3 = (a3, b3, c3)
我希望将上述内容转换为以下内容:
d = {a1: [a2, a3],
b1: [b2, b3],
c1: [c2, c3]}
我明白我应该遍历元组并将它们以某种方式压缩成字典,但我基本上卡住了。
我有一个迭代器,可以产生N个元组,但这里我假装只有3个。它们的长度都是偶数。
t1 = (a1, b1, c1)
t2 = (a2, b2, c2)
t3 = (a3, b3, c3)
d = {a1: [a2, a3],
b1: [b2, b3],
c1: [c2, c3]}
>>> lists = [['a1', 'b1', 'c1'], ['a2', 'b2', 'c2'], ['a3', 'b3', 'c3']]
>>> d = {list[0]:list[1:] for list in zip(*lists)}
>>> print d
>>> {'a1': ('a2', 'a3'), 'b1': ('b2', 'b3'), 'c1': ('c2', 'c3')}
这是一种实现您想要的方法:
ls = [['a1', 'b1', 'c1'], ['a2', 'b2', 'c2'], ['a3', 'b3', 'c3']]
# I create an iterator since that what you have in your problem
it = iter(ls)
keys = it.next()
d = {k: [] for k in keys}
for l in it:
for i, e in enumerate(l):
d[keys[i]].append(e)
生成的字典为{'a1': ['a2', 'a3'], 'c1': ['c2', 'c3'], 'b1': ['b2', 'b3']}
。
d
,您可以执行以下操作:d = collections.defaultdict(list)
。 - Ozgur Vatansever