Pergunta

Eu tenho uma lista de tuplas como esta:

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

Eu quero iterate através deste chaveamento pelo primeiro item, assim, por exemplo eu poderia imprimir algo como isto:

a 1 2 3
b 1 2
c 1

Como eu iria sobre como fazer isso sem manter um item para controlar se o primeiro item é o mesmo que eu laço em volta das tuplas? Isso sente-se um pouco confuso (mais eu tenho para ordenar a lista para começar) ...

Foi útil?

Solução

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

produz:

{'a': [1, 2, 3], 'c': [1], 'b': [1, 2]}

Outras dicas

Um pouco mais simples ...

>>> 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]})

A solução usando 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]) dá-lhe um iterador que contém [ 'a', [( 'a', 1), ...], c, [( 'c', 1) ], ...]

Imprimir lista de tuplas agrupamento pelo primeiro item

Esta resposta é baseada na o @gommen um .

#!/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)

Output:

a 1 2 3
b 1 2
c 1

Gostaria apenas de fazer o básico

answer = {}
for key, value in list_of_tuples:
  if key in answer:
    answer[key].append(value)
  else:
    answer[key] = [value]

Se é este pequeno, por que usar nada complicado. Claro, se você não se importa usando setdefault tudo bem também.

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top