EasyExcel导出

1.简介

        官网:EasyExcel官方文档 - 基于Java的Excel处理工具 | Easy Excel

2.案例

2.1 实现的效果

        效果图如下:

2.2 实现步骤

        三种情景,主要是表头和数据有区别,简列实现步骤如下:

2.3 具体实现

2.3.1 前置-依赖导入

        <!-- easyExcel -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>3.3.2</version>
        </dependency>

        <!-- POI导入导出 -->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>4.1.2</version>
        </dependency>

        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>4.1.2</version>
        </dependency>

        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml-schemas</artifactId>
            <version>4.1.2</version>
        </dependency>

2.3.2 简单列表导出excel文件

        1.创建实体如下:
@Data
public class Order {

    /** 订单ID*/
    @ExcelProperty("订单ID")
    private String orderId;

    /** 总价*/
    @ExcelProperty("总价")
    private BigDecimal totalFee;

    /** 创建时间*/
    @ExcelProperty("创建时间")
    private Date createTime;

    /** 商品名称*/
    @ExcelProperty("商品名称")
    private String goodsName;

    /** 商品件数*/
    @ExcelProperty("商品件数")
    private int num;

}
        2.controller写导出方法,这个是最简单的导出
    @GetMapping("/exportSimpleExcel")
    public void exportSimpleExcel(HttpServletResponse response) throws Exception{
        // 设置response头信息-文件名使用当前时间
        setHeader(response);
        // 获取excel数据
        List<Order> data = generateOrders();
        // 导出数据
        exportExcel(response,data);
    }


    private void setHeader(HttpServletResponse response) {
        response.reset();
        response.setContentType("application/vnd.ms-excel");
        response.setHeader("Content-disposition", "attachment; filename=" + System.currentTimeMillis() + ".xls");
    }

    private List<Order> generateOrders() {
        ArrayList<Order> orders = new ArrayList<>(10);
        for (int i = 0; i < 10; i++) {
            Order order = new Order();
            order.setOrderId(System.nanoTime() + "");
            order.setGoodsName("商品" + i);
            order.setTotalFee(BigDecimal.ONE);
            order.setCreateTime(new Date());
            order.setNum(5);
            orders.add(order);
        }
        return orders;
    }

    private void exportExcel(HttpServletResponse response, List<Order> data) throws Exception{
        EasyExcel.write(response.getOutputStream(), Order.class).sheet("订单").doWrite(data);
    }

然后在浏览器输入我们的地址就下载下来了,实现效果就不再沾图了。

