40

次のようなタプルのリストがあります。

[
('a', 1),
('a', 2),
('a', 3),
('b', 1),
('b', 2),
('c', 1),
]

最初のアイテムでこのキーイングを反復したいので、たとえば、次のように出力できます。

a 1 2 3
b 1 2
c 1

最初のアイテムがタプルをループするのと同じかどうかを追跡するためにアイテムを保持せずに、どうすればこれを行うことができますか? これはかなり面倒です(さらに、最初にリストをソートする必要があります)...

4

5 に答える 5

42
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]}
于 2008-11-04T12:07:21.253 に答える
38

もう少しシンプルに...

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]})
于 2008-11-04T12:11:52.087 に答える
10

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)], を含む反復子を提供します。 ..]

于 2008-11-04T12:42:32.493 に答える
3

基本だけやります

答え = {}
list_of_tuples のキー、値の場合:
  答えのキーの場合:
    answer[キー].append(値)
  そうしないと:
    回答[キー] = [値]

これほど短いのなら、なぜ複雑なものを使う必要があるのでしょう。もちろん、setdefault を使用してもかまわないのであれば、それも問題ありません。

于 2008-11-04T17:06:28.187 に答える
2

最初の項目でグループ化されたタプルのリストを出力します

この回答は@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
于 2009-11-07T23:11:33.383 に答える