离奇问题:java通过poi读取excel单元格的小数时会出错

问题

java通过poi读取excel单元格的小数时会出错,分析后发现是因为会损失精度。

处理的代码

/*** DataFormatter 直接new就行:DataFormatter df = new DataFormatter();*/
private String getNumericCellValue(Cell cell, DataFormatter df) {String valueStr = df.formatCellValue(cell);// 格式化后的数字,比如会保留后面的0if (StringUtils.isNotBlank(valueStr)) {CellStyle cellStyle = cell.getCellStyle();if (cellStyle != null) {String formatString = cellStyle.getDataFormatString();if ("General".equals(formatString)) {// 常规,则直接返回格式化后的值return valueStr;} else {// 如果不是常规,比较准确数字和格式化后的数字小数位数是否一致String valueString = String.valueOf(cell.getNumericCellValue());// 准确的数字if (!valueString.endsWith("0")) {// 如果不是以0结尾,就获取字符串,否则可能不准确cell.setCellType(Cell.CELL_TYPE_STRING);String valueStringStr = cell.getStringCellValue();// 准确的数字字符串if (!valueString.equals(valueStringStr)) {logger.warn("数字与字符串不一致:" + valueString + "," + valueStringStr);valueString = valueStringStr;}}int pointNumString = MathUtil.getDecimalPlace(valueString);// 准确数字的小数位数int pointNumStr = MathUtil.getDecimalPlace(valueStr);// 格式化后数字的小数位数// 如果一致,或者格式化后的数字小数位数比准确数字多,则直接返回格式化后的值if (pointNumString <= pointNumStr) {return valueStr;} else {// 否则设置保留的小数位数return new BigDecimal(valueString).setScale(pointNumStr, BigDecimal.ROUND_HALF_UP).toPlainString();}}}}return valueStr;}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/26162.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于GA遗传算法的多机无源定位系统GDOP优化matlab仿真

目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.本算法原理 5.完整程序 1.程序功能描述 基于GA遗传算法的多机无源定位系统GDOP优化matlab仿真。仿真输出GDOP优化结果&#xff0c;遗传算法的优化收敛曲线以及三维空间坐标点。 2.测试软件版本以及运行…

c语言基础篇D

D1.函数概述 一个c程序可以由一个主函数和若干个其他函数构成&#xff0c;一个较大的程序可分为若干个程序模块&#xff0c;每一个模块用来实现一个特定的功能。在高级语言中用子程序实现模块的功能。子函数由函数来完成一个c程序由一个或多个程序模块构成&#xff0c;每一个程…

rust 1.安装

安装 下载地址&#xff1a;https://www.rust-lang.org/learn/get-started rust安装有一个先决条件&#xff1a;cpp的编译器 在windows下进行Rust开发&#xff0c;编译器有两个选择要么是msvc&#xff0c;要么是MinGW&#xff08;GNU&#xff09;。这是两个是不兼容的编译器&a…

SpringBoot的事务注解

SpringBoot的事务注解 在Spring Boot应用中&#xff0c;事务管理是一个关键的部分&#xff0c;尤其是当涉及到数据库操作时。Spring Boot提供了强大的事务管理支持&#xff0c;使得开发人员可以通过简单的注解来控制事务的边界和行为。本文将介绍如何在Spring Boot中使用事务注…

requests库的常用方法

之前都是用jmeter进行接口测试然后进行持续性集成&#xff0c;之前也写过用jmeter来请求各种类型的接口&#xff0c;今天来学习下如何使用pythonrequests对各种接口发起请求并断言。 1.接口类型 测试项目的ip和端口如下&#xff1a; host "ip" port "8080&q…

传感器技术

传感器技术 传感器概述传感器简介传感器的特性线性度灵敏度迟滞重复性传感器的动态特性 步进电动机步进电机的工作原理 传感器概述 传感器简介 传感器&#xff1a;能够感受被测量并按照一定规律转换成可用输出信号的器件或装置。 敏感元件&#xff1a;传感器中能直接感受或响…

Shell脚本要点和难点以及具体应用和优缺点介绍

Shell 脚本是一种用于自动化任务和简化常见系统命令的脚本语言,通常运行在 Unix 或 Unix-like 的系统上,如 Linux 和 macOS。Shell 脚本可以直接在命令行中执行,也可以保存为文件并通过 bash、sh、zsh 等 shell 解释器来执行。 以下是一个简单的 Shell 脚本示例,它演示了如…

WebSphere面试题精选和参考答案(3万字长文)

目录 什么是WebSphere? WebSphere的主要特点是什么? WebSphere支持哪些编程语言? WebSphere的组件有哪些? 什么是WebSphere Application Server(WAS)? 您如何部署应用程序到WebSphere? 什么是热部署? 什么是节点同步? 如何在不停止DMGR的情况下进行WAS配置备…

Nginx之核心配置指令1

作为一款高性能的HTTP服务器软件&#xff0c;Nginx的核心 功能就是应对HTTP请求的处理。由于具体硬件、操作 系统及应用场景的不同&#xff0c;需要Nginx在对HTTP请求的处 理方法上进行不同的调整&#xff0c;为了应对这些差异&#xff0c;Nginx 提供了多种配置指令&#xff0c…

Nodejs 第七十六章(MQ进阶)

MQ介绍和基本使用在上一章介绍过了&#xff0c;不再重复 消息&#xff1a;在RabbitMQ中&#xff0c;消息是传递的基本单元。它由消息体和可选的属性组成 生产者Producer&#xff1a;生产者是消息的发送方&#xff0c;它将消息发送到RabbitMQ的交换器&#xff08;Exchange&…

10款堪称神器的宝藏软件,相见恨晚

今天给大家带来10款堪称神器的宝藏软件&#xff0c;每一个都非常好用&#xff0c;让你直呼相见恨晚。 1、知犀思维导图 知犀思维导图是大家组织信息、梳理思维的重要利器&#xff0c;它可以帮助我们以图形化的方式呈现思维过程&#xff0c;让整体思路变得清晰直观。通过使用知…

【神经网络】资源

神经网络是一种模拟人脑神经元结构的计算模型&#xff0c;广泛应用于机器学习和深度学习领域。以下是一些关于神经网络的资源&#xff0c;可以帮助你从基础到高级逐步掌握相关知识&#xff1a; 入门教程&#xff1a; 《神经网络教程&#xff1a;从原理到实践的全面解析》提供…

3 数据类型、运算符与表达式-3.5 字符型数据-3.5.2 转义字符

3.5.2 转义字符 #include <stdio.h>main() {int a, b, c;a 5;b 6;c 7;printf("ab c\tde\rf\n");printf("hijk\tL\bM\n");return 0; }

架构师如何运用情景领导力

架构师应用情景领导力意味着根据团队成员的成熟度和项目的具体情况来调整自己的领导风格。以下是架构师如何使用情景领导力的一些方法&#xff1a; 评估团队成员的成熟度&#xff1a;架构师需要评估团队成员在技术和专业领域的成熟度&#xff0c;包括他们的专业技能、经验、解…

花键轴类零件加工方法有哪些?

花键轴零件的加工方法 一辆普通中型卡车上约含 30 个花键轴零件, 通常用在离合器、变速器、传动轴总成、差速器、转向总成等位置。 花键轴零件的加工工艺是传统的切削加工和塑形成形加工两种。传统工艺如下的8个主要工序&#xff1a; 下料→锻造毛坯→毛坯加工→外花键加工…

34、掌握线上系统:jmap和jhat带你深入了解对象分布

34.1、前文总结 在上一篇文章中,我们向大家介绍了一个在日常工作中的实用工具jstat。通过使用jstat,我们可以非常轻松便捷地了解线上系统的运行状况,包括新对象增速、Young GC触发频率及耗时,以及对象进入老年代的增速和Full GC触发频率及耗时。这些信息有助于我们全面掌握…

【C语言】青蛙跳台阶问题 - 递归算法(一种思路,针对三种不同的情况)

文章目录 1. 前言2. 题目和分析2.1 代码实现2.2 反思 (重点) 3.题目二&#xff08;变式&#xff09;3.1 分析3.2 代码实现 4. 题目三&#xff08;变式&#xff09;4.1 分析4.2 代码实现 1. 前言 相信大家看到青蛙跳台阶问题时&#xff0c;第一时间就会想到递归。那你知道为什么…

SwiftUI中结合使用Timer和onReceive

SwiftUI提供了一种现代化的方式来构建用户界面&#xff0c;其中包括对时间驱动的事件的响应。在许多应用中&#xff0c;可能需要根据时间间隔执行某些操作&#xff0c;例如更新界面或触发事件。SwiftUI通过结合使用Timer和 onReceive 来实现这一功能&#xff0c;使得处理时间相…

【免杀】C2远控-Loader加载器-动态API调用

目录 创建后门程序站在杀毒程序立场上对后门进行分析例&#xff1a;动态调用VirtualProtect函数 作用:绕过杀毒对导入表的检测定性 创建后门程序 VS新建项目 回调函数加载Loader #include <Windows.h>unsigned char shellcode[] "";void CallBack() {void* p…

FlashBrowser

本例&#xff1a;windows10 下载FlashBrowser 解决flash失效问题&#xff0c;更换浏览器 https://www.flash.cn/ 下载FlashBrowser浏览器