根据客户提供的Excel,在导入日期数据时,发现获得的值是一串数字。客户设置的日期格式为yyyyy年MM月,当把日期格式设置为yyyy-MM时,就能够正确读取。我们用得是POI3.6,方法:org.apache.poi.ss.usermodel.DateUtil.isCellDateFormatted(Cell cell)。调用时总是返回false,经跟踪源码发现只要含有中文时间单位就不行(例如含有“年”或“月”等时间单位),故修改,增加了对中文时间单位的过滤,经测试判断正确。
方法:DateUtil.isADateFormat(int formatIndex, String formatString)
增加代码内容:
fs = fs.replaceAll("[\"|\']","").replaceAll("[年|月|日|时|分|秒|毫秒|微秒]", "");
附件为修改之后的可执行代码!
解决POI中DateUtil.isCellDateFormatted(Cell cell)不能判断中文日期的问题
最新推荐文章于 2026-05-20 08:24:44 发布
本文介绍使用Apache POI处理Excel文件中日期格式的问题。当遇到特定中文日期格式(如yyyy年MM月)无法被正确识别的情况时,通过修改源码增加对中文时间单位的支持,实现了日期数据的有效读取。
低功耗蓝牙项目,需要一块懂省电的板
思澈 SF32LB52 芯片,BLE 协议栈深度优化,上手即开发
低功耗蓝牙项目,需要一块懂省电的板
思澈 SF32LB52 芯片,BLE 协议栈深度优化,上手即开发


1179

被折叠的 条评论
为什么被折叠?



