按照人们阅读Excel习惯来格式化BigDecimal

1、环境/问题描述

使用springboot发送邮件(附件)的方式将月度报表发送给领导查阅,数据是准确的,领导基本满意。

就是对一些数字的格式化提出了改进建议,比如不要让大数字自动转为科学计数法、浮点数小数点后都是0就不要带出来,根据某列的数值(0-100之间)设置单元格的底色,小于60的标深红色、大于等于60小于70标浅红色,大于等于70小于等于80标浅绿色,大于等于80小于90标中绿色,大于等于90的标深绿色。

2、分析/排查问题

1) 科学计算法的问题

经常,发现数字的长度超过8位Excel才会将次单元格中的值进行科学计算法转换,解决办法就是判断数字的长度,然后设置单元格存储的值类型

2) 浮点数小数点后都是0就不要带出来

数据表中的字段类型设置的是decimal(12,4),存储的值就是预期值,无小数位的就是证书、带小数位的小数位必定不全为0,只是通过mybatis-plus读取出来映射到Java Bean时自动将数字格式化为必定带4位小数,小数位无值则用0填充了

3) 根据某列的数值(0-100之间)设置单元格的底色

可以根据该单元格的数值大小根据规则进行设置色值,通过poi提供的方式给单元格设置底色

3、解决问题

1) 科学计算法的问题
java 复制代码
String s = o.toString();
// 当数字类型长度超过8位时,改为字符串类型显示(Excel数字超过一定长度会显示为科学计数法)
if ( isNumeric( o ) && s.length() < 8 ) {
	cell.setCellType( CellType.NUMERIC );
	cell.setCellValue( Double.parseDouble( s ) );
	return CELL_OTHER;
} else {
	cell.setCellType( CellType.STRING );
	cell.setCellValue( s );
}
2) 浮点数小数点后都是0就不要带出来
java 复制代码
public class BigDecimalFormatter {

    public static String format(BigDecimal number) {
        return format(number,5);
    }

    /**
     * 格式化BigDecimal
     * @param number 要处理的数字
     * @param newScale 保留的小数位
     * @return
     */
    public static String format(BigDecimal number,int newScale) {
        // 设置小数点后最多保留位位数(可以根据需要调整),并四舍五入
        BigDecimal formatted = number.setScale(newScale, RoundingMode.HALF_UP);

        // 再次移除尾随的零
        BigDecimal stripped = formatted.stripTrailingZeros();

        // 如果 scale 是负数或 0,则说明没有小数部分
        if (stripped.scale() <= 0) {
            return stripped.toBigInteger().toString(); // 返回整数部分
        } else {
            return stripped.toString(); // 包含小数部分
        }
    }

    public static String format2(BigDecimal number) {
        return number.stripTrailingZeros().toPlainString();
    }

    public static void main(String[] args) {
        System.out.println(format(new BigDecimal("123.000")));
        System.out.println(format(new BigDecimal("123.456")));
        System.out.println(format(new BigDecimal("123.00100")));
        System.out.println(format2(new BigDecimal("123.000")));
        System.out.println(format2(new BigDecimal("123.456")));
        System.out.println(format2(new BigDecimal("123.00100")));
    }
}
/**
 * 输出以下内容格式
 123
123.456
123.001
123
123.456
123.001
 */
3) 根据某列的数值(0-100之间)设置单元格的底色
java 复制代码
String hexColorStr = "十六进制色值";
XSSFColor xssfColor = new XSSFColor();
xssfColor.setARGBHex( hexColorStr );
cellStyle.setFillForegroundColor( xssfColor );
cellStyle.setFillBackgroundColor( xssfColor );
cellStyle.setFillPattern( FillPatternType.SOLID_FOREGROUND );
// 设置样式
cell.setCellStyle( cellStyle );

至此,问题得到解决,此处记录一下

相关推荐
罗政2 小时前
一键对多个Excel文件进行差异内容提取分析+显示差值
excel
罗政7 小时前
AI提取一批Excel单元格内容(快递信息)数据安全,支持断网提取
人工智能·excel
2501_930707787 小时前
使用C#代码合并或取消合并 Excel 单元格
excel
罗政7 小时前
面向提示词对多Excel,多表单进行“数据分组统计”,“条件合并”,“复杂查询”,“SQL执行”,本地操作,支持百万行表单数据
数据库·sql·excel
无穷小亮17 小时前
Flutter框架跨平台鸿蒙开发——Excel函数教程APP的开发流程
flutter·华为·excel·harmonyos·鸿蒙
开开心心_Every1 天前
家长控制电脑软件:定时锁屏管理使用时长
网络协议·tcp/ip·游戏·微信·pdf·excel·语音识别
技小宝1 天前
Excel网页抓取:批量获取亚马逊商品主图
大数据·经验分享·职场和发展·excel
燕儿_飘飘1 天前
Excel单个表格占用大量空间的问题解决方案
excel·技巧
写代码的【黑咖啡】1 天前
Python中Excel文件的强大处理工具:OpenPyXL
开发语言·python·excel
luffy54591 天前
txt文件所有数据在一列如何转多行多列
windows·excel·txt·一列转多行·一列