当前位置: 首页 > article >正文

SpringBoot中利用EasyExcel+aop实现一个通用Excel导出功能

一、结果展示

主要功能:可以根据前端传递的参数,导出指定列、指定行

1.1 案例一

  1. 前端页面
    在这里插入图片描述
  2. 传递参数
{
    "excelName": "导出用户信息1725738666946",
    "sheetName": "导出用户信息",
    "fieldList": [
        {
            "fieldName": "userId",
            "fieldDesc": "用户id"
        },
        {
            "fieldName": "age",
            "fieldDesc": "年龄"
        },
        {
            "fieldName": "address",
            "fieldDesc": "地址"
        }
    ]
}
  1. 导出的文件
    在这里插入图片描述

1.2 案例二

  1. 前端页面
    在这里插入图片描述

  2. 传递参数

{
    "excelName": "导出用户信息1725739080367",
    "sheetName": "导出用户信息",
    "fieldList": [
        {
            "fieldName": "userId",
            "fieldDesc": "用户id"
        },
        {
            "fieldName": "address",
            "fieldDesc": "地址"
        },
        {
            "fieldName": "age",
            "fieldDesc": "年龄"
        },
        {
            "fieldName": "userName",
            "fieldDesc": "用户名"
        }
    ],
    "userIdList": [
        "1",
        "3",
        "5",
        "8",
        "9"
    ]
}
  1. 导出结果
    在这里插入图片描述

二、代码实现

工具类代码结构
在这里插入图片描述

2.1 入参、出参

在这里插入图片描述
UserExportRequest

public class UserExportRequest extends ExcelExportRequest {
    /**
     * 要导出的用户id列表,不传,则导出所有用户记录
     */
    private List<Integer> userIdList;

    public List<Integer> getUserIdList() {...}
    public void setUserIdList(List<Integer> userIdList) {...}
}

---继承自通用的ExcelExportRequest---
public class ExcelExportRequest {
    /**
     * excel名称
     */
    private String excelName;

    /**
     * sheet的名称
     */
    private String sheetName;

    /**
     * 导出字段有序列表
     */
    private List<ExcelExportField> fieldList;

    public String getSheetName() {...}
    public void setSheetName(String sheetName) {...}
    public String getExcelName() {...}
    public void setExcelName(String excelName) {...}
    public List<ExcelExportField> getFieldList() {...}
    public void setFieldList(List<ExcelExportField> fieldList) {...}
}

ExcelExportResponse

public class ExcelExportResponse {
    //导出的excel文件名称
    private String excelName;
    // sheet列表数据
    private List<ExcelSheet> sheetList;

    public String getExcelName() {...}
    public void setExcelName(String excelName) {...}
    public List<ExcelSheet> getSheetList() {...}
    public void setSheetList(List<ExcelSheet> sheetList) {...}
}

2.2 生成ExcelExportResponse的逻辑

在这里插入图片描述

2.3 aop通知

在这里插入图片描述

2.4 下载Excel

在这里插入图片描述


http://www.kler.cn/a/299970.html

相关文章:

  • Dify:低代码 AI 应用开发平台详解与实战指南
  • 使用printmap()函数来打印地图
  • 随机变量的变量替换——归一化流和直方图规定化的数学基础
  • IPhone16 Pro 设备详情
  • vector的使用,以及部分功能的模拟实现(C++)
  • NewStar CTF week1 web wp
  • Mysql 数据库免费使用
  • windows七个消息队列
  • 基于springboot的校园志愿者管理系统的设计与实现 (含源码+sql+视频导入教程+论文+PPT)
  • 数学基础 -- 线性代数之格拉姆-施密特正交化
  • DNAT和SNAT实践
  • 软件测试之单元测试与unittest框架详解
  • Unity SRP 可编程渲染管线的基本用法
  • 虚幻引擎Gameplay探索 Actor 之间的高效通信与交互技巧二
  • 在springboot中如何使用Jetty替换Tomcat
  • LVGL 部件之滚轮(lv_roller)
  • MySQL的优化原则
  • 使用Selenium WebDriver来检测网页上的坏链接
  • PHP无缝对接预订无忧场馆预订系统小程序源码
  • SDH信号的帧结构与复用
  • ChatGPT提示词优化大师使用指南
  • 【网络安全】-文件下载漏洞-pikachu
  • 常用的 CMD 指令及其功能
  • 2024软件测试面试题及答案
  • 每日一练8:dd爱框框(含链接)
  • 【网络安全】-文件上传漏洞实战-upload-labs(0~16)