2017-03-20 5 views
-1

Ich verwende den Stanford POS-Tagger 3.7.0 in einem Java-Projekt, das auch die Jena RDF API verwendet. Jena erfordert slf4j-api-1.7.12.jar und slf4j-log4j12-1.7.12.jar, aber beim Versuch, die POS-Tagger zu nennen diese Gläser in den Classpath, die ich die folgende Fehlermeldung erhalten:Stanford POS-Tagger funktioniert nicht mit SLF4J im Klassenpfad

Exception in thread "main" java.lang.ExceptionInInitializerError 
    at edu.stanford.nlp.util.logging.Redwood$ConsoleHandler.out(Redwood.java:920) 
    at edu.stanford.nlp.util.logging.RedwoodConfiguration.<init>(RedwoodConfiguration.java:28) 
    at edu.stanford.nlp.util.logging.RedwoodConfiguration.empty(RedwoodConfiguration.java:385) 
    at util.Splitter.split(Splitter.java:58) 
    at core.Main.main(Main.java:23) 
Caused by: java.lang.IllegalStateException: Could not find SLF4J in your classpath 
    at edu.stanford.nlp.util.logging.RedwoodConfiguration$Handlers.lambda$static$530(RedwoodConfiguration.java:190) 
    at edu.stanford.nlp.util.logging.RedwoodConfiguration$Handlers$7.buildChain(RedwoodConfiguration.java:309) 
    at edu.stanford.nlp.util.logging.RedwoodConfiguration$Handlers$7.apply(RedwoodConfiguration.java:318) 
    at edu.stanford.nlp.util.logging.RedwoodConfiguration.lambda$handlers$535(RedwoodConfiguration.java:363) 
    at edu.stanford.nlp.util.logging.RedwoodConfiguration.apply(RedwoodConfiguration.java:41) 
    at edu.stanford.nlp.util.logging.Redwood.<clinit>(Redwood.java:609) 
    ... 5 more 
Caused by: edu.stanford.nlp.util.MetaClass$ClassCreationException: java.lang.ClassNotFoundException: edu.stanford.nlp.util.logging.SLF4JHandler 
    at edu.stanford.nlp.util.MetaClass.createFactory(MetaClass.java:364) 
    at edu.stanford.nlp.util.MetaClass.createInstance(MetaClass.java:381) 
    at edu.stanford.nlp.util.logging.RedwoodConfiguration$Handlers.lambda$static$530(RedwoodConfiguration.java:186) 
    ... 10 more 
Caused by: java.lang.ClassNotFoundException: edu.stanford.nlp.util.logging.SLF4JHandler 
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424) 
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357) 
    at java.lang.Class.forName0(Native Method) 
    at java.lang.Class.forName(Class.java:264) 
    at edu.stanford.nlp.util.MetaClass$ClassFactory.construct(MetaClass.java:135) 
    at edu.stanford.nlp.util.MetaClass$ClassFactory.<init>(MetaClass.java:202) 
    at edu.stanford.nlp.util.MetaClass$ClassFactory.<init>(MetaClass.java:69) 
    at edu.stanford.nlp.util.MetaClass.createFactory(MetaClass.java:360) 
    ... 12 more 

I habe gesehen, dass Leute, die eine similar problem hatten, lösten, indem sie SLF4J aus dem Klassenpfad entfernten. In der Tat, wenn ich die Gläser entferne, funktioniert der POS-Tagger gut, aber dann hört Jena auf zu arbeiten.

Gibt es eine Möglichkeit, SLF4J im Klassenpfad zu behalten und dennoch den POS-Tagger zu aktivieren?

+0

Holen Sie sich den Bugfix oder verwenden Sie 3.6. – Andreas

Antwort

0

Ich denke, die beste Lösung ist, nur die vollständige Version von Stanford CoreNLP 3.7.0 zu verwenden, die dieses Problem nicht haben wird, aber alle POS-Tagging-Funktionalität haben wird.

Der vollständige Download ist hier verfügbar:

http://stanfordnlp.github.io/CoreNLP/download.html

Dieses Problem sollte 3.8.0 in den Standalone-Distributionen für Stanford CoreNLP gelöst werden, die wir versuchen werden im Frühsommer zu lösen.

Verwandte Themen