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

EasyExcel导出多个sheet封装

导出多个sheet

在需求中,会有需要导出多种sheet的情况,那么这里使用easyexcel进行整合

步骤

1、导入依赖
        <dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency><dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.1.1</version></dependency>
2、Sheet类

主要封装了需要导出的sheet,类,数据等

package com.eshore.easyexcel.entity;import lombok.Builder;
import lombok.Data;import java.util.List;@Data
public class SheetInfoBean<T> {/*** sheet页名称*/private String sheetName;/*** sheet标题bean*/private Class<?> headClass;/*** sheet页数据*/private List<T> dataList;public SheetInfoBean(String sheetName, Class<?> headClass, List<T> dataList) {this.sheetName = sheetName;this.headClass = headClass;this.dataList = dataList;}
}
3、导出方法
package com.eshore.easyexcel.utils;import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.ExcelWriter;
import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.write.metadata.WriteSheet;
import com.eshore.easyexcel.entity.SheetInfoBean;
import lombok.extern.slf4j.Slf4j;import java.io.File;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.List;@Slf4j
public class EasyExcelUtils {private final static String XLSX=".xlsx";/*** author:walker* time: 2024/6/4* description:  导出文件* prefix:前缀 如: D:/hello/* title:文件名称 如: test* @return*/public static String exportFile(List<SheetInfoBean> sheetInfoBeans,String prefix,String title){// 导出文件String path=prefix+title+XLSX;File dir = new File(prefix);if(!dir.exists()){dir.mkdirs();}File file = new File(path);try(ExcelWriter excelWriter = EasyExcel.write(file).build()) {WriteSheet writeSheet;List<String> exclueFields = new ArrayList<>();for (SheetInfoBean bean : sheetInfoBeans) {Class<?> headClass = bean.getHeadClass();Field[] declaredFields = headClass.getDeclaredFields();for (Field declaredField : declaredFields) {ExcelProperty annotation = declaredField.getAnnotation(ExcelProperty.class);if(annotation==null) {exclueFields.add(declaredField.getName());}}// 构建sheet对象writeSheet = EasyExcel.writerSheet(bean.getSheetName()).head(bean.getHeadClass()).excludeColumnFieldNames(exclueFields).build();// 写出sheet数据excelWriter.write(bean.getDataList(), writeSheet);}// 关流excelWriter.finish();} catch (Exception e) {log.error("导出失败,原因如下:",e);// do something you want}return path;}
}

注意:
里面做了一个处理,就是当没有@ExcelProperty的时候,该字段则不导出,否则需要对字段进行excludeColumnFieldNames的设置。相对来说麻烦一些

4、案例

需要使用@ExcelProperty对属性进行配置

1、学生类

package com.walker.sample.easyexcel;import com.alibaba.excel.annotation.ExcelProperty;
import lombok.Data;@Data
public class Student {@ExcelProperty("姓名")private String name;@ExcelProperty("年龄")private Integer age;
}

2、老师类

package com.walker.sample.easyexcel;import com.alibaba.excel.annotation.ExcelProperty;
import lombok.Data;@Data
public class Teacher {@ExcelProperty("姓名")private String name;@ExcelProperty("年龄")private Integer age;
}

3、测试方法

package com.walker.sample.easyexcel;import easyexcel.entity.SheetInfoBean;
import easyexcel.utils.EasyExcelUtils;
import lombok.extern.slf4j.Slf4j;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;import java.util.ArrayList;
import java.util.List;@Slf4j
@SpringBootTest
public class EasyExcelTest {@Testpublic void export(){List<Student> students = new ArrayList<>();for (int i = 0; i < 10; i++) {Student student = new Student();student.setName("学生"+i);student.setAge(i);students.add(student);}List<Teacher> teachers = new ArrayList<>();for (int i = 0; i < 10; i++) {Teacher teacher = new Teacher();teacher.setName("老师"+i);teacher.setAge(i);teachers.add(teacher);}List<SheetInfoBean> sheetInfoBeans = new ArrayList<>();sheetInfoBeans.add(new SheetInfoBean("学生",Student.class,students));sheetInfoBeans.add(new SheetInfoBean("老师",Teacher.class,teachers));String prefix="D:/";EasyExcelUtils.exportFile(sheetInfoBeans,prefix,"学生老师表");}
}

4、导出结果
image.png

http://www.lryc.cn/news/366717.html

相关文章:

  • 【Python错误】:AttributeError: ‘generator‘ object has no attribute ‘next‘解决办法
  • 如何配置Feign以实现服务调试
  • pc之间的相互通信详解
  • Mongodb中字段的删除
  • TP8 PHP 动态变量调用 (new $class())->$action($data)
  • 理解JVM内存模型与Java内存模型(JMM)
  • 鸿蒙OS初识
  • 发布自己的 npm 插件包:步骤与最佳实践
  • BubbleML: A Multiphase Multiphysics Dataset and Benchmarks for Machine Learning
  • vscode+latex设置跳转快捷键
  • PHP序列化、反序列化
  • websocket链接携带参数
  • 【C++进阶】深入STL之list:模拟实现深入理解List与迭代器
  • 技术管理之巅—如何从零打造高质效互联网技术团队阅读体验
  • 机器学习与数据挖掘知识点总结(一)
  • 行心科技中禄松波携手,开启智能健康新时代
  • 前端多人项目开发中,如何保证CSS样式不冲突?
  • 【YOLOv10改进[CONV]】使用DualConv二次创新C2f模块实现轻量化 + 含全部代码和详细修改方式 + 手撕结构图 + 全网首发
  • 基于SSM+Jsp的高校信息资源共享平台
  • 软件测试--Linux快速入门
  • module ‘django_cas_ng.views‘ has no attribute ‘login‘
  • CW32F030K8T7单片机在即热式热水器的应用介绍
  • HTML静态网页成品作业(HTML+CSS)—— 美食湘菜介绍网页(5个页面)
  • 使用redis构建简单的社交网站
  • 【Java面试】九、微服务篇-SpringCloud(上)
  • Python 树状数组
  • 【QEMU中文手册】2.2 调用方式(持续更新中)
  • (函数)判断一句话中最长的单词(C语言)
  • QT5.5.0中使用lambda表达式时遇到的问题
  • 【Go语言精进之路】构建高效Go程序:了解切片实现原理并高效使用