Bigdecimal 导出为excel时显示未0E-10,不是0,怎么解决
在使用 BigDecimal 导出到 Excel 时,如果遇到显示为 0E-10 而不是 0 的问题,这通常是因为 BigDecimal 对象的精度问题。0E-10 表示的是 0 乘以 10 的 -10 次方,这在数学上等同于 0,但在 Excel 中显示时可能会出现问题。
以下是一些解决方法:
1. 设置 BigDecimal 的精度
在导出之前,可以设置 BigDecimal 的精度,确保其小数位数为零。
import java.math.BigDecimal;
import java.math.RoundingMode;BigDecimal value = new BigDecimal("0.0000000000");
value = value.setScale(0, RoundingMode.DOWN);
2. 使用 BigDecimal.stripTrailingZeros()
stripTrailingZeros() 方法可以去除 BigDecimal 对象末尾的零,并将其转换为标准形式。
import java.math.BigDecimal;BigDecimal value = new BigDecimal("0.0000000000");
value = value.stripTrailingZeros();
3. 在 Excel 中格式化单元格
如果上述方法仍然无法解决问题,可以在 Excel 中手动格式化单元格,将其设置为数值格式,并指定小数位数为零。
4. 使用 Apache POI 导出 Excel
如果你使用的是 Apache POI 库来导出 Excel,可以在写入单元格时进行格式化。
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;import java.io.FileOutputStream;
import java.io.IOException;
import java.math.BigDecimal;public class ExcelExporter {public static void main(String[] args) throws IOException {Workbook workbook = new XSSFWorkbook();Sheet sheet = workbook.createSheet("Sheet1");BigDecimal value = new BigDecimal("0.0000000000");value = value.stripTrailingZeros();Row row = sheet.createRow(0);Cell cell = row.createCell(0);cell.setCellValue(value.toPlainString());try (FileOutputStream fileOut = new FileOutputStream("workbook.xlsx")) {workbook.write(fileOut);}}
}
5. 自定义格式化方法
你也可以编写一个自定义方法来处理 BigDecimal 的显示问题。
import java.math.BigDecimal;public class BigDecimalUtils {public static String format(BigDecimal value) {if (value.compareTo(BigDecimal.ZERO) == 0) {return "0";}return value.stripTrailingZeros().toPlainString();}
}
然后在导出时使用这个方法:
BigDecimal value = new BigDecimal("0.0000000000");
String formattedValue = BigDecimalUtils.format(value);
cell.setCellValue(formattedValue);
通过上述方法,你可以确保 BigDecimal 在导出到 Excel 时显示为 0 而不是 0E-10。
相关文章:
Bigdecimal 导出为excel时显示未0E-10,不是0,怎么解决
在使用 BigDecimal 导出到 Excel 时,如果遇到显示为 0E-10 而不是 0 的问题,这通常是因为 BigDecimal 对象的精度问题。0E-10 表示的是 0 乘以 10 的 -10 次方,这在数学上等同于…...
springboot项目从jdk8升级为jdk17过程记录
背景:公司有升级项目jdk的规划,计划从jdk8升级到jdk11 开始 首先配置本地的java_home 参考文档:Mac环境下切换JDK版本及不同的maven-CSDN博客 将pom.xml中jdk1.8相关的版本全部改为jdk17,主要是maven编译插件之类的,…...
list、tuple、set和dict传参机制
1、list、tuple、set和dict传参机制 # -------------list------------- def f1(my_list):print(f"②f1()my_list:{my_list} 地址是:{id(my_list)}") # ["tom","mary","hsp"] 0x1122my_list[0]"jack"print(f&quo…...
Redis快速入门基础
Redis入门 Redis是一个基于内存的 key-value 结构数据库。mysql是二维表的接口数据库 优点: 基于内存存储,读写性能高 适合存储热点数据(热点商品、资讯、新闻) 企业应用广泛 官网:https://redis.io 中文网:https://www.redis.net.cn/ Redis下载与…...
python基础介绍
这次的专题是关于python的知识点,加油! 文章目录 1 什么是计算机(1.1 哪些可以称为计算机?(以下)(1.2 计算机可以完成的工作有哪些?(1.3 一台计算机由什么构成? 2. 什么是编程(2.1 编…...
SSRF中伪协议学习
SSRF常用的伪协议 file:// 从文件系统中获取文件内容,如file:///etc/passwd dict:// 字典服务协议,访问字典资源,如 dict:///ip:6739/info: ftp:// 可用于网络端口扫描 sftp:// SSH文件传输协议或安全文件传输协议 ldap://轻量级目录访问协议 tftp:// 简单文件传输协议 gopher…...
Java | Leetcode Java题解之第284题窥视迭代器
题目: 题解: class PeekingIterator<E> implements Iterator<E> {private Iterator<E> iterator;private E nextElement;public PeekingIterator(Iterator<E> iterator) {this.iterator iterator;nextElement iterator.next(…...
哈尔滨等保定级的常见问题
一、哈尔滨等保测评定级标准理解问题 哈尔滨等保测评如何确定信息系统的安全保护等级? 信息系统的安全保护等级应根据其在国家安全、经济建设、社会生活中的重要程度,以及一旦遭到破坏后对国家安全、社会秩序、公共利益以及公民、法人和其他组织的合法权…...
springAOP理解及事务
AOP: springAOP是什么: AOP:Aspect Oriented Programming(面向切面编程、面向方面编程),其实就是面向特定方法编程。 使用场景: 比如你想统计业务中每个方法的执行耗时,那我们最…...
Optional类的使用 java8(附代码)
🍰 个人主页:_小白不加班__ 🍞文章有不合理的地方请各位大佬指正。 🍉文章不定期持续更新,如果我的文章对你有帮助➡️ 关注🙏🏻 点赞👍 收藏⭐️ 文章目录 一、什么是Optional?二、…...
企业利用AI智能名片S2B2C商城小程序参与社区团购的风险与机遇分析
摘要 在新零售浪潮的推动下,社区团购以其独特的商业模式迅速崛起,成为连接消费者与供应商的重要桥梁。企业纷纷探索如何有效利用这一新兴渠道,以扩大市场份额、提升品牌影响力。AI智能名片S2B2C商城小程序的引入,为企业参与社区团…...
全链路追踪 性能监控,GO 应用可观测全面升级
作者:古琦 01 介绍 随着 Kubernetes 和容器化技术的普及,Go 语言不仅在云原生基础组件领域广泛应用,也在各类业务场景中占据了重要地位。如今,越来越多的新兴业务选择 Golang 作为首选编程语言。得益于丰富的 RPC 框架ÿ…...
深入探索CSS3的Media Query:打造响应式网页设计的利器
在今天的互联网世界中,随着设备种类和屏幕尺寸的多样化,响应式网页设计(Responsive Web Design, RWD)已成为不可或缺的一部分。CSS3中的Media Query正是这一设计理念的实现利器,它允许开发者根据用户的设备特性和屏幕尺…...
DDD(Domain-Driven Design)领域驱动设计
在软件开发中,DDD(Domain-Driven Design,领域驱动设计)是一种方法论,它强调在开发过程中将业务领域的知识和规则作为核心。DDD的目标是通过理解和建模业务领域来创建更好的软件系统。本文将详细讲解DDD的基本概念、原则…...
基于k8s快速搭建docker镜像服务的demo
基于k8s快速搭建docker镜像服务的demo 一、环境准备 如标题,你需要环境中有和2个平台,并且服务器上也已经安装好docker服务 接下来我来构建一个docker镜像,然后使用harbork8s来快速部署服务demo 二、部署概述 使用docker构建镜像&#x…...
“论大数据处理架构及其应用”写作框架,软考高级论文,系统架构设计师论文
论文真题 大数据处理架构是专门用于处理和分析巨量复杂数据集的软件架构。它通常包括数据收集、存储、处理、分析和可视化等多个层面,旨在从海量、多样化的数据中提取有价值的信息。Lambda架构是大数据平台里最成熟、最稳定的架构,它是一种将批处理和流…...
tarojs项目启动篇
TaroJS 是一个开放式跨端开发解决方案,使用 React 语法规范来开发多端应用(包括小程序、H5、React Native 等)。它可以帮助开发者高效地构建出在不同端上运行一致的应用。以下是启动 TaroJS 项目(本来就有的旧项目)的步…...
Maven打包时将本地 jar 加入 classpath
在使用 maven 编译项目时,我们有时候会需要引入本地的 jar 包作为依赖(不部署到本地仓库),一般会使用 scope 为 system 的标签来引入,如下所示: <dependency><groupId>com.example</groupI…...
Spring Boot打出的jar包为什么可以独立运行
闲来无事,浏览网页看到有人说jar包为什么可以独立运行,想起前端时间写的jar打包后无法正常运行处理。jar解压缩后有多个文件夹,内部存放运行所需jar包和一些配置文件,本文做一个简单介绍。 JAR包和WAR包区别 在Java开发中&#…...
“微软蓝屏”事件:网络安全与稳定性的深刻反思
🌈所属专栏:【其它】✨作者主页: Mr.Zwq✔️个人简介:一个正在努力学技术的Python领域创作者,擅长爬虫,逆向,全栈方向,专注基础和实战分享,欢迎咨询! 您的点…...
NoderCMS开发者手册:扩展功能与自定义模块开发技巧
NoderCMS开发者手册:扩展功能与自定义模块开发技巧 【免费下载链接】nodercms 轻量级内容管理系统,基于 Node.js MongoDB 开发,拥有灵活的内容模型以及完善的权限角色机制。 项目地址: https://gitcode.com/gh_mirrors/no/nodercms N…...
如何为sync-settings开发自定义存储位置插件:完整开发者指南
如何为sync-settings开发自定义存储位置插件:完整开发者指南 【免费下载链接】sync-settings Synchronize all your settings and packages across atom instances 项目地址: https://gitcode.com/gh_mirrors/sy/sync-settings 你是否想要为Atom的sync-setti…...
在Ubuntu 22.04上,用AutoDockTools给蛋白-小分子做对接,保姆级避坑指南
在Ubuntu 22.04上,用AutoDockTools给蛋白-小分子做对接,保姆级避坑指南1. 环境准备与依赖安装Ubuntu 22.04 LTS作为长期支持版本,其稳定性非常适合科研计算。但首次使用时,需要确保系统环境完整。打开终端(CtrlAltT&am…...
深入Linux内核链表:从of_property_read_bool看设备树属性的组织与查找
深入Linux内核链表:从of_property_read_bool看设备树属性的组织与查找 在Linux内核开发中,设备树(Device Tree)作为描述硬件配置的标准方式,其高效解析机制一直是内核开发者关注的焦点。当我们调用 of_property_read_…...
机器学习引导的多目标运动规划:TSP与采样搜索的深度耦合
1. 项目概述:当机器人需要“跑腿”时,我们如何为它规划最优路线?想象一下,你是一个仓库管理员,手里有一台自动导引车(AGV),今天它的任务是从仓库的充电桩出发,依次去货架…...
AI Agent Harness Engineering 生态工具链盘点:2026 开发者必备的 15 款核心工具
AI Agent Harness Engineering 生态工具链盘点:2026 开发者必备的 15 款核心工具 关键词:AI Agent Harness Engineering、Agent 编排调度、多模态工具调用、RAG增强协同、端云混合部署、伦理安全合规、图灵完备推理链、2026开发者技术栈 摘要:…...
开源可穿戴系统HARNode:低成本高精度人体活动识别方案
1. 项目概述:开源可穿戴系统如何革新人体活动识别研究在人体活动识别(HAR)研究领域,我们长期面临一个尴尬局面:实验室里的算法准确率动辄宣称99%,但一到真实场景就频频失灵。问题根源在于——研究者们往往只…...
UE5 RPG开发实战:用MVC架构重构你的UI系统(GAS项目避坑指南)
UE5 RPG开发实战:用MVC架构重构UI系统的工程化实践当你的UE5 RPG项目从原型阶段进入正式开发,UI系统往往会成为第一个显露出架构问题的模块。属性面板、技能栏、BUFF指示器等数十个UI组件相互纠缠,每次新增功能都像在走钢丝——这就是我们引入…...
Unity Addressable本地HTTP服务器5分钟合规搭建指南
1. 为什么Addressable资源托管总卡在“本地跑不通”这一步? Unity Addressable Asset System(可寻址资源系统)上线这么多年,我见过太多团队在最后一步集体卡壳:资源打包没问题,加载逻辑写得滴水不漏&#…...
Redis 缓存实战案例与技术详解
Redis 缓存实战案例与技术详解 1. Redis 简介 Redis 是一种开源的内存数据存储,常用于缓存和消息队列。 2. 配置优化 使用 LRU 淘汰策略配置数据持久化功能 3. 实战案例 案例一:电商秒杀系统 架构:前端系统 Redis 持久化缓存特点:…...