2.3.3 复杂列表导出

        1.controller代码如下:
    @GetMapping("/exportComplexHeadExcel")
    public void exportComplexHeadExcel(HttpServletResponse response) throws Exception{
        // 设置response头信息-文件名使用当前时间
        setHeader(response);
        // 获取excel数据
        List<Order> data = generateOrders();
        // 导出数据
        exportComplexHeadExcel(response,data);
    }


    private void exportComplexHeadExcel(HttpServletResponse response, List<Order> data) throws Exception{
        EasyExcel.write(response.getOutputStream()).sheet("订单").head(getHeadData()).doWrite(data);
    }

    private List<List<String>> getHeadData() {
        List<List<String>> heads = new ArrayList<>();
        // 第一层循环行数的循环
        for (int column = 0; column < 5; column++) {
            List<String> columnData = new ArrayList<>();
            heads.add(columnData);
            // 表头第一列数据
            if(column==0){
                addFirstColumnData(columnData);
                continue;
            }
            // 表头第二列数据
            if(column==1){
                addSecondColumnData(columnData);
                continue;
            }
            // 表头第三列数据
            if(column==2){
                addThreeColumnData(columnData);
                continue;
            }
            // 表头第四列数据
            if(column==3){
                addFourColumnData(columnData);
            }
            // 表头第五列数据
            if(column==4){
                addFivelumnData(columnData);
            }
        }
        return heads;
    }

    private void addFivelumnData(List<String> lineData) {
        for (int lineNum = 0; lineNum < 3; lineNum++) {
            if(lineNum == 0){
                lineData.add("订单信息汇总");
                continue;
            }
            if(lineNum == 1){
                lineData.add("2023年12月26");
                continue;
            }
            lineData.add("商品件数");
        }
    }

    private void addFourColumnData(List<String> lineData) {
        for (int lineNum = 0; lineNum < 3; lineNum++) {
            if(lineNum == 0){
                lineData.add("订单信息汇总");
                continue;
            }
            if(lineNum == 1){
                lineData.add("");
                continue;
            }
            if(lineNum == 2){
                lineData.add("商品名称");
            }
        }
    }

    private void addThreeColumnData(List<String> lineData) {
        for (int lineNum = 0; lineNum < 3; lineNum++) {
            if(lineNum == 0){
                lineData.add("订单信息汇总");
                continue;
            }
            if(lineNum == 1){
                lineData.add("");
                continue;
            }
            if(lineNum == 2){
                lineData.add("创建时间");
            }
        }
    }

    private void addSecondColumnData(List<String> lineData) {
        for (int lineNum = 0; lineNum < 3; lineNum++) {
            if(lineNum == 0){
                lineData.add("订单信息汇总");
                continue;
            }
            if(lineNum == 1){
                lineData.add("");
                continue;
            }
            if(lineNum == 2){
                lineData.add("总价");
            }
        }
    }

    private void addFirstColumnData(List<String> lineData) {
        for (int lineNum = 0; lineNum < 3; lineNum++) {
            if(lineNum == 0){
                lineData.add("订单信息汇总");
                continue;
            }
            if(lineNum == 1){
                lineData.add("荆州公司");
                continue;
            }
            if(lineNum == 2){
                lineData.add("订单ID");
            }
        }
    }

        2.表头分析

        代码可以通过,head需要传的数据是List<List<String>>数据结构的数据,这个外层的List是column,这个里边的是line数据。分清楚这个,那么其他的就和简单列表是一样的了。

2.3.4 含图片导出

        1.实体增加图片字段
@Data
public class Order {

    /** 订单ID*/
    @ExcelProperty("订单ID")
    private String orderId;

    /** 总价*/
    @ExcelProperty("总价")
    private BigDecimal totalFee;

    /** 创建时间*/
    @ExcelProperty("创建时间")
    private Date createTime;

    /** 商品名称*/
    @ExcelProperty("商品名称")
    private String goodsName;

    /** 商品件数*/
    @ExcelProperty("商品件数")
    private int num;

    /** 商品图片*/
    @ExcelProperty("商品图片")
    private File img;
}
        2.controller代码
    @GetMapping("/exportContailImgExcel")
    public void exportContailImgExcel(HttpServletResponse response) throws Exception{
        // 设置response头信息-文件名使用当前时间
        setHeader(response);
        // 获取excel数据
        List<Order> data = generateOrders();
        // 添加图片
        addImg(data);
        // 导出数据
        exportContailImgExcel(response,data);
    }

    private void setHeader(HttpServletResponse response) {
        response.reset();
        response.setContentType("application/vnd.ms-excel");
        response.setHeader("Content-disposition", "attachment; filename=" + System.currentTimeMillis() + ".xls");
    }

    private List<Order> generateOrders() {
        ArrayList<Order> orders = new ArrayList<>(10);
        for (int i = 0; i < 10; i++) {
            Order order = new Order();
            order.setOrderId(System.nanoTime() + "");
            order.setGoodsName("商品" + i);
            order.setTotalFee(BigDecimal.ONE);
            order.setCreateTime(new Date());
            order.setNum(5);
            orders.add(order);
        }
        return orders;
    }

    private void addImg(List<Order> data) throws Exception{
        for (int i = 0; i < data.size(); i++) {
            Order order = data.get(i);
            order.setImg(new File("D:\\img\\shanzi.png"));
        }
    }

    private void exportContailImgExcel(HttpServletResponse response, List<Order> data) throws Exception{
        EasyExcel.write(response.getOutputStream(), Order.class).sheet("订单").doWrite(data);
    }

本次导出使用了本地图片,官网还支持其他的方式,大家可以看看官网。

