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

时间:2024-10-21 13:29:49

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

 

二、关键代码:

(1)设置为数值

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

        ( (value));    
        (hssfCellStyleDouble);

(2)设置为日期
        HSSFCellStyle hssfCellStyleDate = ();
        (("yyyy-MM-dd"));//
        SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");

        ((value));
        (hssfCellStyleDate);

三、效果

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

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

四、总结

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