POI设置单元格格式为数值或日期

开发中程序导出的Excel表存在数字和日期为文本格式的问题,数字需转换格式才能统计,日期无法用自动筛选功能。通过Java使用POI设置单元格格式,将数字设为数值、日期设为日期格式,解决了这些问题,且强调保存数据与设置格式需一致。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、需求:开发过程中,程序导出的Excel表中的数字为文本(即在Excel中表现为单元格左上角带绿色三角形),导致需要在Excel中先转换格式才能统计;表中的日期也为文本,不能直接利用Excel的自动刷选功能按月、季度和年度选择。

 

二、关键代码:

(1)设置为数值

        HSSFCellStyle hssfCellStyleDouble = wb.createCellStyle();
        HSSFDataFormat df = wb.createDataFormat(); // 此处设置数据格式
        hssfCellStyleDouble.setDataFormat(df.getBuiltinFormat("#,##0.0"));//保留1位小数点

        cell0.setCellValue( Double.parseDouble(value));    
        cell0.setCellStyle(hssfCellStyleDouble);

(2)设置为日期
        HSSFCellStyle hssfCellStyleDate = wb.createCellStyle();
        hssfCellStyleDate.setDataFormat(df.getFormat("yyyy-MM-dd"));//
        SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");

        cell0.setCellValue(format.parse(value));
        cell0.setCellStyle(hssfCellStyleDate);

三、效果

在图1中可以看到,单元格没有绿色三角形,元数据是整数则显示整数,是小数则保留一位小数,可直接统计。

在图2中可以看到,单元格显示的虽然是yyyy-mm-dd格式,但是在Excel中识别为yyyy/mm/dd格式,这是Excel日期格式默认识别的一种,所以在图3中可以看到可以直接利用EXCEL的自动筛选功能按月、季度和年度进行选择了。

四、总结

单元格除了要设置格式外,保存到单元格的数据也要设置为同一格式,否则最终导出的Excel数据达不到你想要的效果。

 

 

 

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值