목록에서 빈도별로 단어 계산 및 정렬
이 작업에는 주어진 단어에서 단어의 빈도를 효과적으로 나타내는 데이터 구조를 만드는 작업이 포함됩니다. 목록. 한 가지 간단한 접근 방식에는 두 개의 목록이 포함됩니다. 하나는 고유 단어에 대한 것이고 다른 하나는 해당 빈도에 대한 것입니다. 빈도를 기준으로 단어를 정렬하려면 빈도 목록에 저장된 정보를 활용해야 합니다.
카운터를 사용한 Python 구현
고급 도구를 사용하지 않고 Python에서 이를 구현하려면 사전과 같은 구성을 사용하면 컬렉션 모듈에서 Counter 클래스를 활용할 수 있습니다. 이 클래스는 단어 빈도를 편리하게 추적하여 간단한 솔루션을 제공합니다.
아래 코드 조각은 Counter 클래스를 활용하는 방법을 보여줍니다.
<code class="python">from collections import Counter list1 = ['apple', 'egg', 'apple', 'banana', 'egg', 'apple'] counts = Counter(list1)</code>
이 코드는 counts라는 Counter 개체를 생성합니다. 단어 빈도가 포함되어 있습니다. print(counts) 문은 다음을 출력합니다.
Counter({'apple': 3, 'egg': 2, 'banana': 1})
기본적으로 Counter 클래스는 단어를 알파벳순으로 정렬합니다. 그러나 Most_common() 메서드에 대한 인수로 키 함수를 제공하여 정렬 동작을 사용자 정의할 수 있습니다. 예를 들어 빈도를 기준으로 단어를 내림차순으로 정렬하려면:
<code class="python">sorted_words = sorted(counts, key=lambda x: x[1], reverse=True)</code>
요약하면 Counter 클래스는 다음과 같은 복잡한 데이터 구조 없이도 빈도를 기준으로 단어를 계산하고 정렬하는 효율적인 방법을 제공합니다. 사전.
위 내용은 Python의 목록에서 빈도별로 단어를 계산하고 정렬하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!