如何在Python NLTK中使用正则回退标记器覆盖NN?

0 投票
1 回答
2317 浏览
提问于 2025-04-17 15:26

我一直在使用一个自定义训练的nltk词性标注器,有时候一些明显的动词(以ING或ED结尾的)却被标记成名词NN。请问我该如何让这个标注器对所有的名词NN进行额外的处理,通过一个正则表达式标注器来找出这些额外的动词呢?

我附上了一些用于第二个正则表达式标注器的示例代码。

from nltk.tag.sequential import RegexpTagger

rgt = RegexpTagger(
    (r'.*ing$', 'VBG'),                # gerunds
    (r'.*ed$', 'VBD'),                 # past tense verbs
])

谢谢

1 个回答

0

这里有一个三元标记器,它的工作方式是先用二元标记器,如果二元标记器也不行,就用单元标记器。而最后的标记工作会交给正则表达式标记器。如果前面的标记器都没办法根据这里定义的规则进行标记,那么就会使用正则表达式来处理。希望这能帮助你建立自己的正则表达式标记器,按照你自己的规则来使用。

   from nltk.corpus import brown
   import sys
   from nltk import pos_tag
   from nltk.tokenize import word_tokenize
   import nltk
   from nltk import ne_chunk
   def tri_gram():
   ##Trigram tagger done by training data from brown corpus 
    b_t_sents=brown.tagged_sents(categories='news')

   ##Making n-gram tagger using Turing backoff
   default_tagger = nltk.RegexpTagger(
            [(r'^-?[0-9]+(.[0-9]+)?$', 'CD'),   # cardinal numbers
         (r'(The|the|A|a|An|an)$', 'AT'),   # articles
         (r'.*able$', 'JJ'),                # adjectives
         (r'.*ness$', 'NN'),                # nouns formed from adjectives  
         (r'.*ly$', 'RB'),                  # adverbs
         (r'.*s$', 'NNS'),                  # plural nouns  
         (r'.*ing$', 'VBG'),                # gerunds   
         (r'.*ed$', 'VBD'),                 # past tense verbs
         (r'.*', 'NN')                      # nouns (default)
        ])
    u_gram_tag=nltk.UnigramTagger(b_t_sents,backoff=default_tagger) 
    b_gram_tag=nltk.BigramTagger(b_t_sents,backoff=u_gram_tag)
    t_gram_tag=nltk.TrigramTagger(b_t_sents,backoff=b_gram_tag)

    ##pos of given text
    f_read=open(sys.argv[1],'r')
    given_text=f_read.read();
    segmented_lines=nltk.sent_tokenize(given_text) 
    for text in segmented_lines:
        words=word_tokenize(text)
        sent = t_gram_tag.tag(words)
        print ne_chunk(sent)
tri_gram()

撰写回答