【Bug】Apache POI 读取Excel小数补位问题

使用 Apache POI 读取导入的Excel的小数数据时,发现原本的小数值精度发生变化:

导入的是 0.6314,读取的却是 0.6314000000000001

导入的是 0.5207,读取的却是 0.5206999999999999

这种情况是 float数值转成double时增加补位的问题,要解决这个问题可以通过BigDecimal保留固定为小数,但不够准确,如果要将补位后的小数还原,则可以将其再转为float类型的数值即可:

java 复制代码
Cell cell = row.getCell(i);
double val = cell.getNumericCellValue();
String strVal = String.valueOf(val);
String decimalPart = strVal.substring(strVal.indexOf(".") + 1);
// 处理 float 类型转为 double后补0导致小数位不准确的情况(判断方法很粗暴)
BigDecimal newVal = null;
if (decimalPart.contains("00000") || decimalPart.contains("99999")) {
    Float floatVal = new Float(strVal);
    newValc = new BigDecimal(floatVal.toString());
} else {
    newVal = new BigDecimal(strVal);
}
相关推荐
❀͜͡傀儡师17 分钟前
Spring AI Alibaba vs. AgentScope:两个阿里AI框架,如何选择?
java·人工智能·spring
aq553560024 分钟前
Laravel10.x重磅升级,新特性一览
android·java·开发语言
一 乐1 小时前
酒店预订|基于springboot + vue酒店预订系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·酒店预订系统
zfan5201 小时前
python对Excel数据处理(1)
python·excel·pandas
Moe4881 小时前
Spring AI Advisors:从链式增强到递归顾问
java·后端
敖正炀1 小时前
ReentrantReadWriteLock、ReentrantLock、synchronized 对比
java
cike_y1 小时前
Java反序列化漏洞-Shiro721流程分析
java·反序列化·shiro框架
大白菜和MySQL2 小时前
apache服务器部署简记
运维·服务器·apache
极创信息2 小时前
信创系统认证服务怎么做?从适配到验收全流程指南
java·大数据·运维·tomcat·健康医疗
格鸰爱童话2 小时前
向AI学习项目技能(六)
java·人工智能·spring boot·python·学习