【发布时间】:2015-06-01 16:39:19
【问题描述】:
我想使用 Apache POI 在 Android 中读取和写入 excel 文件(xlsx 和 xls)。但我无法解决我目前遇到的依赖问题。
如果我的 gradle 文件中只有这两个依赖项
compile files('libs/poi-3.12-20150511.jar')
compile files('libs/poi-ooxml-3.12-20150511.jar')
然后我得到以下错误:
java.lang.NoClassDefFoundError: Failed resolution of: Lorg/apache/xmlbeans/XmlOptions;
at org.apache.poi.POIXMLDocumentPart.<clinit>(POIXMLDocumentPart.java:59)
at com.gargzdai.spreadsheet.MainActivity.readData(MainActivity.java:131)
at com.gargzdai.spreadsheet.MainActivity.prepareForReadingData(MainActivity.java:109)
at com.gargzdai.spreadsheet.MainActivity.onCreate(MainActivity.java:68)
at android.app.Activity.performCreate(Activity.java:5990)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1106)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2278)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2387)
at android.app.ActivityThread.access$800(ActivityThread.java:151)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1303)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5254)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
这是我用来读取 excel 文件的代码:
if (isXlsxFile)
myWorkbook = new XSSFWorkbook(OPCPackage.open(file));
else
myWorkbook = new HSSFWorkbook(fileStream);
Sheet mySheet = myWorkbook.getSheetAt(0);
Iterator rowIterator = mySheet.rowIterator();
看来我应该添加 xmlbeans 库。在我将此依赖项添加到我的 gradle 文件后:
compile files('libs/xmlbeans-2.6.0.jar')
添加此依赖项后,我在 gradle 构建期间收到以下错误:
Error:Execution failed for task ':app:preDexDebug'.
> com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExecException: Process 'command 'C:\Program Files\Java\jdk1.8.0_40\bin\java.exe'' finished with non-zero exit value 1
关于我应该如何解决这个问题的任何想法?
【问题讨论】:
-
有一点需要注意的是,Android 还不支持 Java 8:developer.android.com/sdk/index.html#Requirementsstackoverflow.com/questions/23318109/…
-
感谢您注意到这一点,但它并没有改变任何东西。
-
android 有不同版本的 poi 依赖吗?我只是想知道。我正在使用
适用于 java 项目,它可以工作org.apache.poi poi-ooxml 3.9 version> -
是的,有。 3.12 中的最新版本,您可以从这里获取:poi.apache.org/download.html