执行OWLAPI时出错

时间:2015-11-13 09:08:05

标签: java eclipse

我正在尝试使用owl-osgi-distribution 4.0.2在eclipse中使用owlapi创建一个本体,并获得Noclassfound的错误,类似于链接中的错误

Getting error in executing OWL API

并且根据我得到的错误:

Exception in thread "main" java.lang.NoClassDefFoundError:   
com/google/inject/Provider at java.lang.ClassLoader.defineClass1(Native  
Method) at java.lang.ClassLoader.defineClass(Unknown Source) at    
java.security.SecureClassLoader.defineClass(Unknown Source) at   
java.net.URLClassLoader.defineClass(Unknown Source) at 
java.net.URLClassLoader.access$100(Unknown Source) at 
java.net.URLClassLoader$1.run(Unknown Source) at 
java.net.URLClassLoader$1.run(Unknown Source) at 
java.security.AccessController.doPrivileged(Native Method) at 
java.net.URLClassLoader.findClass(Unknown Source) at 
java.lang.ClassLoader.loadClass(Unknown Source) at 
sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source) at 
java.lang.ClassLoader.loadClass(Unknown Source) at 
java.lang.ClassLoader.defineClass1(Native Method) at 
java.lang.ClassLoader.defineClass(Unknown Source) at 
java.security.SecureClassLoader.defineClass(Unknown Source) at 
java.net.URLClassLoader.defineClass(Unknown Source) at 
java.net.URLClassLoader.access$100(Unknown Source) at 
java.net.URLClassLoader$1.run(Unknown Source) at 
java.net.URLClassLoader$1.run(Unknown Source) at 
java.security.AccessController.doPrivileged(Native Method) at 
java.net.URLClassLoader.findClass(Unknown Source) at 
java.lang.ClassLoader.loadClass(Unknown Source) at 
sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source) at 
java.lang.ClassLoader.loadClass(Unknown Source) at test.main(test.java:18) 
Caused by: java.lang.ClassNotFoundException: com.google.inject.Provider at 
java.net.URLClassLoader.findClass(Unknown Source) at 
java.lang.ClassLoader.loadClass(Unknown Source) at 
sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source) at 
java.lang.ClassLoader.loadClass(Unknown Source) ... 25 more

通过链接中的答案,我理解我需要添加我的owlapi文件,我通过以下方式引用它来解决它。

http://www.jabenitez.com/2015/08/19/solucionando-el-error-java-lang-noclassdeffounderror-comgoogleinjectprovider/

我完成了上述整个过程并运行了代码

 package ontology;

 import java.io.File;
 import java.util.Set;

 import org.semanticweb.owlapi.apibinding.OWLManager;
 import org.semanticweb.owlapi.model.IRI;
 import org.semanticweb.owlapi.model.OWLAxiom;
 import org.semanticweb.owlapi.model.OWLOntology;
 import org.semanticweb.owlapi.model.OWLOntologyCreationException;
 import org.semanticweb.owlapi.model.OWLOntologyManager;

 public class Owlapitutorial {

    public static void main(String[] args) {
    // TODO Auto-generated method stub
    // load file
    File file = new File("F://Ankita//creatingOntology//ontofit.owl");

    // loading the ontology
    try {
        OWLOntologyManager manager = OWLManager.createOWLOntologyManager();
        OWLOntology localOntology = manager.loadOntologyFromOntologyDocument(file);

        //getting all axioms    
        Set<OWLAxiom> axSet= localOntology.getAxioms();

        System.out.println(localOntology.getLogicalAxiomCount());

    } catch (OWLOntologyCreationException e) {
        e.printStackTrace();
    }

}

}

之后我的程序给了我以下错误

 Exception in thread "main" java.lang.NoClassDefFoundError:   
org/slf4j/LoggerFactory
at org.semanticweb.owlapi.OWLAPIServiceLoaderModule.<clinit>  
(OWLAPIServiceLoaderModule.java:50)
at org.semanticweb.owlapi.apibinding.OWLManager.<clinit>(OWLManager.java:42)
at ontology.Owlapitutorial.main(Owlapitutorial.java:22)
Caused by: java.lang.ClassNotFoundException: org.slf4j.LoggerFactory
at java.net.URLClassLoader.findClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)
at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)
... 3 more

我确实理解并验证了一个依赖文件org.slf4j:slf4j-api:jar:1.7.7:在我下载并添加到构建新库的构建路径中的owlosgi的lib文件夹中丢失了。

我还在我的文件夹F://Ankita//creatingOntology//ontofit.owl中创建了一个新文件并运行程序,现在我得到了一个不同的错误,即

SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further    
details.
0

我已经去了StaticLoggerBinder网站了解更多细节并下载了SLF4J的zip文件,但我不知道我应该做什么,因为里面有很多jar文件。

任何人都可以帮助我。

电弧

1 个答案:

答案 0 :(得分:1)

SLF4J为几个备用日志记录系统提供了一个通用接口,但您还没有在项目中包含任何这些系统,因此它默认为NOP记录器实现。如果要实现更有用的日志记录,则应该在错误消息(http://www.slf4j.org/codes.html#StaticLoggerBinder)中给出的SLF4J页面上提供一个备选方案,例如Log4J。

或者您可以放心地忽略该消息,但如果出现问题,您将无法获取任何记录信息。