> 백엔드 개발 > 파이썬 튜토리얼 > 순서를 유지하거나 무시하면서 Python의 목록에서 중복 항목을 효율적으로 제거하려면 어떻게 해야 합니까?

순서를 유지하거나 무시하면서 Python의 목록에서 중복 항목을 효율적으로 제거하려면 어떻게 해야 합니까?

DDD
풀어 주다: 2024-12-20 15:26:14
원래의
627명이 탐색했습니다.

How Can I Efficiently Remove Duplicates from a List in Python While Maintaining or Ignoring Order?

목록에서 중복 요소 제거

목록에서 중복 요소를 식별하고 제거하는 것은 프로그래밍의 기본 작업입니다. 이 기사에서는 순서 보존과 솔루션의 효율성을 모두 고려하여 이를 달성하기 위한 다양한 방법을 살펴봅니다.

효율적인 중복 제거를 위한 세트 사용

간단하고 효율적인 목록에서 중복 항목을 제거하는 방법은 목록을 집합으로 변환하는 것입니다. 세트는 고유한 요소를 순서 없이 모아 놓은 것입니다. 목록을 세트로 변환하면 모든 중복 항목이 자동으로 제거됩니다. 중복 없이 목록을 다시 생성하려면 수정된 집합을 list() 함수를 사용하여 다시 목록으로 변환할 수 있습니다.

아래 예를 고려하세요.

t = [1, 2, 3, 1, 2, 3, 5, 6, 7, 8]
unique_list = list(set(t))
로그인 후 복사

결과인 Unique_list는 [1, 2, 3, 5, 6, 7, 8]이 되고, 모두 중복됩니다. 삭제되었습니다.

OrderedDict 또는 사전을 사용하여 순서 유지

요소의 원래 순서를 유지하는 것이 중요한 경우 세트는 순서가 지정되지 않은 컬렉션이므로 사용할 수 없습니다. 대신 OrderedDict 또는 사전을 사용하여 삽입 순서를 유지할 수 있습니다.

OrderedDict 사용:

from collections import OrderedDict
ordered_unique_list = list(OrderedDict.fromkeys(t))
로그인 후 복사

사전 사용(Python 3.7 이상):

unique_list = list(dict.fromkeys(t))
로그인 후 복사

두 접근 방식 모두 원본을 유지하면서 중복 항목이 제거된 목록을 반환합니다.

성능 고려 사항

목록을 집합으로 변환했다가 다시 목록으로 변환하는 것은 효율적이지만 추가 오버헤드가 발생할 수 있습니다. 순서가 중요하지 않은 경우 일반적으로 속도와 다양성을 위해 세트를 사용하는 것이 좋습니다. 그러나 순서를 유지해야 하는 경우 OrderedDict 또는 사전 접근 방식이 실행 가능한 옵션을 제공합니다.

해싱할 수 없는 항목 처리

세트, OrderedDict 및 사전 솔루션에서는 목록의 요소가 해시 가능해야 합니다. 해시할 수 없는 요소(예: 목록)의 경우 각 요소를 다른 모든 요소와 비교하려면 중첩 루프를 사용하는 더 느린 접근 방식이 필요합니다.

위 내용은 순서를 유지하거나 무시하면서 Python의 목록에서 중복 항목을 효율적으로 제거하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