POI 单元格格式化 - 数据格式化

简介: HSSFCellStyle cellPercentStyle = workbook.createCellStyle();       cellPercentStyle.setDataFormat((short)10);//百分数        一、第一种方式    //POI...

  1. HSSFCellStyle cellPercentStyle = workbook.createCellStyle();      

  2. cellPercentStyle.setDataFormat((short)10);//百分数    

  3.   

  4. 一、第一种方式   

  5. //POI 自定义保留一位小数格式   

  6. HSSFCellStyle cellDigitStyle = workbook.createCellStyle();   

  7. cellDigitStyle.setDataFormat(workbook.createDataFormat().getFormat("0.0"));   

  8.   

  9. // 也可以自定义成其它格式,5格式化成05   

  10. HSSFCellStyle cellDigitStyle = workbook.createCellStyle();   

  11. cellDigitStyle.setDataFormat(workbook.createDataFormat().getFormat("00"));   

  12.   

  13.   

  14. 二、第二种方式   

  15. HSSFCellStyle cellDigitStyle2 = workbook.createCellStyle();      

  16. cellDigitStyle2.setDataFormat(HSSFDataFormat.getBuiltinFormat("0.00"));//两位小数   

  17. cellDigitStyle2.setDataFormat((short) 2);                              //作用同上   

  18.   

  19. 注:第二种不是自定义,如果 getBuiltinFormat 返回不了参数,格式化就会失效。   

  20. 例如HSSFDataFormat.getBuiltinFormat("00")只会返回-1,这样格式化就会失效。   

  21. 所以要实现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内嵌格式列表大家可以看这个窗口中的自定义列表:


img_623ebefb53cf1578eb54ee3fe89c9c22.jpg
 这里就不一一列出了

 

第三种:货币格式

 

            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

目录
相关文章
|
Java API Android开发
【POI框架实战】——POI设置Excel单元格格式
 “这个excel中的数据怎么不能做加法啊?”、“标头这一行的字体怎么这么小啊,我都看不清”、“这一列能不能换个颜色,明显一些”、“你把这一列的数据给我留两个小数位。”、“这些数据能不能以货币的类型展示啊,就每个三位一个小逗号那种……”
【POI框架实战】——POI设置Excel单元格格式
|
4月前
|
数据库
在Excel中将某一列的格式通过数据分列彻底变为文本格式
在Excel中将某一列的格式通过数据分列彻底变为文本格式
60 0
|
7天前
|
存储 API C#
C# 实现格式化文本导入到Excel
C# 实现格式化文本导入到Excel
|
5月前
POI(excel)中表格(单元格)样式应用实践总结
POI(excel)中表格(单元格)样式应用实践总结
41 0
|
8月前
POI入门操作Excel单元格
POI入门操作Excel单元格
105 0
poi 生成word 表格,并向表格单元格中插入多个图片
poi 生成word 表格,并向表格单元格中插入多个图片
316 0
poi 生成word 表格,并向表格单元格中插入多个图片
将excel文件中的内容转换成word文本(去表格)
将excel文件中的内容转换成word文本(去表格)
385 0
将excel文件中的内容转换成word文本(去表格)
|
Android开发
安卓中显示表格并将表格数据以excel格式导出
安卓中显示表格并将表格数据以excel格式导出
371 0