我在尝试使用Apache POI打开XLSX文件时遇到问题。
我的代码:
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
public class ExcelTest {
public static void main(String[] args) {
try(FileInputStream f = new FileInputStream(new File("path/to/my/file.xlsx"))) {
XSSFWorkbook wb = new XSSFWorkbook(f); // This is the line throwing the exception
} catch(IOException e) {
System.err.println(e.getMessage());
e.printStackTrace(System.err);
}
}
}
抛出异常:
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/xmlbeans/XmlException
at my.TEST.ExcelTest.main(ExcelTest.java:24)
Caused by: java.lang.ClassNotFoundException: org.apache.xmlbeans.XmlException
at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
... 1 more
背景:
poi-3.11-20141221.jar
poi-ooxml-3.11-20141221.jar
poi-ooxml-schemas-3.11-20141221.jar
commons-codec-1.9.jar
log4j-1.2.17.jar
我什至无法开始做真正的事情,因为我什至无法打开这本书!:(
当我看到异常时,我以为“好,让我们获取xmlbeans并查看它是否有效”,但是xmlbeans被移到了Apache的阁楼中。
我想念什么吗?如何打开工作簿?
我认为您也xmlbeans-2.6.0.jar
很需要。这似乎是Poi的依赖之一。我设置了一个残留Maven项目有poi
,poi-scratchpad
,poi-ooxml
,和poi-ooxml-schemas
我的直接依赖。Maven在其他JAR中依赖于依赖项:
commons-codec-1.9.jar
xmlbeans-2.6.0.jar
stax-api-1.0.1.jar
在进一步调查中,我发现这stax-api
是的传递依赖xmlbeans
。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句