有没有现成的英语语法可以直接加载并在NLTK中使用?我搜索过使用NLTK解析的示例,但似乎在解析句子之前必须手动指定语法。
非常感谢!
发布于 2013-07-30 06:52:36
您可以看看pyStatParser,这是一个简单的python统计解析器,它返回NLTK解析树。它附带了公共树库,并且只在您第一次实例化Parser对象时生成语法模型(大约在8秒内)。它使用CKY算法,在不到一秒的时间内解析平均长度的句子(如下面的句子)。
>>> from stat_parser import Parser
>>> parser = Parser()
>>> print parser.parse("How can the net amount of entropy of the universe be massively decreased?")
(SBARQ
(WHADVP (WRB how))
(SQ
(MD can)
(NP
(NP (DT the) (JJ net) (NN amount))
(PP
(IN of)
(NP
(NP (NNS entropy))
(PP (IN of) (NP (DT the) (NN universe))))))
(VP (VB be) (ADJP (RB massively) (VBN decreased))))
(. ?))
发布于 2015-09-09 04:25:39
我的库spaCy提供了一个高性能的依赖解析器。
安装:
pip install spacy
python -m spacy.en.download all
用法:
from spacy.en import English
nlp = English()
doc = nlp(u'A whole document.\nNo preprocessing require. Robust to arbitrary formating.')
for sent in doc:
for token in sent:
if token.is_alpha:
print token.orth_, token.tag_, token.head.lemma_
Choi et al. (2015)发现spaCy是可用的最快的依赖解析器。它在一个线程上每秒处理超过13,000个句子。在《华尔街日报》的标准评估中,它的得分为92.7%,比CoreNLP的任何模型都要准确1%以上。
发布于 2011-05-25 03:25:26
在nltk_data
发行版中有一些语法。在Python解释器中,发出nltk.download()
。
https://stackoverflow.com/questions/6115677
复制相似问题