【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);
}
相关推荐
赫瑞11 分钟前
Java中的 Dijkstra 算法
java·算法
pip install USART12 分钟前
解决@Autowired注解失败导致空指针bug
java·spring·bug
摇滚侠19 分钟前
限流的方法,Redis 计算器限流算法、滑动时间窗口限流算法、漏漏桶限流算法、令牌桶限流算法,Java 开发
java·数据库·redis
IronMurphy22 分钟前
Java 泛型深度解析:编译期类型擦除机制与 PECS 准则
java·windows·python
南山love33 分钟前
spring-boot项目实现发送qq邮箱
java·服务器·前端
wuqingshun31415936 分钟前
说一下spring的bean的作用域
java·后端·spring
花间相见1 小时前
【Java基础面试题】—— 核心知识点面试题(含答案):语法+集合+JVM+设计模式+算法
java·jvm·设计模式
会飞De琥珀1 小时前
java工具类,字符串转时间
java·开发语言
曹牧2 小时前
JSON 数组的正确使用方式
java·服务器·前端
LINgZone22 小时前
深入解析:Cglib与JDK动态代理的实现原理、区别及性能对比
java·开发语言