Python-중복 단어 필터링

많은 경우 파일에있는 고유 한 단어에 대해서만 텍스트를 분석해야합니다. 따라서 텍스트에서 중복 된 단어를 제거해야합니다. 이는 토큰 화라는 단어를 사용하고 nltk에서 사용할 수있는 기능을 설정하여 수행됩니다.

주문을 보존하지 않고

아래 예에서는 먼저 문장을 단어로 토큰 화합니다. 그런 다음 고유 한 요소의 정렬되지 않은 컬렉션을 생성하는 set () 함수를 적용합니다. 결과에 순서가 지정되지 않은 고유 한 단어가 있습니다.

import nltk
word_data = "The Sky is blue also the ocean is blue also Rainbow has a blue colour." 
# First Word tokenization
nltk_tokens = nltk.word_tokenize(word_data)
# Applying Set
no_order = list(set(nltk_tokens))
print no_order

위의 프로그램을 실행하면 다음과 같은 결과가 나옵니다.

['blue', 'Rainbow', 'is', 'Sky', 'colour', 'ocean', 'also', 'a', '.', 'The', 'has', 'the']

질서 보존

중복을 제거한 후 단어를 가져 오지만 문장의 단어 순서는 그대로 유지하기 위해 단어를 읽고 추가하여 목록에 추가합니다.

import nltk
word_data = "The Sky is blue also the ocean is blue also Rainbow has a blue colour." 
# First Word tokenization
nltk_tokens = nltk.word_tokenize(word_data)
ordered_tokens = set()
result = []
for word in nltk_tokens:
    if word not in ordered_tokens:
        ordered_tokens.add(word)
        result.append(word)
     
print result

위의 프로그램을 실행하면 다음과 같은 결과가 나옵니다.

['The', 'Sky', 'is', 'blue', 'also', 'the', 'ocean', 'Rainbow', 'has', 'a', 'colour', '.']