>  기사  >  데이터 베이스  >  순서를 유지하면서 Python 목록에서 중복 개체를 효율적으로 제거하려면 어떻게 해야 합니까?

순서를 유지하면서 Python 목록에서 중복 개체를 효율적으로 제거하려면 어떻게 해야 합니까?

Barbara Streisand
Barbara Streisand원래의
2024-10-27 00:22:30339검색

How Do I Efficiently Remove Duplicate Objects from a Python List While Preserving Order?

Python을 사용하여 중복 개체를 효율적으로 처리

Python에서는 원래 순서를 유지하면서 목록에서 중복 개체를 제거해야 할 수 있습니다. 이 문제는 사용자 정의 개체 목록이 있고 특정 기준에 따라 중복 항목을 필터링하거나 데이터베이스에서 중복 항목을 확인하려는 경우에 발생합니다.

특정 요구 사항과 관련하여 효과적으로 사용하려면 개체 내에서 고유성을 정의해야 합니다. set(list_of_objects) 메소드. 여기에는 eqhash 메소드를 구현하여 객체를 해시 가능하게 만드는 작업이 포함됩니다.

eq 메소드는 객체 동등성을 정의합니다. 예를 들어, Author_name 및 title 속성이 있고 작성자와 제목의 조합이 고유한 Book 개체가 있는 경우 eq 메서드는 다음과 같습니다.

<code class="python">def __eq__(self, other):
    return self.author_name == other.author_name and self.title == other.title</code>

마찬가지로, hash 메소드는 객체의 해시 값을 생성합니다. 일반적인 접근 방식은 주요 속성의 튜플을 해시하는 것입니다.

<code class="python">def __hash__(self):
    return hash(('title', self.title, 'author_name', self.author_name))</code>

이러한 방법을 사용하면 이제 Book 개체 목록에서 중복 항목을 제거할 수 있습니다.

<code class="python">books = [Book('title1', 'author1'), Book('title2', 'author2'), Book('title1', 'author1')]
unique_books = list(set(books))</code>

게다가, 데이터베이스에서 중복 항목을 확인하려면 다음 접근 방식을 사용할 수 있습니다.

<code class="python">import sqlalchemy

session = sqlalchemy.orm.sessionmaker()()
records = session.query(YourModel).all()
existing_titles = set([record.title for record in records])
unique_objects = [obj for obj in objects if obj.title not in existing_titles]</code>

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

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.