java cell值_新版POI获取日期类型cell值过程图解

在使用Java的POI库读取Excel时,遇到日期类型单元格的处理是一个挑战。因为POI将日期作为double值返回,需要通过单元格样式检查数据格式。本文介绍了如何通过`cell.getCellStyle().getDataFormatString()`来判断日期格式,并提供了处理日期的代码示例,包括检查特定日期格式并转换的方法。尽管这种方法存在局限性,但在某些场景下能有效解决问题。
摘要由CSDN通过智能技术生成

使用poi读取excel值的同学,一定为日期类型抓狂过!

poi对单元格日期处理很弱,没有针对的类型,日期类型取出来的也是一个double值,所以同样作为数值类型。即使使用cell.setcelltype(celltype.string) 也还是会返回一个数字

网上大部分的方法是:

cell.getcelltype()

但是在新版的poi中,比如3.15版,这个写法已经被放弃使用了。由于项目需要在下不能调整jar包,只好硬着头皮去解决。

67e2dcf599d0867ab477a78c646c5c74.png

后来发现了一个方法:

cell.getcellstyle().getdataformatstring() 可以判断单元格的格式类型,如下图

96e06c1268f5e6180420e8660a076cc2.png

于是便可以使用如下方法判断:

if("yyyy/mm;@".equals(cell.getcellstyle().getdataformatstring()) || "m/d/yy".equals(cell.getcellstyle().getdataformatstring())

|| "yy/m/d".equals(cell.g

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值