XSSFWorkbook和HSSFWorkbook导出(亲测)

简介: 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;
    }
}
目录
相关文章
|
7月前
|
人工智能 缓存 Linux
Confluence PDF导出中文支持
Confluence PDF导出中文支持
|
3月前
|
安全
SFX的妙用——如何在不安装软件的情况下打开自定义格式文件?
【8月更文挑战第31天】SFX(自解压文件)能在无需安装特定软件的情况下打开自定义格式文件。通过将所需程序与资源打包进 SFX 文件,用户可轻松解压并运行文件。此方法需确定所需程序、创建 SFX 文件并分发给用户,同时需注意合法性、兼容性和安全性问题,以确保文件正常且安全地运行。这为用户提供了便捷的解决方案。
116 7
|
1月前
|
存储 Java API
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
45 4
|
1月前
|
前端开发 API
前端界面生成PDF并导出下载
【10月更文挑战第21天】利用合适的第三方库,你可以在前端轻松实现界面生成 PDF 并导出下载的功能,为用户提供更方便的文档分享和保存方式。你还可以根据具体的需求进一步优化和定制生成的 PDF 文件,以满足不同的业务场景要求。
|
7月前
|
存储 程序员
Typora设置 “图片自动保存到文档对应目录下” 的方法(亲测有效)
Typora设置 “图片自动保存到文档对应目录下” 的方法(亲测有效)
vscode设置自动保存步骤
vscode设置自动保存就不用每次要运行时候去先保存一下才能加载新页面了
15283 0
vscode设置自动保存步骤
|
Linux 网络安全 数据安全/隐私保护
pycharm上传更新内容至linux服务器
pycharm上传更新内容至linux服务器
269 0
|
编解码 Python
Geany导入带有中文字符的.py文件然后执行报错解决办法
Geany导入带有中文字符的.py文件然后执行报错解决办法
210 0
Geany导入带有中文字符的.py文件然后执行报错解决办法
|
IDE 开发工具
phpstorm打开项目不能显示最近文件的解决方法
phpstorm打开项目不能显示最近文件的解决方法
218 0