私はこのようなタプルのリストを持っています:
[
('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 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
私は基本的なことをするだけです
answer = {} keyの場合、list_of_tuplesの値: if key in answer: answer [key] .append(value) else: answer [key] = [value]
これほど短い場合は、なぜ複雑なものを使用するのですか。もちろん、setdefaultを使用してもかまわない場合は、それでもかまいません。