先分享到这,有问题欢迎提问。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/274957.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

双向链表基本操作及顺序和链表总结

目录 基本函数实现 链表声明 总的函数实现声明 创建一个节点 初始化链表 打印 尾插 尾删 头插 头删 查找 pos前插入 删除pos位置 销毁链表 顺序表和链表总结 基本函数实现 链表声明 typedef int DLTDataType;typedef struct DListNode {struct DListNode* nex…

小白必学!手把手教你从零打造Facebook脸书商城

Facebook 脸书商城已经逐渐成为了跨境电商开拓市场的选择&#xff0c;这是因为脸书商城背靠 Facebook 巨大的平台流量&#xff0c;可以链接卖家的品牌&#xff0c;增加品牌曝光率&#xff0c;提高流量&#xff0c;是一个非常好的流量洼地。如果你还没有注册脸书商城&#xff0c…

图像处理-周期噪声

周期噪声 对于具有周期性的噪声被称为周期噪声&#xff0c;其中周期噪声在频率域会出现关于中心对称的性质&#xff0c;如下图所示 带阻滤波器 为了消除周期性噪声&#xff0c;由此设计了几种常见的滤波器&#xff0c;其中 W W W表示带阻滤波器的带宽 理想带阻滤波器 H ( u …

【Fastadmin】通用排序weigh不执行model模型的事件

在model模型类支持的before_delete、after_delete、before_write、after_write、before_update、after_update、before_insert、after_insert事件行为中&#xff0c;我们可以快捷的做很多操作&#xff0c;如删除缓存、逻辑判断等 但是在fastadmin的通用排序weigh拖动中无法触发…

Flink项目实战篇 基于Flink的城市交通监控平台(上)

系列文章目录 Flink项目实战篇 基于Flink的城市交通监控平台&#xff08;上&#xff09; Flink项目实战篇 基于Flink的城市交通监控平台&#xff08;下&#xff09; 文章目录 系列文章目录1. 项目整体介绍1.1 项目架构1.2 项目数据流1.3 项目主要模块 2. 项目数据字典2.1 卡口…

Goby 漏洞发布| Apache OFBiz webtools/control/ProgramExport 远程代码执行漏洞(CVE-2023-51467)

漏洞名称&#xff1a;Apusic 应用服务器 createDataSource 远程代码执行漏洞 English Name&#xff1a;Apache OFBiz webtools/control/ProgramExport remote code execution vulnerability (CVE-2023-51467) CVSS core: 9.8 影响资产数&#xff1a; 5912 漏洞描述&#xf…

堡垒机的演变过程

堡垒机的概念源自跳板机&#xff08;前置机&#xff09;。早在20世纪90年代末21世纪初期&#xff0c;部分中大型企业为了能对运维人员的远程登录进行集中管理&#xff0c;会在机房部署一台跳板机。跳板机其实就是一台unix/windows操作系统的服务器。并且所有运维人员都需要先远…

如何使用甘特图进行项目管理?

或许你在工作中或项目启动会议上听说过“甘特图”一词&#xff0c;但对此了解不多。虽然这些图表可能变得相当复杂&#xff0c;但基础知识并不难掌握。通过本文&#xff0c;你将清楚地了解什么是甘特图、何时使用甘特图、创建甘特图的技巧等等。 什么是甘特图&#xff1f; 甘特…

HBase 例行灾备方案:快照备份与还原演练

博主历时三年精心创作的《大数据平台架构与原型实现&#xff1a;数据中台建设实战》一书现已由知名IT图书品牌电子工业出版社博文视点出版发行&#xff0c;点击《重磅推荐&#xff1a;建大数据平台太难了&#xff01;给我发个工程原型吧&#xff01;》了解图书详情&#xff0c;…

UDP协议工作原理及实战(二)UDP客户端代码实现

这个是一个测试我们写的函数是否正确。 启动服务&#xff1a;这里边的udpsocket->bind(port)就是对端口号进行连接。

【OpenAI Q* 超越人类的自主系统】DQN :Q-Learning + 深度神经网络

深度 Q 网络&#xff1a;用深度神经网络&#xff0c;来近似Q函数 强化学习介绍离散场景&#xff0c;使用行为价值方法连续场景&#xff0c;使用概率分布方法实时反馈连续场景&#xff1a;使用概率分布 行为价值方法 DQN&#xff08;深度 Q 网络&#xff09; 深度神经网络 Q-L…

【本地缓存篇】LFU、LRU 等缓存失效算法

LFU、LRU 等缓存失效算法 ✔️ 解析✔️FIFO✔️LRU✔️LFU✔️W-TinyLFU ✔️ 解析 缓存失效算法主要是进行缓存失效的&#xff0c;当缓存中的存储的对象过多时&#xff0c;需要通过一定的算法选择出需要被淘汰的对象&#xff0c;一个好的算法对缓存的命中率影响是巨大的。常见…

排列组合算法(升级版)

前言 在上一期博客中我们分享了一般的排列组合算法&#xff08;没看的话点这里哦~&#xff09;&#xff0c;但是缺点很明显&#xff0c;没法进行取模运算&#xff0c;而且计算的范围十分有限&#xff0c;而今天分享的排列组合升级版算法能够轻松解决这些问题&#xff0c;话不多…

Matlab:非线性规划

1、语法&#xff1a; xfmincon(fun,x0,A,b) xfmincon(fun,x0,A,b,Aeq,beq) xfmincon(fun,x0,A,b,Aeq,beq,lb,ub) xfmincon(fun,x0,A,b,Aeq,beq,lb,ub,nonlcon) xfmincon(fun,x0,A,b,Aeq,beq,lb,ub,nonlcon,options) xfmincon(problem) [x,fval]fmincon(___) [x,fval,exitflag,…

Leetcode—2660.保龄球游戏的获胜者【简单】

2023每日刷题&#xff08;七十二&#xff09; Leetcode—2660.保龄球游戏的获胜者 实现代码 class Solution { public:int isWinner(vector<int>& player1, vector<int>& player2) {long long sum1 0, sum2 0;int n player1.size();for(int i 0; i &…

跟小德学C++之参数处理

嗨&#xff0c;大家好&#xff0c;我是出生在达纳苏斯的一名德鲁伊&#xff0c;我是要立志成为海贼王&#xff0c;啊不&#xff0c;是立志成为科学家的德鲁伊。最近&#xff0c;我发现我们所处的世界是一个虚拟的世界&#xff0c;并由此开始&#xff0c;我展开了对我们这个世界…

go 使用 - sync.Metux

[TOC]&#xff08;sync.metux 使用&#xff09; 简介 简述使用metux使用的方法&#xff0c; 使用的注意点&#xff0c; 以及使用情况使用方法 提供的方法 Lock() 方法用于获取锁 Unlock() 方法用于释放锁 TryLock()方法尝试获取锁 对共享资源进行加锁&#xff0c; 例 &#…

1.3MySQL中的自连接

自己的表和自己连接&#xff0c;核心&#xff1a;一张表拆为两张一样的表。 语法&#xff1a;select 字段列表 from 表 [as] 表别名1,表 [as] 表别名2 where 条件...; 关于怎样把一个表拆分成一个表&#xff0c;只要给它们分别取别名就行 categoryidpidcategoryname21信息…

errors包返回堆栈信息的性能测试

errors包返回堆栈信息的性能测试 上一篇Golang中使用errors返回调用堆栈信息 讲了使用第三方开源库的errors github.com/go-errors/errors&#xff0c;错误信息带调用栈&#xff0c;方便定位错误的抛出位置。 通过堆栈的信息来定位是方便了&#xff0c;性能怎么样&#xff0c…

力扣:452. 用最少数量的箭引爆气球(贪心)

题目&#xff1a; 有一些球形气球贴在一堵用 XY 平面表示的墙面上。墙面上的气球记录在整数数组 points &#xff0c;其中points[i] [xstart, xend] 表示水平直径在 xstart 和 xend之间的气球。你不知道气球的确切 y 坐标。 一支弓箭可以沿着 x 轴从不同点 完全垂直 地射出。…