XSSFWorkbook和HSSFWorkbook导出(亲测)

项目上这种功能很多,写了一个工具类,代码有点垃圾,大神勿喷

在这里插入图片描述

导入导出poi组件Excel

     
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>3.9</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>3.9</version>
        </dependency>
package com.tc.util;
import org.apache.poi.hssf.usermodel.*;
import org.apache.poi.ss.usermodel.Footer;
import org.apache.poi.ss.usermodel.Header;
import org.apache.poi.ss.util.CellRangeAddress;
import org.apache.poi.xssf.usermodel.*;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;

import javax.servlet.http.HttpServletResponse;
import java.io.OutputStream;
import java.lang.reflect.Field;
import java.net.URLEncoder;
import java.text.SimpleDateFormat;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * 导出工具类  <p>07导出不限制行数,03有66535局限性</p>
 *
 * @author Fyg_gm
 * @since 2021-05-12 21:01:20
 */
@Component
public class ExcelUtil {
    Logger logger = LoggerFactory.getLogger(ExcelUtil.class);

    /**
     * 07 无限制导出
     *
     * @param response
     * @param list     导出的数据
     * @param filename 导出文件名
     * @param title    导出表头
     */
    public void exportMultiToDownFile(HttpServletResponse response, List<?> list, String filename, String[] title) {
        Logger logger = LoggerFactory.getLogger(ExcelUtil.class);
        filename += new SimpleDateFormat("yyyy-MM-dd").format(System.currentTimeMillis());

        //创建工作薄
        XSSFWorkbook workbook = new XSSFWorkbook();
        //创建表单
        XSSFSheet sheet = genSheet(workbook, filename);
        //创建表单样式
        Map<String, XSSFCellStyle> tableStyle = createStyle(workbook);//创建表头样式
        Map<String, XSSFCellStyle> titleStyle = createStyle(workbook);//创建标题样式
        Map<String, XSSFCellStyle> contextStyle = createStyle(workbook);//创建正文样式

        //创建Excel
        genExcel(filename, list, title, sheet, tableStyle.get("cellStyle2"), titleStyle.get("cellStyle"), contextStyle.get("cellStyle3"));
        String suffix = ".xls";
        filename += suffix;
//            最终已流的形式返回
        OutputStream out = null;
        try {
            out = response.getOutputStream();
            response.setHeader("content-type", "application/octet-stream");
            response.setContentType("application/octet-stream");
            response.addHeader("Content-Disposition", "attachment; filename=" + URLEncoder.encode(filename, "UTF-8"));
            workbook.write(out);
            out.flush();
            out.close();
        } catch (Exception e) {
            e.printStackTrace();
            logger.info(e.getMessage());
        } finally {
            try {
                if (out != null) {
                    out.close();
                }
            } catch (Exception e) {
                e.printStackTrace();
                logger.info(e.getMessage());
            }
        }

    }

    /**
     * 03 限制导出行数66535 有局限性
     *
     * @param response
     * @param list     导出的数据
     * @param filename 导出的文件名
     * @param title    导出的表头
     */
    public void exportToDownFile(HttpServletResponse response, List<?> list, String filename, String[] title) {
        filename += new SimpleDateFormat("yyyy-MM-dd").format(System.currentTimeMillis());
        String suffix = ".xls";
        filename += suffix;
        //创建excel表
        HSSFWorkbook workbook = new HSSFWorkbook();
        //建立sheet对象
        HSSFSheet sheet = workbook.createSheet(filename);

        //设置默认行宽
        sheet.setDefaultColumnWidth(20);
        //创建样式
        Map<String, HSSFCellStyle> style = createStyle(workbook);

        //创建表头
        HSSFRow row = sheet.createRow(0);
        row.setHeightInPoints(20);//行高

        HSSFCell cell = row.createCell(0);
        cell.setCellValue(filename);
        cell.setCellStyle(style.get("cellStyle"));

        sheet.addMergedRegion(new CellRangeAddress(0, 0, 0, (title.length - 1)));

        //创建标题
        HSSFRow rowTitle = sheet.createRow(1);
        rowTitle.setHeightInPoints(20);

        HSSFCell hc;
        for (int i = 0; i < title.length; i++) {
            hc = rowTitle.createCell(i);
            hc.setCellValue(title[i]);
            //设置标题样式
            hc.setCellStyle(style.get("cellStyle2"));
        }
        //创建表格数据
        Field[] fields;
        int i = 2;
        int index = 0;//记录额外创建的sheet数量

        //数据源
        for (Object obj : list) {
            //反射获取到实体
            fields = obj.getClass().getDeclaredFields();
            HSSFRow rowBody = sheet.createRow(i);
            rowBody.setHeightInPoints(20);
            int j = 0;
            //遍历渲染表格
            for (Field f : fields) {
                f.setAccessible(true);
                Object va = null;
                try {
                    va = f.get(obj);
                } catch (IllegalAccessException e) {
                    e.printStackTrace();
                }
                if (null == va) {
                    va = "---";
                }
                //创建行数
                hc = rowBody.createCell(j);
                //赋值数据
                hc.setCellValue(va.toString());
                //设置表格样式
                hc.setCellStyle(style.get("cellStyle3"));

                j++;
            }

            i++;
        }
        //最终已流的形式返回
        OutputStream out = null;
        try {
            out = response.getOutputStream();
            response.setHeader("content-type", "application/octet-stream");
            response.setContentType("application/octet-stream");
            response.addHeader("Content-Disposition", "attachment; filename=" + URLEncoder.encode(filename, "UTF-8"));
            workbook.write(out);
            out.flush();
            out.close();
        } catch (Exception e) {
            e.printStackTrace();
            logger.info(e.getMessage());
        } finally {
            try {
                if (out != null) {
                    out.close();
                }
            } catch (Exception e) {
                e.printStackTrace();
                logger.info(e.getMessage());
            }
        }
    }

