zoukankan      html  css  js  c++  java
  • 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内嵌格式列表大家可以看这个窗口中的自定义列表:



     这里就不一一列出了

    第三种:货币格式

                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

  • 相关阅读:
    python 学习常见问题笔记
    mac os 使用 from scipy.misc import imread ImportError: cannot import name 'imread'
    mac解决安装提示“xxx软件已损坏,打不开,您应该将它移到废纸篓”的提示
    一文搞懂HMM(隐马尔可夫模型)
    docker从容器里面拷文件到宿主机或从宿主机拷文件到docker容器里面
    centos 7 安装python3 & pip3
    HTK HResults计算字错率(WER)、句错率(SER)
    sublime text3安装ConvertToUTF8
    intellij idea 解决2019年4月到期延期问题
    Python 3 教程
  • 原文地址:https://www.cnblogs.com/ae6623/p/4416597.html
Copyright © 2011-2022 走看看