Python의 목록에서 중복 사전 제거
Python에서 사전 목록을 처리할 때 중복을 제거해야 할 수도 있습니다. 중복 항목이 동일한 키-값 쌍을 공유하든, 정확한 키-값 순서를 공유하든 효율적인 접근 방식이 필요합니다.
중복 제거를 위해 해싱 사용
다음 한 줄 키-값 쌍을 기반으로 중복 사전을 효과적으로 제거합니다.
[dict(t) for t in {tuple(d.items()) for d in l}]
이 접근 방식에는 각 사전을 키-값 쌍의 튜플입니다. 튜플은 해시될 수 있으므로 설정된 데이터 구조를 활용하여 중복을 제거할 수 있습니다. 결과 세트에는 고유한 튜플이 포함되어 있으며, 이 튜플은 다시 사전으로 변환됩니다.
순서 유지
사전의 순서가 중요한 경우 위의 접근 방식으로는 충분하지 않습니다. 대신, 보다 명시적인 방법을 사용할 수 있습니다.
l = [{'a': 123, 'b': 1234}, {'a': 3222, 'b': 1234}, {'a': 123, 'b': 1234}] seen = set() new_l = [] for d in l: t = tuple(d.items()) if t not in seen: seen.add(t) new_l.append(d) print(new_l)
이 코드는 원래 순서를 유지하면서 중복되지 않는 사전을 새 목록에 누적합니다. 고유성을 보장하기 위해 집합을 활용하여 발생한 튜플을 추적합니다.
참고:
어떤 경우에는 동일한 키와 값을 가진 두 개의 사전이 있다는 점에 유의하는 것이 중요합니다. 동일한 튜플이 생성되지 않을 수 있습니다. 이는 사전의 키 추가/제거 순서가 다를 때 발생합니다. 시나리오에서 이것이 문제가 되는 경우 튜플을 생성하기 전에 각 사전의 항목을 정렬하는 것이 좋습니다.
위 내용은 Python 목록에서 중복 사전을 효율적으로 제거하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!