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);
三、效果
在图1中可以看到,单元格没有绿色三角形,元数据是整数则显示整数,是小数则保留一位小数,可直接统计。
在图2中可以看到,单元格显示的虽然是yyyy-mm-dd格式,但是在Excel中识别为yyyy/mm/dd格式,这是Excel日期格式默认识别的一种,所以在图3中可以看到可以直接利用EXCEL的自动筛选功能按月、季度和年度进行选择了。
四、总结
单元格除了要设置格式外,保存到单元格的数据也要设置为同一格式,否则最终导出的Excel数据达不到你想要的效果。