[英]Converting a list of tuples into a dict
我有一個像這樣的元組列表:
[
('a', 1),
('a', 2),
('a', 3),
('b', 1),
('b', 2),
('c', 1),
]
我想通過第一個項目迭代這個鍵控,所以,例如,我可以打印這樣的東西:
a 1 2 3
b 1 2
c 1
如何在不保持項目跟蹤第一項是否與我在元組周圍循環相同的情況下進行此操作? 這感覺相當混亂(加上我必須從列表開始排序)...
l = [
('a', 1),
('a', 2),
('a', 3),
('b', 1),
('b', 2),
('c', 1),
]
d = {}
for x, y in l:
d.setdefault(x, []).append(y)
print d
生產:
{'a': [1, 2, 3], 'c': [1], 'b': [1, 2]}
稍微簡單......
>>> from collections import defaultdict
>>> fq= defaultdict( list )
>>> for n,v in myList:
fq[n].append(v)
>>> fq
defaultdict(<type 'list'>, {'a': [1, 2, 3], 'c': [1], 'b': [1, 2]})
使用groupby的解決方案
>>> from itertools import groupby
>>> l = [('a',1), ('a', 2),('a', 3),('b', 1),('b', 2),('c', 1),]
>>> [(label, [v for l,v in value]) for (label, value) in groupby(l, lambda x:x[0])]
[('a', [1, 2, 3]), ('b', [1, 2]), ('c', [1])]
groupby(l,lambda x:x [0])給你一個包含['a',[('a',1),...],c,[('c',1)]的迭代器。 ..]
這個答案基於@gommen 。
#!/usr/bin/env python
from itertools import groupby
from operator import itemgetter
L = [
('a', 1),
('a', 2),
('a', 3),
('b', 1),
('b', 2),
('c', 1),
]
key = itemgetter(0)
L.sort(key=key) #NOTE: use `L.sort()` if you'd like second items to be sorted too
for k, group in groupby(L, key=key):
print k, ' '.join(str(item[1]) for item in group)
輸出:
a 1 2 3
b 1 2
c 1
我會做基本的
answer = {} for key, value in list_of_tuples: if key in answer: answer[key].append(value) else: answer[key] = [value]
如果這么短,為什么要使用任何復雜的東西。 當然如果你不介意使用setdefault也沒關系。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.