但是在查找了一些初学者代码后,我发现了以下代码props.setProperty(“annotators”,“tokenize,ssplit,pos,lemma,ner,parse,dcoref”);(链接到代码示例:http://sergey-tihon.github.io/Stanford.NLP.NET/StanfordCoreNLP.html)
但是,每当控制台应用程序加载pos时,它就会触发运行时错误,指出它无法加载标记器.
我想知道我是否缺少任何nugetpackages或如果有额外的设置我必须通过. (注意.任何时候我试图添加说postagger nuget包然后得到一个错误,说两个dlls引用类Annotation.)
我发现,如果我删除一些属性,应用程序将正确运行,所以新行看起来像这样
“props.setProperty(”annotators“,”tokenize,ssplit“);
任何有助于超越运行时错误以帮助我继续进一步分析示例文本的帮助将不胜感激.谢谢.
附图片供参考.(显然我需要更多的声誉才能发布图片但我什么时候可以立即发布:)编辑我现在添加了图片:)
行异常的堆栈跟踪如下:
at edu.stanford.nlp.pipeline.AnnotatorFactories.4.create() at edu.stanford.nlp.pipeline.AnnotatorPool.get(String name) at edu.stanford.nlp.pipeline.StanfordCoreNLP.construct(Properties,Boolean,AnnotatorImplementations ) at edu.stanford.nlp.pipeline.StanfordCoreNLP..ctor(Properties props,Boolean enforceRequirements) at edu.stanford.nlp.pipeline.StanfordCoreNLP..ctor(Properties props) at ConApplicationSabrinaNLP.TestClass.donlp() in c:\Users\Justin\Documents\Visual Studio 2013\Projects\ConApplicationSabrinaNLP\ConApplicationSabrinaNLP\TestClass.cs:line 28 at ConApplicationSabrinaNLP.Program.Main(String[] args) in c:\Users\Justin\Documents\Visual Studio 2013\Projects\ConApplicationSabrinaNLP\ConApplicationSabrinaNLP\Program.cs:line 20 at System.AppDomain._nExecuteAssembly(RuntimeAssembly assembly,String[] args) at System.AppDomain.ExecuteAssembly(String assemblyFile,Evidence assemblySecurity,String[] args) at Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly() at System.Threading.ThreadHelper.ThreadStart_Context(Object state) at System.Threading.ExecutionContext.RunInternal(ExecutionContext executionContext,ContextCallback callback,Object state,Boolean preserveSyncCtx) at System.Threading.ExecutionContext.Run(ExecutionContext executionContext,Object state) at System.Threading.ThreadHelper.ThreadStart()
解决方法
你必须在这里下载最新的版本 POS-Tagger
完成后,将其放入项目目录中.然后将代码指向它.在“3.6.0 2015-12-09更新的兼容性”版本中,标记器具有不同的名称,例如“english-bidirectional-distsim.tagger”.
确保将代码指向正确的文件夹和文件,它将起作用.
以下是我的Windows窗体项目中的一个工作示例.
using java.io; using java.util; using edu.stanford.nlp.ling; using edu.stanford.nlp.tagger.maxent; using Console = System.Console; using System.IO; using System.Windows.Forms; namespace Stanford.NLP.POSTagger.CSharp { class PosTagger { // get the base folder for the project public static string GetAppFolder() { return Path.GetDirectoryName(Application.ExecutablePath).Replace(@"*your project directory here*\bin\Debug",string.Empty); } public void testTagger() { var jarRoot = Path.Combine(GetAppFolder(),@"packages\stanford-postagger-2015-12-09"); Console.WriteLine(jarRoot.ToString()); var modelsDirectory = jarRoot + @"\models"; // Loading POS Tagger var tagger = new MaxentTagger(modelsDirectory + @"\english-bidirectional-distsim.tagger"); // Text for tagging var text = "A Part-Of-Speech Tagger (POS Tagger) is a piece of software that reads text" + "in some language and assigns parts of speech to each word (and other token)," + " such as noun,verb,adjective,etc.,although generally computational " + "applications use more fine-grained POS tags like 'noun-plural'."; var sentences = MaxentTagger.tokenizeText(new java.io.StringReader(text)).toArray(); foreach (ArrayList sentence in sentences) { var taggedSentence = tagger.tagSentence(sentence); Console.WriteLine(Sentence.listToString(taggedSentence,false)); } } } }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。