【开发实践】使用POI实现导出带有复杂表头的的excel文件

news/2024/7/10 0:54:39 标签: vue, java, excel, spring boot, sql

一、需求分析

公司业务部门需要,根据一些数据,加上表头,导出需要的excel表格。效果如下:

 二、代码实现

【依赖准备】

        <!-- POI -->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>3.16</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>3.16</version>
        </dependency>

对于excel样式,笔者的做法是,读取设置好的xlsx模板样式,设置导出表格的样式。

poi导出的各类样式设置

笔者的样式设置:

java">    public static void setPrintSetupInfoMargin(Sheet templeteSheet, Sheet outputSheet, String type) {
        PrintSetup psTemplete = templeteSheet.getPrintSetup();
        PrintSetup psOutput = outputSheet.getPrintSetup();

        //页眉边距设置
        psOutput.setHeaderMargin(psTemplete.getHeaderMargin());
        psOutput.setFooterMargin(psTemplete.getFooterMargin());
        //设置宽、高页数以适合纸张
        psOutput.setFitWidth(psTemplete.getFitWidth());
        psOutput.setFitHeight(psTemplete.getFitHeight());
        //设置纸张尺寸
        psOutput.setPaperSize(psTemplete.getPaperSize());
        //设置页码开始
        psOutput.setPageStart(psTemplete.getPageStart());
        //设置是否横向打印
        psOutput.setLandscape(psTemplete.getLandscape());
        //设置是按顺序从左到右还是自上而下
        psOutput.setLeftToRight(psTemplete.getLeftToRight());
        //设置是否处于草稿模式
        psOutput.setDraft(psTemplete.getDraft());
        //设置比例
        psOutput.setScale(psTemplete.getScale());
        //页边距设置
        psOutput.setHeaderMargin(psTemplete.getHeaderMargin());
        psOutput.setFooterMargin(psTemplete.getFooterMargin());
        if (".xls".equals(type)) {
            psOutput.setScale((short) (psTemplete.getScale()+5));
            outputSheet.setMargin(HSSFSheet.TopMargin, templeteSheet.getMargin(SXSSFSheet.TopMargin));
            outputSheet.setMargin(HSSFSheet.BottomMargin, templeteSheet.getMargin(SXSSFSheet.BottomMargin));
            outputSheet.setMargin(HSSFSheet.RightMargin, templeteSheet.getMargin(SXSSFSheet.RightMargin));
            outputSheet.setMargin(HSSFSheet.LeftMargin, templeteSheet.getMargin(SXSSFSheet.LeftMargin));
        }else {
            outputSheet.setMargin(SXSSFSheet.TopMargin, templeteSheet.getMargin(SXSSFSheet.TopMargin));
            outputSheet.setMargin(SXSSFSheet.BottomMargin, templeteSheet.getMargin(SXSSFSheet.BottomMargin));
            outputSheet.setMargin(SXSSFSheet.RightMargin, templeteSheet.getMargin(SXSSFSheet.RightMargin));
            outputSheet.setMargin(SXSSFSheet.LeftMargin, templeteSheet.getMargin(SXSSFSheet.LeftMargin));
        }

        //页面打印选项设置(根据模板的选择来设置)
        outputSheet.setFitToPage(templeteSheet.getFitToPage());
        //页脚设置
        Footer psTempletefooter = templeteSheet.getFooter();
        Footer psOutputfooter = outputSheet.getFooter();
        psOutputfooter.setCenter(psTempletefooter.getCenter());
        //页眉设置省略。。。

        //设置标题(实现打印时每一页都有同个头部标题)
        outputSheet.setRepeatingRows(templeteSheet.getRepeatingRows());
        outputSheet.setRepeatingColumns(templeteSheet.getRepeatingColumns());

    }

 根据模板设置长宽:

java">//设置行宽度、行高度
for (int i = 0; i < items.get(0).length + 3; i++) {
    sheet.setColumnWidth(i, tempSheet.getColumnWidth(i));
}

设置表头样式:

java">//设置合并区域
sheet.addMergedRegion(new CellRangeAddress(startLine + 2, startLine + 3, itemLists.length - 1, itemLists.length - 1));

效果图片:

手动控制分页的情况:

java">//设置分页符
sheet.setRowBreak(currNowCow - 1);

效果如下: 


项目涉密,不能贴完整代码,谢谢理解哈! 


http://www.niftyadmin.cn/n/5224186.html

相关文章

postgreSQL 查询所有模式的语句

场景 postgre 数据库下携带模式的分组 sql select schema_name from information_schema.schemata;

git分支拉取时,提示冲突

stderr: error: unable to resolve reference refs/remotes/origin/xx/20231129: ??? 来自http://192.168.0.xx:6452/xxx-xx/xx-xx ! [新分支] hotfix/20231129 -> origin/xxx/20231129 &#xff08;不能更新本地引用&#xff09; error: 一些本地引用不能被更新&#xf…

ERRO报错

无法下载nginx 如下解决&#xff1a; 查看是否有epel 源 安装epel源 安装第三方 yum -y install epel-release.noarch NGINX端口被占用 解决&#xff1a; 编译安装的NGINX配置文件在/usr/local/ngin/conf 修改端口

如何使用 Python(NumPy 和 OpenCV)对图像进行 Funkify

如何使用 Python&#xff08;NumPy 和 OpenCV&#xff09;对图像进行 Funkify 作者|Luke Tambakis 编译|Flin 来源|medium 在这篇博客中&#xff0c;我将解释如何制作一个 Python 脚本来使用 Python 代码“funkify”图像。该程序速度足够快&#xff0c;甚至可以处理实时视频&am…

Python入门学习篇(四)——if详解

if详解 1 单项分支 1.1 语法结构 if 条件:逻辑代码(条件为真时执行的代码) # 注: 如果条件不满足,那么则不执行if下面的逻辑代码1.2 示例代码 username input("请输入您的用户名: ") if username "admin":print("管理员登录成功")1.3 运行…

RF Power Generator射频源维修射频匹配器维修

RF MATCH射频匹配器维修范围有ADVANCED射频电源匹配器&#xff1b;ASTEX射频电源匹配器&#xff1b;NP射频电源匹配器&#xff1b;ASTECH射频电源匹配器&#xff1b;SEREN射频电源匹配器&#xff1b;射频电源匹配器&#xff1b;KYOSAN射频电源匹配器&#xff1b;ENI射频电源匹配…

word2vec的算法原理(不用开源包,python实现)

看了很多关于word2vec的算法原理的介绍文章&#xff0c;看明白了&#xff0c;但依然有点不深刻。 以下是python直接实现的word2vec的算法&#xff0c;简单明了&#xff0c;读完就懂了 import numpy as npdef tokenize(text):return text.lower().split()def generate_word_pa…

Pytorch Lightning 完全攻略

Pytorch-Lightning这个库我“发现”过两次。第一次发现时&#xff0c;感觉它很重很难学&#xff0c;而且似乎自己也用不上。但是后面随着做的项目开始出现了一些稍微高阶的要求&#xff0c;我发现我总是不断地在相似工程代码上花费大量时间&#xff0c;Debug也是这些代码花的时…