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

一、需求:开发过程中,程序导出的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);

三、效果

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

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

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

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

四、总结

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