设定excel导出时单元格的格式

一、需求

要求excel导出时,对应列里面的内容格式为日期,数值格式并有精度要求 ,如下图:

使用alibaba,easyexcel,默认的导出数据格式为文本,excel显示为常规,使用数据规范注解@NumberFormat一直不生效,无奈选择原生的apache.poi。

二、具体实现

java 复制代码
   public void writePoi(List<Export> exportList) {
        // 1.在内存中创建一个excel文件,excel2003之前版本使用HSSFWorkbook,之后版本使用XSSFWorkbook
        HSSFWorkbook workbook = new HSSFWorkbook();
//        XSSFWorkbook workbook = new XSSFWorkbook();
        // 2.创建工作簿
        HSSFSheet sheet = workbook.createSheet("已开具发票");
        //设置列宽
        sheet.setDefaultColumnWidth(15);
        // 3.创建标题行

        HSSFRow titlerRow = sheet.createRow(0);

        titlerRow.createCell(0).setCellValue("开票日期");
        titlerRow.createCell(1).setCellValue("发票号码");
        titlerRow.createCell(2).setCellValue("购方税号");
        titlerRow.createCell(3).setCellValue("购方名称");
        titlerRow.createCell(4).setCellValue("规格型号");
        titlerRow.createCell(5).setCellValue("计量单位");
        titlerRow.createCell(6).setCellValue("单价");
        titlerRow.createCell(7).setCellValue("数量");
        titlerRow.createCell(8).setCellValue("金额");
        titlerRow.createCell(9).setCellValue("税额");
        
        //4.设置需要的格式
        DataFormat dataFormat = workbook.createDataFormat();
        CellStyle dateStyle = workbook.createCellStyle();
        dateStyle.setDataFormat(dataFormat.getFormat("yyyy-m-d;@")); // 设置日期格式,注意日期格式规范之后不会直接显示单元格式为日期,但是使用筛选功能时可以按照日期范围进行筛选。
        dateStyle.setAlignment(HorizontalAlignment.CENTER); // 设置水平居中

        CellStyle doubleStyle = workbook.createCellStyle();
        doubleStyle.setDataFormat(dataFormat.getFormat("0.00_ ")); // 设置数值格式
        doubleStyle.setAlignment(HorizontalAlignment.CENTER); // 设置水平居中

        CellStyle floatStyle = workbook.createCellStyle();
        floatStyle.setDataFormat(dataFormat.getFormat("0.00000000_ ")); // 设置单价格式
        floatStyle.setAlignment(HorizontalAlignment.CENTER); // 设置水平居中

        // 5.遍历数据,创建数据行
        for (Export export : exportList) {
            // 获取最后一行的行号
            int lastRowNum = sheet.getLastRowNum();
            // 添加新行
            HSSFRow dataRow = sheet.createRow(lastRowNum + 1);
            HSSFCell hssfCell0 = dataRow.createCell(0);
            hssfCell0.setCellStyle(dateStyle);
            hssfCell0.setCellValue(export.getKprq());
            dataRow.createCell(1).setCellValue(export.getFphm());
            dataRow.createCell(2).setCellValue(export.getGfsh());
            dataRow.createCell(3).setCellValue(export.getGfmc());
            dataRow.createCell(4).setCellValue(export.getGgxh());
            dataRow.createCell(5).setCellValue(export.getJldw());
            HSSFCell hssfCell6 = dataRow.createCell(6);
            hssfCell6.setCellStyle(floatStyle);
            hssfCell6.setCellValue(export.getDj());

            HSSFCell hssfCell7 = dataRow.createCell(7);
            hssfCell7.setCellStyle(doubleStyle);
            hssfCell7.setCellValue(export.getSl());

            HSSFCell hssfCell8 =dataRow.createCell(8);
            hssfCell8.setCellStyle(doubleStyle);
            hssfCell8.setCellValue(export.getJe());

            HSSFCell hssfCell9 =dataRow.createCell(9);
            hssfCell9.setCellStyle(doubleStyle);
            hssfCell9.setCellValue(export.getSe());
        }
        // 设置自适应列宽
        for (int i = 0; i < sheet.getRow(0).getLastCellNum(); i++) {
            sheet.autoSizeColumn(i);
        }
        // 5.创建文件名
        String fileName = "已开发票明细导出_" + new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()) + ".xls";
        // 6.获取输出流对象
        OutputStream outputStream;
        try {
            outputStream = new FileOutputStream(excelFilePath + "\\" + fileName);
        // 7.写出文件,关闭流
            workbook.write(outputStream);
            workbook.close();
            outputStream.close();
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();

        }
    }

注:数据规范所需的format规则可从excel中的格式设置看到,具体步骤为:

右键单击单元格,选择设置单元格格式,1选择你需要的格式,2设定好精度,

3直接点击自定义,即可看到format规范,注意数值格式的规范后面必须有一个空格,否则不生效,可以看到下图的下划线与光标之间是有一个空格的。

相关推荐
小c君tt29 分钟前
MFC中Excel的导入以及使用步骤
c++·excel·mfc
一名技术极客3 小时前
Vue2 doc、excel、pdf、ppt、txt、图片以及视频等在线预览
pdf·powerpoint·excel·文件在线预览
用余生去守护3 小时前
【反射率】-- Lab 转换(excel)
excel
进击的六角龙3 小时前
Python中处理Excel的基本概念(如工作簿、工作表等)
开发语言·python·excel
TracyDemo3 小时前
excel功能
excel
lc寒曦3 小时前
【VBA实战】用Excel制作排序算法动画
排序算法·excel·vba
zzzgd8163 小时前
easyexcel实现自定义的策略类, 最后追加错误提示列, 自适应列宽,自动合并重复单元格, 美化表头
java·excel·表格·easyexcel·导入导出
努力学习技能的LY3 小时前
Excel:vba实现批量插入图片批注
excel
图片转成excel表格5 小时前
wps怎么算出一行1和0两种数值中连续数值1的个数,出现0后不再计算?
excel·wps
q2498596935 小时前
前端预览word、excel、ppt
前端·word·excel