poi相关编译报错,运行保找不到CLASS org.apache.poi.ss.usermodel.Date1904Support

本文解决了一个关于Eclipse中出现的包处理错误问题,该问题与org.apache.poi.ss.usermodel.Date1904Support有关。尽管Maven可以正常打包,但在Eclipse中会出现编译错误。文章指出这可能是由于poi.jar和poi-ooxml.jar的版本不一致导致的。

eclipse编译报错,package第一行报错,提示org.apache.poi.ss.usermodel.Date1904Support这个无法处理,但是maven能正常打包,但是eclipse编译报错很不爽,后来在网上查了下,果然有相同的问题,说是版本冲突poi.jar 和poi-ooxml.jar版本号必须一直

参考网址

https://blog.youkuaiyun.com/luckyboy198961/article/details/105035842 

<think> 我们正在解决EasyExcel报错:`NoSuchMethodError: org.apache.poi.ss.usermodel.Cell.getCellType()`。根据引用内容,这个错误通常是由于POI版本冲突引起的。具体来说,EasyExcel内部依赖了特定版本的POI,而项目中可能引入了不兼容的POI版本(比如旧版本3.17和新版本4.0.1混用),导致在运行不到正确的方法(因为不同版本的POI中`Cell`类的方法可能有差异)。 引用[4]中提到,通过排除其他对POI的依赖(如注释掉指定的旧版本POI依赖)解决了类似问题。因此,我们的解决方案主要是解决版本冲突。 ### 错误原因 `NoSuchMethodError`通常发生在: 1. **编译时和运行时类路径不一致**:编译时使用的是高版本POI(比如4.x以上,其中`Cell.getCellType()`方法存在),而运行时加载了低版本POI(如3.17,其中`Cell.getCellType()`不存在,而是`Cell.getCellTypeEnum()`)。 2. **多个POI版本共存**:项目中引入了多个不同版本的POI,导致类加载器加载了错误版本的类。 ### 解决方案 #### ✅ 方案1:统一POI版本(推荐) 确项目中所有POI相关依赖(包括传递依赖)使用与EasyExcel兼容的版本。根据引用[1]和[4]的经验,我们可以采取以下步骤: 1. **检查当前依赖树**,出冲突的POI版本: ```bash mvn dependency:tree -Dincludes=org.apache.poi ``` 或者对于Gradle项目: ```bash gradle dependencies --configuration runtimeClasspath | grep poi ``` 2. **排除旧版本POI依赖**,特别是在其他依赖中传递进来的旧版本POI。例如,如果某个依赖引入了`poi:3.17`,我们需要排除它: ```xml <dependency> <groupId>some.group</groupId> <artifactId>some-artifact</artifactId> <version>xxx</version> <exclusions> <exclusion> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> </exclusion> <!-- 如果有poi-ooxml也要排除 --> <exclusion> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> </exclusion> </exclusions> </dependency> ``` 3. **显式声明与EasyExcel兼容的POI版本**。根据引用[1]中使用的EasyExcel版本(2.1.6),我们应选择与之兼容的POI版本(通常EasyExcel 2.x兼容POI 4.x)。在`pom.xml`中添加: ```xml <properties> <!-- 建议使用POI 4.1.2,因为EasyExcel 2.1.6通常适配此版本 --> <poi.version>4.1.2</poi.version> </properties> <dependencies> <!-- EasyExcel --> <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>2.1.6</version> <!-- 排除EasyExcel内部可能引入的旧版POI --> <exclusions> <exclusion> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> </exclusion> <exclusion> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> </exclusion> </exclusions> </dependency> <!-- 显式引入POI --> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>${poi.version}</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>${poi.version}</version> </dependency> </dependencies> ``` #### ✅ 方案2:升级EasyExcel版本(如果可行) 考虑升级到较新的EasyExcel版本(如3.x),因为新版本可能已经解决了与POI的兼容性问题。但要注意,升级后可能会有API变动。例如: ```xml <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>3.3.2</version> </dependency> ``` 然后同样需要确POI版本为5.x(与EasyExcel 3.x兼容): ```xml <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>5.2.3</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>5.2.3</version> </dependency> ``` #### ✅ 方案3:检查依赖作用域 确POI依赖的作用域不是`provided`或`test`,否则在运行时可能无法使用。例如: ```xml <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>4.1.2</version> <!-- 不要使用provided --> <!-- <scope>provided</scope> --> </dependency> ``` ### 验证 在代码中添加以下检查,确加载的POI版本正确: ```java import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; public class POIVersionChecker { public static void main(String[] args) { // 检查Cell类是否有getCellType方法 try { Cell.class.getMethod("getCellType"); System.out.println("POI版本兼容(4.x以上)"); } catch (NoSuchMethodException e) { System.err.println("错误:使用了不兼容的POI版本(可能是3.x)"); } } } ``` ### 常见错误排查 - **`NoClassDefFoundError` 或 `NoSuchMethodError` 仍然存在**:可能是依赖排除不彻底,或者有多个版本的POI jar包被加载。使用`mvn dependency:tree`仔细检查。 - **日志警告**:注意类加载时的警告信息,如`Overriding managed version`,表明Maven在解决版本冲突。 ### 参考 - 引用[4]中用户通过排除旧版本POI解决了问题[^4]。 - 引用[1]中提到了EasyExcel的依赖配置[^1]。 §§相关问题§§ 1. EasyExcel与POI版本兼容性对照表是什么? 2. 如何排查Maven项目中的依赖冲突问题? 3. 使用EasyExcel导出Excel时如何避免内存溢出? </think>### 解决 EasyExcel 报错 `NoSuchMethodError: org.apache.poi.ss.usermodel.Cell.getCellType()` 的方案 #### 🔍 问题原因分析 此错误通常由 **POI 版本冲突** 引起: 1. **方法签名变更** POI 3.x 中 `Cell.getCellType()` 返回 `int`,而 POI 4.x+ 改为 `Cell.getCellType()` 返回 `CellType` 枚举类型,旧方法已废弃[^1][^3] ```java // POI 3.x (已过时) int cellType = cell.getCellType(); // POI 4.x+ CellType cellType = cell.getCellType(); ``` 2. **依赖冲突** 项目中同时存在多个 POI 版本(如 3.x 和 4.x),导致 JVM 加载了错误版本的方法实现[^4] 3. **EasyExcel 版本兼容性** EasyExcel 2.x 兼容 POI 3.17,而 EasyExcel 3.x 需要 POI 5.x[^1][^4] --- ### ✅ 解决方案 #### 方案 1:统一 POI 版本(推荐) 在 `pom.xml` 中强制指定 POI 版本并排除旧依赖: ```xml <properties> <!-- EasyExcel 2.x 用 4.1.2,EasyExcel 3.x 用 5.2.3 --> <poi.version>4.1.2</poi.version> </properties> <dependencies> <!-- 1. 引入 EasyExcel --> <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>2.1.6</version> <!-- 排除旧版 POI --> <exclusions> <exclusion> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> </exclusion> <exclusion> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> </exclusion> </exclusions> </dependency> <!-- 2. 显式声明 POI 依赖 --> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>${poi.version}</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>${poi.version}</version> </dependency> </dependencies> ``` #### 方案 2:升级 EasyExcel + POI(适用于新项目) ```xml <!-- EasyExcel 3.x + POI 5.x --> <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>3.3.2</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>5.2.3</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>5.2.3</version> </dependency> ``` #### 方案 3:排查依赖冲突 通过 Maven 命令检查冲突: ```bash mvn dependency:tree -Dincludes=org.apache.poi ``` 若发现旧版本(如 3.17),在冲突的依赖中排除: ```xml <dependency> <groupId>some.group</groupId> <artifactId>conflicting-artifact</artifactId> <version>1.0</version> <exclusions> <exclusion> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> </exclusion> <exclusion> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> </exclusion> </exclusions> </dependency> ``` --- ### 🧪 验证步骤 1. **清理并重建项目**: ```bash mvn clean install -U ``` 2. **检查加载的 POI 版本**: ```java public class PoiVersionChecker { public static void main(String[] args) { System.out.println("POI Version: " + org.apache.poi.Version.getVersion()); } } ``` 3. **验证方法是否存在**: ```java try { Class<?> cellClass = Class.forName("org.apache.poi.ss.usermodel.Cell"); cellClass.getMethod("getCellType"); System.out.println("✅ getCellType 方法存在"); } catch (Exception e) { System.out.println("❌ 方法不存在: " + e.getMessage()); } ``` --- ### 📊 EasyExcel 与 POI 版本兼容表 | EasyExcel 版本 | 推荐 POI 版本 | 注意事项 | |----------------|---------------|----------| | 2.1.x / 2.2.x | 4.1.2 | 兼容旧版 `getCellType()` | | 3.0.x+ | 5.2.3 | 需适配新版枚举类型 | | 3.3.x+ | 5.2.3 | 需添加 `xmlbeans` 依赖 | > **📌 关键提示**:EasyExcel 3.x 默认要求 POI 5.x+,使用旧版 POI 4.x 会引发 `NoSuchMethodError`[^4] [^1]: EasyExcel 2.1.6 默认依赖 POI 3.17,方法签名已过时 [^3]: POI 4.x 重构了 `Cell` 类的方法签名 [^4]: 排除旧版 POI 依赖是解决冲突的有效方案
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值