동의어 및 반의어 대체

공통 동의어로 단어 바꾸기

NLP로 작업하는 동안, 특히 빈도 분석 및 텍스트 인덱싱의 경우에는 많은 메모리를 절약하기 때문에 의미를 잃지 않고 어휘를 압축하는 것이 항상 유익합니다. 이를 위해서는 단어와 동의어의 매핑을 정의해야합니다. 아래 예에서는 다음과 같은 클래스를 생성합니다.word_syn_replacer 단어를 공통 동의어로 대체하는 데 사용할 수 있습니다.

먼저 필요한 패키지를 가져옵니다. re 정규 표현식으로 작업합니다.

import re
from nltk.corpus import wordnet

다음으로, 단어 대체 매핑을 취하는 클래스를 만듭니다.

class word_syn_replacer(object):
   def __init__(self, word_map):
   self.word_map = word_map
def replace(self, word):
   return self.word_map.get(word, word)

이 파이썬 프로그램 (예 : replacesyn.py)을 저장하고 파이썬 명령 프롬프트에서 실행하십시오. 실행 후 가져 오기word_syn_replacer단어를 공통 동의어로 바꾸려는 경우 클래스. 방법을 살펴 보겠습니다.

from replacesyn import word_syn_replacer
rep_syn = word_syn_replacer ({‘bday’: ‘birthday’)
rep_syn.replace(‘bday’)

산출

'birthday'

완전한 구현 예

import re
from nltk.corpus import wordnet
class word_syn_replacer(object):
   def __init__(self, word_map):
   self.word_map = word_map
def replace(self, word):
   return self.word_map.get(word, word)

이제 위의 프로그램을 저장하고 실행하면 다음과 같이 클래스를 가져와 사용할 수 있습니다.

from replacesyn import word_syn_replacer
rep_syn = word_syn_replacer ({‘bday’: ‘birthday’)
rep_syn.replace(‘bday’)

산출

'birthday'

위 방법의 단점은 파이썬 사전에 동의어를 하드 코딩해야한다는 것입니다. CSV 및 YAML 파일 형식의 두 가지 더 나은 대안이 있습니다. 우리는 위에서 언급 한 파일에 동의어 어휘를 저장하고 다음을 구성 할 수 있습니다.word_map그들로부터 사전. 예제의 도움으로 개념을 이해합시다.

CSV 파일 사용

이 목적으로 CSV 파일을 사용하기 위해서는 파일에 두 개의 열이 있어야합니다. 첫 번째 열은 단어로 구성되고 두 번째 열은 대체 할 동의어로 구성됩니다. 이 파일을 다음과 같이 저장하겠습니다.syn.csv. 아래 예에서는 다음과 같은 클래스를 생성합니다. CSVword_syn_replacer 확장됩니다 word_syn_replacerreplacesyn.py 파일을 구성하는 데 사용됩니다. word_map 사전 syn.csv 파일.

먼저 필요한 패키지를 가져옵니다.

import csv

다음으로, 단어 대체 매핑을 취하는 클래스를 만듭니다.

class CSVword_syn_replacer(word_syn_replacer):
   def __init__(self, fname):
      word_map = {}
      for line in csv.reader(open(fname)):
         word, syn = line
         word_map[word] = syn
      super(Csvword_syn_replacer, self).__init__(word_map)

실행 후 가져 오기 CSVword_syn_replacer단어를 공통 동의어로 바꾸려는 경우 클래스. 어떻게 볼까요?

from replacesyn import CSVword_syn_replacer
rep_syn = CSVword_syn_replacer (‘syn.csv’)
rep_syn.replace(‘bday’)

산출

'birthday'

완전한 구현 예

import csv
class CSVword_syn_replacer(word_syn_replacer):
def __init__(self, fname):
word_map = {}
for line in csv.reader(open(fname)):
   word, syn = line
   word_map[word] = syn
super(Csvword_syn_replacer, self).__init__(word_map)

이제 위의 프로그램을 저장하고 실행하면 다음과 같이 클래스를 가져와 사용할 수 있습니다.

from replacesyn import CSVword_syn_replacer
rep_syn = CSVword_syn_replacer (‘syn.csv’)
rep_syn.replace(‘bday’)

산출

'birthday'

YAML 파일 사용

CSV 파일을 사용 했으므로이 목적으로 YAML 파일을 사용할 수도 있습니다 (PyYAML이 설치되어 있어야 함). 파일을 다음과 같이 저장하겠습니다.syn.yaml. 아래 예에서는 다음과 같은 클래스를 생성합니다. YAMLword_syn_replacer 확장됩니다 word_syn_replacerreplacesyn.py 파일을 구성하는 데 사용됩니다. word_map 사전 syn.yaml 파일.

먼저 필요한 패키지를 가져옵니다.

import yaml

다음으로, 단어 대체 매핑을 취하는 클래스를 만듭니다.

class YAMLword_syn_replacer(word_syn_replacer):
   def __init__(self, fname):
   word_map = yaml.load(open(fname))
   super(YamlWordReplacer, self).__init__(word_map)

실행 후 가져 오기 YAMLword_syn_replacer단어를 공통 동의어로 바꾸려는 경우 클래스. 어떻게 볼까요?

from replacesyn import YAMLword_syn_replacer
rep_syn = YAMLword_syn_replacer (‘syn.yaml’)
rep_syn.replace(‘bday’)

산출

'birthday'

완전한 구현 예

import yaml
class YAMLword_syn_replacer(word_syn_replacer):
def __init__(self, fname):
   word_map = yaml.load(open(fname))
   super(YamlWordReplacer, self).__init__(word_map)

이제 위의 프로그램을 저장하고 실행하면 다음과 같이 클래스를 가져와 사용할 수 있습니다.

from replacesyn import YAMLword_syn_replacer
rep_syn = YAMLword_syn_replacer (‘syn.yaml’)
rep_syn.replace(‘bday’)

산출

'birthday'

반의어 대체

우리가 알다시피 반의어는 다른 단어와 반대의 의미를 가진 단어이고 동의어 대체의 반대는 반의어 대체라고합니다. 이 섹션에서는 반의어 대체, 즉 WordNet을 사용하여 단어를 명확한 반의어로 대체하는 방법을 다룰 것입니다. 아래 예에서는 다음과 같은 클래스를 생성합니다.word_antonym_replacer 두 가지 방법이 있습니다. 하나는 단어를 바꾸고 다른 하나는 부정을 제거하는 것입니다.

먼저 필요한 패키지를 가져옵니다.

from nltk.corpus import wordnet

다음으로, word_antonym_replacer

class word_antonym_replacer(object):
   def replace(self, word, pos=None):
      antonyms = set()
      for syn in wordnet.synsets(word, pos=pos):
         for lemma in syn.lemmas():
            for antonym in lemma.antonyms():
               antonyms.add(antonym.name())
      if len(antonyms) == 1:
         return antonyms.pop()
      else:
         return None
   def replace_negations(self, sent):
      i, l = 0, len(sent)
      words = []
      while i < l:
         word = sent[i]
         if word == 'not' and i+1 < l:
            ant = self.replace(sent[i+1])
            if ant:
               words.append(ant)
               i += 2
               continue
         words.append(word)
         i += 1
      return words

이 파이썬 프로그램 (예 : replaceantonym.py)을 저장하고 파이썬 명령 프롬프트에서 실행하십시오. 실행 후 가져 오기word_antonym_replacer단어를 명확한 반의어로 바꾸고 싶을 때 수업. 방법을 살펴 보겠습니다.

from replacerantonym import word_antonym_replacer
rep_antonym = word_antonym_replacer ()
rep_antonym.replace(‘uglify’)

산출

['beautify'']
sentence = ["Let us", 'not', 'uglify', 'our', 'country']
rep_antonym.replace _negations(sentence)

산출

["Let us", 'beautify', 'our', 'country']

완전한 구현 예

nltk.corpus import wordnet
class word_antonym_replacer(object):
def replace(self, word, pos=None):
   antonyms = set()
   for syn in wordnet.synsets(word, pos=pos):
      for lemma in syn.lemmas():
      for antonym in lemma.antonyms():
         antonyms.add(antonym.name())
   if len(antonyms) == 1:
      return antonyms.pop()
   else:
      return None
def replace_negations(self, sent):
   i, l = 0, len(sent)
   words = []
   while i < l:
      word = sent[i]
      if word == 'not' and i+1 < l:
         ant = self.replace(sent[i+1])
         if ant:
            words.append(ant)
            i += 2
            continue
      words.append(word)
      i += 1
   return words

이제 위의 프로그램을 저장하고 실행하면 다음과 같이 클래스를 가져와 사용할 수 있습니다.

from replacerantonym import word_antonym_replacer
rep_antonym = word_antonym_replacer ()
rep_antonym.replace(‘uglify’)
sentence = ["Let us", 'not', 'uglify', 'our', 'country']
rep_antonym.replace _negations(sentence)

산출

["Let us", 'beautify', 'our', 'country']