집 >데이터 베이스 >MySQL 튜토리얼 >순서를 유지하면서 Python 목록에서 중복 개체를 효율적으로 제거하려면 어떻게 해야 합니까?
Python을 사용하여 중복 개체를 효율적으로 처리
Python에서는 원래 순서를 유지하면서 목록에서 중복 개체를 제거해야 할 수 있습니다. 이 문제는 사용자 정의 개체 목록이 있고 특정 기준에 따라 중복 항목을 필터링하거나 데이터베이스에서 중복 항목을 확인하려는 경우에 발생합니다.
특정 요구 사항과 관련하여 효과적으로 사용하려면 개체 내에서 고유성을 정의해야 합니다. set(list_of_objects) 메소드. 여기에는 eq 및 hash 메소드를 구현하여 객체를 해시 가능하게 만드는 작업이 포함됩니다.
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!