我对 Java 开发完全陌生。
有人可以详细说明如何使用斯坦福大学的自然语言处理词法分析器 - 开源 Java 代码获得“语法关系”吗?
谢谢!
请参阅我的代码中第一个文件的第 88 行以编程方式运行斯坦福解析器
GrammaticalStructureFactory gsf = tlp.grammaticalStructureFactory();
GrammaticalStructure gs = gsf.newGrammaticalStructure(parse);
Collection tdl = gs.typedDependenciesCollapsed();
System.out.println("words: "+words);
System.out.println("POStags: "+tags);
System.out.println("stemmedWordsAndTags: "+stems);
System.out.println("typedDependencies: "+tdl);
集合 tdl 是这些类型化依赖项的列表。如果您查看TypedDependency 的 javadoc,您会发现使用 .reln() 方法可以获得语法关系。
我的代码中第三个文件的第 311-318 行显示了如何使用该类型依赖项列表。我碰巧得到了关系的名称,但你可以得到关系本身,它属于 GrammaticalRelation 类。
for( Iterator<TypedDependency> iter = tdl.iterator(); iter.hasNext(); ) {
TypedDependency var = iter.next();
TreeGraphNode dep = var.dep();
TreeGraphNode gov = var.gov();
// All useful information for a node in the tree
String reln = var.reln().getShortName();
不要难过,我花了一两天痛苦的时间试图弄清楚如何使用解析器。我不知道文档是否有所改进,但是当我使用它时,它们非常糟糕。