在java中获取excel的cell值的时候报错

在获取cell的时候,通常会有报错类型不匹配的问题,这是因为你的cell中存储的数据类型和使用的方法不匹配的原因,假如说cell中存储了一个数字,但是使用的cell.getStringCellValue()获取值,就会有如下错误

java.lang.IllegalStateException: Cannot get a STRING value from a NUMERIC cell

at org.apache.poi.xssf.usermodel.XSSFCell.typeMismatch(XSSFCell.java:946)

at org.apache.poi.xssf.usermodel.XSSFCell.getRichStringCellValue(XSSFCell.java:336)

at org.apache.poi.xssf.usermodel.XSSFCell.getStringCellValue(XSSFCell.java:280)

at com.example.test.TestApplicationTests.testIsEmpty(TestApplicationTests.java:68)

at com.example.test.TestApplicationTests.branch(TestApplicationTests.java:44)

at com.example.test.TestApplicationTests.main(TestApplicationTests.java:35)

这种错误的处理方式很简单,之前有一种方式,是可以解决这个问题的,但是这个方法已经被弃用了,所以找了一下现行可用的方法

java 复制代码
cell.setCellType(CellType.STRING);
cell.getStringCellValue();

这个是从其他地方找到解决方式,可以参考一下

java 复制代码
//使用的是这个包下的
import org.apache.poi.ss.usermodel.*;

//格式化cell,就可以获取cell的值
DataFormatter formatter = new DataFormatter();
String stringCellValue = formatter.formatCellValue(cell);

这个方式看了一下源码,大概是这么个意思哈,此处对cell做了空判断,第二个从字面意思来看,应该是判断是否是公式数据(是否引用函数),如果此处不准确的话,有了解的大佬给我回消息哈,我及时纠正

再接下来对型号进行分支匹配,对于各种类型,进行响应的值的返回,此处涉及到一个cell.getRichStringCellValue()方法,也是用来获取cell的值,但是与getStringCellValue不同的是,这个方法功能更加丰富,比如文字的样式,颜色等等

相关推荐
2501_9181269110 分钟前
学习所有6502写游戏控制器的语句
java·linux·网络·汇编·嵌入式硬件
消失的旧时光-194310 分钟前
C++ 多态核心三件套:虚函数、纯虚函数、虚析构函数(面试 + 工程完全指南)
开发语言·c++·面试·虚函数·纯虚函数·虚析构函数
青春易逝丶28 分钟前
策略模式
java·开发语言·策略模式
freexyn29 分钟前
Matlab入门自学七十四:坐标系转换,直角坐标、极坐标和球坐标的转换
开发语言·算法·matlab
贼爱学习的小黄36 分钟前
NC BIP参照开发
java·前端·nc
小江的记录本40 分钟前
【MyBatis-Plus】MyBatis-Plus的核心特性、条件构造器、分页插件、乐观锁插件
java·前端·spring boot·后端·sql·tomcat·mybatis
小张会进步41 分钟前
数组:二维数组
java·javascript·算法
vx-程序开发1 小时前
springboot在线装修管理系统-计算机毕业设计源码56278
java·c语言·spring boot·python·spring·django·php
大傻^1 小时前
Spring AI Alibaba 可观测性实践:AI应用监控与链路追踪
java·人工智能·后端·spring·springaialibaba
Dxy12393102161 小时前
js如何把字符串转数字
开发语言·前端·javascript