    //封装动态渲染excel
    public static void genExcel(String filename, List<?> list, String[] title, XSSFSheet sheet, XSSFCellStyle tableStyle, XSSFCellStyle titleStyle, XSSFCellStyle contextStyle) {
        //设置默认行宽
        sheet.setDefaultColumnWidth(20);
        //创建第一行,为标题,index从0开始
        XSSFRow row = sheet.createRow(0);
        row.setHeightInPoints(20);
        //创建一列
        XSSFCell cell = row.createCell(0);
        //标题
        cell.setCellValue(filename);
        //设置标题样式
        cell.setCellStyle(titleStyle);
        //设置标题位置
        sheet.addMergedRegion(new CellRangeAddress(
                0, //first row
                0, //last row
                0, //first column
                (title.length - 1) //last column
        ));

        //创建第二行  表头
        XSSFRow rowTitle = sheet.createRow(1);
        rowTitle.setHeightInPoints(20);
        XSSFCell xc;
        for (int i = 0; i < title.length; i++) {
            xc = rowTitle.createCell(i);
            xc.setCellValue(title[i]);
            //设置表头样式
            xc.setCellStyle(tableStyle);
        }
        //从数据库取数据填充到Excel,
        Field[] fields;
        //i从2开始计数,因为上面已经创建了 0 1行
        int i = 2;
        for (Object obj : list) {
            //反射获取到实体
            fields = obj.getClass().getDeclaredFields();
            //从第三行动态去创建
            XSSFRow rowBody = sheet.createRow(i);
            rowBody.setHeightInPoints(20);
            int j = 0;
            //遍历渲染表格
            for (Field f : fields) {
                f.setAccessible(true);
                Object va = null;
                try {
                    va = f.get(obj);
                } catch (IllegalAccessException e) {
                    e.printStackTrace();
                }
                if (null == va) {
                    va = "---";
                }
                //创建行数
                xc = rowBody.createCell(j);
                //赋值数据
                xc.setCellValue(va.toString());
                //设置表格样式
                xc.setCellStyle(contextStyle);

                j++;
            }
            i++;
        }
    }

    //设置表单,并生成表单
    public static XSSFSheet genSheet(XSSFWorkbook workbook, String sheetName) {
        //生成表单
        XSSFSheet sheet = workbook.createSheet(sheetName);
        //设置表单文本居中
        sheet.setHorizontallyCenter(true);
        sheet.setFitToPage(false);
        //打印时在底部右边显示文本页信息
        Footer footer = sheet.getFooter();
        footer.setRight("Page " + HeaderFooter.numPages() + " Of " + HeaderFooter.page());
        //打印时在头部右边显示Excel创建日期信息
        Header header = sheet.getHeader();
        header.setRight("Create Date " + HeaderFooter.date() + " " + HeaderFooter.time());
        //设置打印方式
        XSSFPrintSetup ps = sheet.getPrintSetup();
        ps.setLandscape(true); // true:横向打印,false:竖向打印 ,因为列数较多,推荐在打印时横向打印
        ps.setPaperSize(HSSFPrintSetup.A4_PAPERSIZE); //打印尺寸大小设置为A4纸大小
        return sheet;
    }

