poi excel导出

先引入依赖

<!--       poi引用 -->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>4.0.1</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>4.0.1</version>
        </dependency>

工具类:

    /**
     * 导出excel文件
     *
     * @param title    表sheet的名字
     * @param headers  表头
     * @param dataList 正文单元格
     * @param out      输出流
     */
    private void exporteExcel(String title, String[] headers, List<Map> dataList, OutputStream out) {
        HSSFWorkbook workBook = new HSSFWorkbook();
        createSheet(title, headers, dataList, workBook);
        //这里可多次调用生成工作簿
//        createSheet(title + "2", headers, dataList, workBook);
        try {
            workBook.write(out);
        } catch (IOException e) {
            System.out.println("写入文件失败" + e.getMessage());
        }
    }

    /**
     * 创建sheet
     *
     * @param title    sheet的名字
     * @param headers  表头
     * @param dataList 正文单元格
     */
    private void createSheet(String title, String[] headers, List<Map> dataList, HSSFWorkbook workBook) {

        HSSFSheet sheet = workBook.createSheet(title);
        /**
         *合并单元格,注意要在创建行之前合并,起始单元格不能小于结束单元格
         * 参数1: 起始单元格的行数
         * 参数2:结束单元格的行数
         * 参数3: 起始单元格的列
         * 参数4: 结束单元格的列
         * */
        // sheet .addMergedRegion(new CellRangeAddress(0, 0, 0, 2));

        sheet.setDefaultColumnWidth(15);
        //设置表头和普通单元格的格式
        HSSFCellStyle headStyle = setHeaderStyle(workBook);
        HSSFCellStyle bodyStyle = setBodyStyle(workBook);

        createHeader(headers, sheet, headStyle);
        createBody(dataList, sheet, bodyStyle, headers);
    }

    /**
     * 设置表头格式
     *
     * @param workBook
     * @return
     */
    private HSSFCellStyle setHeaderStyle(HSSFWorkbook workBook) {
        HSSFCellStyle style = workBook.createCellStyle();
        //设置背景颜色
//        style.setFillForegroundColor(IndexedColors.GREY_25_PERCENT.getIndex());
//        style.setFillPattern(FillPatternType.SOLID_FOREGROUND);
//        边框颜色和宽度设置
        style.setBorderBottom(BorderStyle.THIN);
        style.setBottomBorderColor(IndexedColors.BLACK.getIndex()); // 下边框
        style.setBorderLeft(BorderStyle.THIN);
        style.setLeftBorderColor(IndexedColors.BLACK.getIndex()); // 左边框
        style.setBorderRight(BorderStyle.THIN);
        style.setRightBorderColor(IndexedColors.BLACK.getIndex()); // 右边框
        style.setBorderTop(BorderStyle.THIN);
        style.setTopBorderColor(IndexedColors.BLACK.getIndex()); // 上边框
//        对齐方式设置
        style.setAlignment(HorizontalAlignment.CENTER);
//        粗体字设置
        Font font = workBook.createFont();
        font.setBold(true);
//        font.setFontName("微软雅黑");
        style.setFont(font);
        return style;
    }

    /**
     * 设置正文单元格格式
     *
     * @param workBook
     * @return
     */
    private HSSFCellStyle setBodyStyle(HSSFWorkbook workBook) {
        HSSFCellStyle style = workBook.createCellStyle();
        //设置背景颜色
//        style.setFillForegroundColor(IndexedColors.GREY_25_PERCENT.getIndex());
//        style.setFillPattern(FillPatternType.SOLID_FOREGROUND);
        //边框颜色和宽度设置
        style.setBorderBottom(BorderStyle.THIN);
        style.setBottomBorderColor(IndexedColors.BLACK.getIndex()); // 下边框
        style.setBorderLeft(BorderStyle.THIN);
        style.setLeftBorderColor(IndexedColors.BLACK.getIndex()); // 左边框
        style.setBorderRight(BorderStyle.THIN);
        style.setRightBorderColor(IndexedColors.BLACK.getIndex()); // 右边框
        style.setBorderTop(BorderStyle.THIN);
        style.setTopBorderColor(IndexedColors.BLACK.getIndex()); // 上边框
        //对齐方式设置
        style.setAlignment(HorizontalAlignment.CENTER);
//        粗体字设置
//        Font font = workBook.createFont();
//        font.setFontName("微软雅黑");
//        style.setFont(font);
        style.setAlignment(HorizontalAlignment.CENTER);//行居中
//        style.setVerticalAlignment(VerticalAlignment.CENTER);//垂直居中
        return style;
    }

    /**
     * 创建表头
     *
     * @param headers   表头
     * @param sheet     表
     * @param headStyle 表头格式
     */
    private void createHeader(String[] headers, HSSFSheet sheet, HSSFCellStyle headStyle) {
        HSSFRow row = sheet.createRow(0);
        for (int i = 0; i < headers.length; i++) {
            HSSFCell cell = row.createCell(i);
            cell.setCellStyle(headStyle);
            HSSFRichTextString textString = new HSSFRichTextString(headers[i]);
            cell.setCellValue(textString);
            //只能解决英文、数字列宽自适应,如果该列为中文,会出现列宽不足现象。
            sheet.autoSizeColumn((short) i);
            // 解决自动设置列宽中文失效的问题
            sheet.setColumnWidth(i, sheet.getColumnWidth(i) * 17 / 10);


        }
    }


    /**
     * 创建正文单元格
     *
     * @param dataList  数据数组
     * @param sheet     表
     * @param bodyStyle 单元格格式
     * @param headers   表头
     */
    private void createBody(List<Map> dataList, HSSFSheet sheet, HSSFCellStyle bodyStyle, String[] headers) {
        //当前行
        int sheetRow = 1;
        for (int a = 0; a < dataList.size(); a++) {
            Map map = dataList.get(a);
            HSSFRow row = sheet.createRow(sheetRow);
            for (int j = 0; j < headers.length; j++) {
                HSSFCell cell = row.createCell(j);
                HSSFRichTextString textString = null;
                String val=null;
                if (map.get(headers[j]) != null) {
                    val = map.get(headers[j]).toString();
                    textString= new HSSFRichTextString(val);
                    //给单元格赋值颜色和值
                    cell.setCellStyle(bodyStyle);
                    cell.setCellValue(textString);
                } else {
                    cell.setCellValue(textString);
                }


            }
            sheetRow++;
        }
    }



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值