我有一个这样的元组列表:
[
('a', 1),
('a', 2),
('a', 3),
('b', 1),
('b', 2),
('c', 1),
]
我想通过第一项来遍历这个键控,所以,例如,我可以打印这样的东西:
a 1 2 3
b 1 2
c 1
如果不保留一个项目来跟踪第一个项目是否与我在元组周围循环的相同,我将如何去做呢?这感觉相当混乱(另外我必须从列表开始排序)......
我有一个这样的元组列表:
[
('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)
print(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)], 的迭代器。 ..]
我只会做基本的
答案 = {} 对于 list_of_tuples 中的键、值: 如果键入答案: 答案[key].append(value) 别的: 答案[键] = [值]
如果它这么短,为什么要使用任何复杂的东西。当然,如果您不介意使用 setdefault 也没关系。
这个答案基于@gommen one。
#!/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