    //设置exportToDownFile样式
    public Map<String, HSSFCellStyle> createStyle(HSSFWorkbook workbook) {
        Map<String, HSSFCellStyle> map = new HashMap<>();
        //表头样式(加粗,水平居中,垂直居中)
        HSSFCellStyle cellStyle = workbook.createCellStyle();
        cellStyle.setAlignment(XSSFCellStyle.ALIGN_CENTER);//水平居中
//        cellStyle.setVerticalAlignment(VerticalAlignment.CENTER);//垂直居中
        //设置边框样式
        cellStyle.setBorderBottom(XSSFCellStyle.BORDER_THIN); //下边框
        cellStyle.setBorderLeft(XSSFCellStyle.BORDER_THIN);//左边框
        cellStyle.setBorderTop(XSSFCellStyle.BORDER_THIN);//上边框
        cellStyle.setBorderRight(XSSFCellStyle.BORDER_THIN);//右边框

        HSSFFont fontStyle = workbook.createFont();
        fontStyle.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);

        cellStyle.setFont(fontStyle);

        //标题样式(加粗,垂直居中)
        HSSFCellStyle cellStyle2 = workbook.createCellStyle();
//        cellStyle2.setVerticalAlignment(VerticalAlignment.CENTER);//垂直居中
        cellStyle2.setFont(fontStyle);

        //设置边框样式
        cellStyle2.setBorderBottom(XSSFCellStyle.BORDER_THIN); //下边框
        cellStyle2.setBorderLeft(XSSFCellStyle.BORDER_THIN);//左边框
        cellStyle2.setBorderTop(XSSFCellStyle.BORDER_THIN);//上边框
        cellStyle2.setBorderRight(XSSFCellStyle.BORDER_THIN);//右边框

        //字段样式(垂直居中)
        HSSFCellStyle cellStyle3 = workbook.createCellStyle();
        //设置边框样式
        cellStyle3.setBorderBottom(XSSFCellStyle.BORDER_THIN); //下边框
        cellStyle3.setBorderLeft(XSSFCellStyle.BORDER_THIN);//左边框
        cellStyle3.setBorderTop(XSSFCellStyle.BORDER_THIN);//上边框
        cellStyle3.setBorderRight(XSSFCellStyle.BORDER_THIN);//右边框
        map.put("cellStyle", cellStyle);
        map.put("cellStyle2", cellStyle2);
        map.put("cellStyle3", cellStyle3);
        return map;
    }

    //设置exportMultiToDownFile样式
    public Map<String, XSSFCellStyle> createStyle(XSSFWorkbook workbook) {
        Map<String, XSSFCellStyle> map = new HashMap<>();
        //表头样式(加粗,水平居中,垂直居中)
        XSSFCellStyle cellStyle = workbook.createCellStyle();
        cellStyle.setAlignment(XSSFCellStyle.ALIGN_CENTER);//水平居中
//        cellStyle.setVerticalAlignment(VerticalAlignment.CENTER);//垂直居中
        //设置边框样式
        cellStyle.setBorderBottom(XSSFCellStyle.BORDER_THIN); //下边框
        cellStyle.setBorderLeft(XSSFCellStyle.BORDER_THIN);//左边框
        cellStyle.setBorderTop(XSSFCellStyle.BORDER_THIN);//上边框
        cellStyle.setBorderRight(XSSFCellStyle.BORDER_THIN);//右边框

        XSSFFont fontStyle = workbook.createFont();
        fontStyle.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);

        cellStyle.setFont(fontStyle);

        //标题样式(加粗,垂直居中)
        XSSFCellStyle cellStyle2 = workbook.createCellStyle();
//        cellStyle2.setVerticalAlignment(VerticalAlignment.CENTER);//垂直居中
        cellStyle2.setFont(fontStyle);

        //设置边框样式
        cellStyle2.setBorderBottom(XSSFCellStyle.BORDER_THIN); //下边框
        cellStyle2.setBorderLeft(XSSFCellStyle.BORDER_THIN);//左边框
        cellStyle2.setBorderTop(XSSFCellStyle.BORDER_THIN);//上边框
        cellStyle2.setBorderRight(XSSFCellStyle.BORDER_THIN);//右边框

        //字段样式(垂直居中)
        XSSFCellStyle cellStyle3 = workbook.createCellStyle();
//        cellStyle3.setVerticalAlignment(VerticalAlignment.CENTER);//垂直居中

        //设置边框样式
        cellStyle3.setBorderBottom(XSSFCellStyle.BORDER_THIN); //下边框
        cellStyle3.setBorderLeft(XSSFCellStyle.BORDER_THIN);//左边框
        cellStyle3.setBorderTop(XSSFCellStyle.BORDER_THIN);//上边框
        cellStyle3.setBorderRight(XSSFCellStyle.BORDER_THIN);//右边框
        map.put("cellStyle", cellStyle);
        map.put("cellStyle2", cellStyle2);
        map.put("cellStyle3", cellStyle3);
        return map;
    }


}


posted @ 2024-09-27 09:53  Peak-Gao  阅读(65)  评论(0编辑  收藏  举报  来源