我正在尝试使用Apache POI 3.14库创建.xlsx
文档。
这是我的Gradle配置:
(...)
defaultConfig {
applicationId "com.example.app"
minSdkVersion 14
targetSdkVersion 19
multiDexEnabled true
}
buildTypes {
release {
minifyEnabled true
proguardFiles getDefaultProguardFile('proguard-android.txt')
proguardFile 'Path/app/proguard-rules.pro'
}
}
}
dependencies {
compile 'com.android.support:appcompat-v7:22.2.0'
compile 'com.android.support:multidex:1.0.1'
//compile files('libs/android-support-v13.jar')
compile files('libs/commons-io-2.4.jar')
compile files('libs/commons-net-3.3.jar')
compile files('libs/poi-3.14-20160307.jar')
compile files('libs/poi-ooxml-3.14-20160307.jar')
compile files('libs/poi-ooxml-schemas-3.14-20160307.jar')
compile files('libs/xmlbeans-2.6.0.jar')
compile files('libs/curvesapi-1.03.jar')
compile files('libs/commons-codec-1.10.jar')
compile files('libs/commons-logging-1.2.jar')
compile files('libs/junit-4.12.jar')
compile files('libs/log4j-1.2.17.jar')
compile 'com.roomorama:caldroid:2.3.1'
}
使用原始xmlbeans库xmlbeans-2.6.0.jar
当我尝试运行APP时出现此异常
Error:Execution failed for task ':app:transformClassesWithJarMergingForDebug'.
> com.android.build.api.transform.TransformException: java.util.zip.ZipException: duplicate entry: org/apache/xmlbeans/xml/stream/Location.class
我尝试使用此方法删除重复的类
-Unzip the jar file. (Simply change .jar extension to .zip
-This will remove the duplicate files.
-Recreate the jar using jar cf xmlbeans.jar -C (path to unzipped folder) . (Mind it, there is a dot in the end of command)
-Use this regenerated jar
当我尝试使用此重新编译的.jar运行应用程序时,我收到此警告,但即使如此,它也会启动到设备
Error:warning: Ignoring InnerClasses attribute for an anonymous inner class
Error:(org.apache.xmlbeans.impl.inst2xsd.RussianDollStrategy$1) that doesn't come with an
Error:associated EnclosingMethod attribute. This class was probably produced by a
Error:compiler that did not target the modern .class file format. The recommended
Error:solution is to recompile the class from source, using an up-to-date compiler
Error:and without specifying any "-target" type options. The consequence of ignoring
Error:this warning is that reflective operations on this class will incorrectly
Error:indicate that it is *not* an inner class.
(...)
然后在我的代码中尝试:
XSSFWorkbook wb = new XSSFWorkbook();
我收到此异常并关闭了应用
Caused by: java.lang.NoClassDefFoundError: javax.xml.stream.XMLEventFactory
at org.apache.poi.openxml4j.opc.internal.marshallers.PackagePropertiesMarshaller.<clinit>(PackagePropertiesMarshaller.java:41)
at org.apache.poi.openxml4j.opc.OPCPackage.init(OPCPackage.java:162)
at org.apache.poi.openxml4j.opc.OPCPackage.<init>(OPCPackage.java:142)
at org.apache.poi.openxml4j.opc.Package.<init>(Package.java:37)
at org.apache.poi.openxml4j.opc.ZipPackage.<init>(ZipPackage.java:67)
at org.apache.poi.openxml4j.opc.OPCPackage.create(OPCPackage.java:344)
at org.apache.poi.xssf.usermodel.XSSFWorkbook.newPackage(XSSFWorkbook.java:453)
at org.apache.poi.xssf.usermodel.XSSFWorkbook.<init>(XSSFWorkbook.java:226)
at org.apache.poi.xssf.usermodel.XSSFWorkbook.<init>(XSSFWorkbook.java:218)
at com.asde.armatest.persistency.AsyncExcelFile.doInBackground(AsyncExcelFile.java:285)
会出现什么问题?