POI 单元格格式化 - 数据格式化
HSSFCellStyle cellPercentStyle = workbook.createCellStyle();
cellPercentStyle.setDataFormat((short)10);//百分数
一、第一种方式
//POI 自定义保留一位小数格式
HSSFCellStyle cellDigitStyle = workbook.createCellStyle();
cellDigitStyle.setDataFormat(workbook.createDataFormat().getFormat("0.0"));
// 也可以自定义成其它格式,5格式化成05
HSSFCellStyle cellDigitStyle = workbook.createCellStyle();
cellDigitStyle.setDataFormat(workbook.createDataFormat().getFormat("00"));
二、第二种方式
HSSFCellStyle cellDigitStyle2 = workbook.createCellStyle();
cellDigitStyle2.setDataFormat(HSSFDataFormat.getBuiltinFormat("0.00"));//两位小数
cellDigitStyle2.setDataFormat((short) 2); //作用同上
注:第二种不是自定义,如果 getBuiltinFormat 返回不了参数,格式化就会失效。
例如HSSFDataFormat.getBuiltinFormat("00")只会返回-1,这样格式化就会失效。
所以要实现Excel-> Format cell-> Custom,暂时只知道用第一种方式。
以下将要介绍的每一种都会用到这三行中的变量
HSSFWorkbook demoWorkBook = new HSSFWorkbook();
HSSFSheet demoSheet = demoWorkBook.createSheet("The World's 500 Enterprises");
HSSFCell cell = demoSheet.createRow(0).createCell(0);
第一种:日期格式
cell.setCellValue(new Date(2008,5,5));
//set date format
HSSFCellStyle cellStyle = demoWorkBook.createCellStyle();
HSSFDataFormat format= demoWorkBook.createDataFormat();
cellStyle.setDataFormat(format.getFormat("yyyy年m月d日"));
cell.setCellStyle(cellStyle);
第二种:保留两位小数格式
cell.setCellValue(1.2);
HSSFCellStyle cellStyle = demoWorkBook.createCellStyle();
cellStyle.setDataFormat(HSSFDataFormat.getBuiltinFormat("0.00"));
cell.setCellStyle(cellStyle);
这里与上面有所不同,用的是HSSFDataFormat.getBuiltinFormat()方法,之所以用这个,是因为0.00是Excel内嵌的格式,完整的Excel内嵌格式列表大家可以看这个窗口中的自定义列表:
这里就不一一列出了
第三种:货币格式
cell.setCellValue(20000);
HSSFCellStyle cellStyle = demoWorkBook.createCellStyle();
HSSFDataFormat format= demoWorkBook.createDataFormat();
cellStyle.setDataFormat(format.getFormat("¥#,##0"));
cell.setCellStyle(cellStyle);
第四种:百分比格式
cell.setCellValue(20);
HSSFCellStyle cellStyle = demoWorkBook.createCellStyle();
cellStyle.setDataFormat(HSSFDataFormat.getBuiltinFormat("0.00%"));
cell.setCellStyle(cellStyle);
此种情况跟第二种一样
第五种:中文大写格式
cell.setCellValue(20000);
HSSFCellStyle cellStyle = demoWorkBook.createCellStyle();
HSSFDataFormat format= demoWorkBook.createDataFormat();
cellStyle.setDataFormat(format.getFormat("[DbNum2][$-804]0"));
cell.setCellStyle(cellStyle);
第六种:科学计数法格式
cell.setCellValue(20000);
HSSFCellStyle cellStyle = demoWorkBook.createCellStyle();
cellStyle.setDataFormat( HSSFDataFormat.getBuiltinFormat("0.00E+00"));
cell.setCellStyle(cellStyle);
此种情况也与第二种情况一样
转自 http://yehuang-happy-163-com.iteye.com/blog/1326267