- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
您好,我第一次尝试使用 apache.poi 将 xlsx 转换为 pdf,它工作得很好,直到我添加一些需要使用 3.17 版本的代码(将 docx 转换为 pdf)。之后,当我尝试转换 xlsx 时,出现此错误
java.lang.NoSuchMethodError: org.apache.poi.util.POILogger.log(ILjava/lang/Object;Ljava/lang/Throwable;)V
我不知道会发生什么。无论如何,这是我获取文件的一些代码
ByteArrayOutputStream baos = new ByteArrayOutputStream();
OPCPackage pkg = OPCPackage.open(file);
XSSFWorkbook xls = new XSSFWorkbook(pkg);
XSSFSheet worksheet = xls.getSheetAt(0);
OPCPackage 打开文件(InputStream)时出现错误。请问有人可以帮助我吗?
库:poi 3.17 和所有依赖项,itextpdf 5.5.13
最佳答案
请检查您的依赖项的实际版本(例如使用 mvn dependency:tree
)。
我认为 poi 3.17 和 itextpdf 5.5.13 没有任何问题。下面pom的单元测试通过了。
package stackoverflow.q59892610;
import org.junit.Rule;
import org.junit.Test;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.junit.rules.TemporaryFolder;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.util.UUID;
import static org.apache.poi.xssf.usermodel.XSSFWorkbookType.XLSX;
import static org.junit.Assert.*;
public class PoiTest
{
@Rule
public TemporaryFolder folder= new TemporaryFolder(new File("target"));
@Test
public void xlsTest() throws Exception
{
File file = new File(folder.getRoot(), UUID.randomUUID() + ".xlxs");
String cellValue = UUID.randomUUID().toString();
try (XSSFWorkbook xls = new XSSFWorkbook(XLSX)) {
xls.createSheet("new sheet").createRow(0).createCell(0).setCellValue(cellValue);
try(OutputStream out = new FileOutputStream(file)) {xls.write(out);}
}
ByteArrayOutputStream baos = new ByteArrayOutputStream();
XSSFWorkbook xls = new XSSFWorkbook(file);
XSSFSheet worksheet = xls.getSheetAt(0);
assertEquals("cell value mismatch", cellValue, worksheet.getRow(0).getCell(0).getStringCellValue());
}
}
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>stackoverflow</groupId>
<artifactId>poi-logger</artifactId>
<packaging>jar</packaging>
<version>1.0-SNAPSHOT</version>
<name>poi-logger</name>
<url>http://maven.apache.org</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<poi-version>3.17</poi-version>
<itextpdf-version>5.5.13</itextpdf-version>
<junit-version>4.13</junit-version>
</properties>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>${junit-version}</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>${poi-version}</version>
</dependency>
<dependency>
<groupId>com.itextpdf</groupId>
<artifactId>itextpdf</artifactId>
<version>${itextpdf-version}</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>${poi-version}</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
关于java.lang.NoSuchMethodError : org. apache.poi.util.POILogger.log(ILjava/lang/Object;Ljava/lang/Throwable;)V,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59892610/
尝试在 mysql 数据库中使用 log4j2 进行日志记录时出现此错误: java.lang.AbstractMethodError: org.apache.commons.dbcp.Delegat
我已添加 Itercom Chat 以获得客户支持或联系我们。但是当我添加对讲 sdk 依赖项时 ( implementation 'io.intercom.android:intercom-sdk-
这个问题在这里已经有了答案: Why do I get java.lang.AbstractMethodError when trying to load a blob in the db? (14
这个问题在这里已经有了答案: Why do I get java.lang.AbstractMethodError when trying to load a blob in the db? (14
我有一个测试用例,我试图使用 JNI 从我的 Java 程序访问 C 代码。涉及的步骤如下: 1。调用 native 方法的 Java 程序: public class RunnerClass{
尝试将 CKEditor(用于 CMS - 内容管理系统)的内容插入 Oracle 数据库时出现以下异常 - 甲骨文 10g . Oracle 表中的字段是clob 类型。 java.lang.Abs
我正在将 Hibernate 4.2 与 c3p0 一起使用,但出现此错误:Method com/mchange/v2/c3p0/impl/NewProxyPreparedStatement.setC
有没有办法解决这种报错: # A fatal error has been detected by the Java Runtime Environment: # # SIGSEGV (0xb) a
您好,我第一次尝试使用 apache.poi 将 xlsx 转换为 pdf,它工作得很好,直到我添加一些需要使用 3.17 版本的代码(将 docx 转换为 pdf)。之后,当我尝试转换 xlsx 时
我的 DAO 总是抛出这个异常:java.lang.NoSuchMethodError: fr.la.juserright.metier.Ressource.(ILjava/lang/String;L
我是 maven、spring、嵌入式 glassfish、依赖冲突的新手(我不知道如何查看它们以及如何解决它们)...而且我无法单独解决这个问题,即使我我花了几个小时尝试。 我没有遇到嵌入式 tom
我是一个有 maven、spring、依赖冲突的新手(我不知道如何查看它们以及如何解决它们)...即使我花了几个小时尝试解决这个问题,我也无法单独解决. 感谢您花时间帮助解决问题 错误 SEVERE:
我是一名优秀的程序员,十分优秀!