คำพ้องความหมายและการแทนที่คำตรงข้าม

การแทนที่คำด้วยคำพ้องความหมายทั่วไป

ในขณะที่ทำงานกับ 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)

บันทึกโปรแกรม python นี้ (พูดว่า replacesyn.py) และเรียกใช้จากพรอมต์คำสั่ง python หลังจากเรียกใช้แล้วให้นำเข้า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'

ข้อเสียของวิธีการข้างต้นคือเราควรต้องฮาร์ดโค้ดคำพ้องความหมายในพจนานุกรม Python เรามีทางเลือกที่ดีกว่าสองทางในรูปแบบไฟล์ CSV และ YAML เราสามารถบันทึกคำศัพท์พ้องของเราในไฟล์ที่กล่าวถึงข้างต้นและสามารถสร้างword_mapพจนานุกรมจากพวกเขา ให้เราเข้าใจแนวคิดด้วยความช่วยเหลือของตัวอย่าง

ใช้ไฟล์ CSV

ในการใช้ไฟล์ CSV เพื่อจุดประสงค์นี้ไฟล์ควรมีสองคอลัมน์คอลัมน์แรกประกอบด้วยคำและคอลัมน์ที่สองประกอบด้วยคำพ้องความหมายที่ใช้แทนที่ ให้เราบันทึกไฟล์นี้เป็นไฟล์syn.csv. ในตัวอย่างด้านล่างเราจะสร้างคลาสชื่อ CSVword_syn_replacer ซึ่งจะขยายออกไป word_syn_replacer ใน replacesyn.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_replacer ใน replacesyn.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

บันทึกโปรแกรม python นี้ (พูดว่า replaceantonym.py) และเรียกใช้จากพรอมต์คำสั่ง python หลังจากเรียกใช้แล้วให้นำเข้า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']