python 정렬 튜플리스트를 파이썬에서 Dict로 변환하기



파이썬 리스트를 딕셔너리로 (4)

다음과 같은 튜플 목록이 있습니다.

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

첫 번째 항목에서이 키잉을 반복하고 싶습니다. 예를 들어 다음과 같이 인쇄 할 수 있습니다.

a 1 2 3
b 1 2
c 1

첫 번째 항목이 튜플 주위를 반복하는 것과 같은지 추적하기 위해 항목을 유지하지 않고이 작업을 수행하는 방법은 무엇입니까? 이것은 오히려 지저분한 느낌이 듭니다. (플러스로 시작하려면 목록을 정렬해야합니다) ...

감사,


약간 더 간단하게 ...

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

첫 번째 항목으로 그룹화 된 튜플 목록 인쇄

이 답변은 @gomen 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 = {}
for key, value in list_of_tuples:
  if key in answer:
    answer[key].append(value)
  else:
    answer[key] = [value]

이 짧은 경우 왜 복잡한 것을 사용해야합니다. 물론 setdefault를 사용해도 상관 없으면 괜찮습니다.


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)]를 포함하는 반복자를 제공합니다. ..]





iteration