SpringBoot 实现合并表头导出数据 - EasyExcel应用

简介: EasyExcel是一款开源的Java处理Excel文件的工具库,它提供了简单易用的API,可以方便地读取、写入和操作Excel文件。下面是一些常见的EasyExcel应用场景:读取Excel文件:使用EasyExcel可以轻松地读取Excel文件中的数据,并将其转换为Java对象或集合。你可以指定读取的起始行、列,还可以处理不同Sheet的数据。

EasyExcel是一款开源的Java处理Excel文件的工具库,它提供了简单易用的API,可以方便地读取、写入和操作Excel文件。下面是一些常见的EasyExcel应用场景:


读取Excel文件:使用EasyExcel可以轻松地读取Excel文件中的数据,并将其转换为Java对象或集合。你可以指定读取的起始行、列,还可以处理不同Sheet的数据。


写入Excel文件:EasyExcel允许将Java对象或集合写入到Excel文件中。你可以根据需要设置每列的标题、样式等属性,同时支持大数据量的写入操作。


复杂数据处理:EasyExcel提供了丰富的数据处理功能,例如筛选、排序、合并等操作,使得对Excel数据的处理更加便捷。


导入导出工具:借助EasyExcel,你可以快速构建复杂的导入导出工具,实现将数据从数据库或其他来源导入到Excel,或者将Excel中的数据导出到其他格式。


数据校验与转换:EasyExcel支持对读取的Excel数据进行校验和转换操作,包括基本的数据类型校验、日期格式转换、字典数据转换等,以确保数据的准确性和一致性。


模板导出:通过结合Excel模板和EasyExcel,你可以生成自定义格式的Excel报表。可以将模板文件中的占位符替换为具体数据,生成最终的Excel报表。


EasyExcel简单易用,并且在处理大量数据时性能较好。你可以查阅EasyExcel的官方文档或示例代码,了解更多关于其用法和功能的详细信息。



上一节我们实现了数据的导出,效果如下:

fa3f15e8b2bf462ea3de5cb2a044d01c.png


但是我们实际业务中往往数据比较复杂,还会出现合并表头的情况,So 这篇文章我们来实现合并表头。

1. 构建实体类

@Data
@NoArgsConstructor
@AllArgsConstructor
@Builder
public class User implements Serializable {
    @ExcelProperty(value = {"用户基本信息","用户名"},index = 0)
    private String userName;
    @ExcelProperty(value = {"用户基本信息","年龄"},index = 1)
    private Integer age;
    @ExcelProperty(value = {"用户基本信息","地址"} ,index = 2)
    private String address;
    @ExcelProperty(value = {"用户基本信息","生日"},index = 3)
    //注意:日期格式注解由alibaba.excel提供
//    @DateTimeFormat("yyyy-MM-dd HH:mm")
    private Date birthday;
}

2. 导出

public static void main(String[] args) {
  //组装数据
    ArrayList<User> users = new ArrayList<>();
    for (int i = 0; i < 10; i++) {
        User user = new User();
        user.setAddress("西安" + i);
        user.setUserName("张三" + i);
        user.setBirthday(new Date());
        user.setAge(10 + i);
        users.add(user);
    }
    //不做任何注解处理时,表头名称与实体类属性名称一致
    EasyExcel.write("D:\\用户.xlsx", User.class).sheet("用户信息").doWrite(users);
}


效果如下


d243295bf7ff400a818f7a3275a34662.png

3. 导入

/**
 * excel数据格式必须与实体类定义一致,否则数据读取不到
 */
@Test
public void readExcel(){
    ArrayList<User> users = new ArrayList<>();
    //读取数据
    EasyExcel.read("C:\\用户.xls", User.class, new AnalysisEventListener<User>() {
        @Override
        public void invoke(User o, AnalysisContext analysisContext) {
            System.out.println(o);
            users.add(o);
        }
        @Override
        public void doAfterAllAnalysed(AnalysisContext analysisContext) {
            System.out.println("完成。。。。");
        }
    }).sheet().doRead();
    System.out.println(users);
}

总结:


EasyExcel可以使用合并单元格的方式实现导出带有合并头的Excel文件。


在导出过程中,先写入每行的表头数据,然后再写入数据行。最后,通过CellRangeAddress定义一个合并单元格范围,将表头的相应单元格进行合并。


注意:上述示例代码仅供参考,实际使用时需要根据自己的需求进行适当修改。

相关文章
|
5天前
|
JSON Java 数据格式
Spring Boot返回Json数据及数据封装
在Spring Boot中,接口间及前后端的数据传输通常使用JSON格式。通过@RestController注解,可轻松实现Controller返回JSON数据。该注解是Spring Boot新增的组合注解,结合了@Controller和@ResponseBody的功能,默认将返回值转换为JSON格式。Spring Boot底层默认采用Jackson作为JSON解析框架,并通过spring-boot-starter-json依赖集成了相关库,包括jackson-databind、jackson-datatype-jdk8等常用模块,简化了开发者对依赖的手动管理。
29 3
|
4月前
|
JSON Java 数据格式
微服务——SpringBoot使用归纳——Spring Boot返回Json数据及数据封装——封装统一返回的数据结构
本文介绍了在Spring Boot中封装统一返回的数据结构的方法。通过定义一个泛型类`JsonResult&lt;T&gt;`,包含数据、状态码和提示信息三个属性,满足不同场景下的JSON返回需求。例如,无数据返回时可设置默认状态码&quot;0&quot;和消息&quot;操作成功!&quot;,有数据返回时也可自定义状态码和消息。同时,文章展示了如何在Controller中使用该结构,通过具体示例(如用户信息、列表和Map)说明其灵活性与便捷性。最后总结了Spring Boot中JSON数据返回的配置与实际项目中的应用技巧。
247 0
|
4月前
|
JSON Java fastjson
微服务——SpringBoot使用归纳——Spring Boot返回Json数据及数据封装——使用 fastJson 处理 null
本文介绍如何使用 fastJson 处理 null 值。与 Jackson 不同,fastJson 需要通过继承 `WebMvcConfigurationSupport` 类并覆盖 `configureMessageConverters` 方法来配置 null 值的处理方式。例如,可将 String 类型的 null 转为 &quot;&quot;,Number 类型的 null 转为 0,避免循环引用等。代码示例展示了具体实现步骤,包括引入相关依赖、设置序列化特性及解决中文乱码问题。
128 0
|
4月前
|
JSON Java fastjson
微服务——SpringBoot使用归纳——Spring Boot返回Json数据及数据封装——Spring Boot 默认对Json的处理
本文介绍了在Spring Boot中返回Json数据的方法及数据封装技巧。通过使用`@RestController`注解,可以轻松实现接口返回Json格式的数据,默认使用的Json解析框架是Jackson。文章详细讲解了如何处理不同数据类型(如类对象、List、Map)的Json转换,并提供了自定义配置以应对null值问题。此外,还对比了Jackson与阿里巴巴FastJson的特点,以及如何在项目中引入和配置FastJson,解决null值转换和中文乱码等问题。
360 0
|
6月前
|
前端开发 Java API
SpringBoot整合Flowable【06】- 查询历史数据
本文介绍了Flowable工作流引擎中历史数据的查询与管理。首先回顾了流程变量的应用场景及其局限性,引出表单在灵活定制流程中的重要性。接着详细讲解了如何通过Flowable的历史服务API查询用户的历史绩效数据,包括启动流程、执行任务和查询历史记录的具体步骤,并展示了如何将查询结果封装为更易理解的对象返回。最后总结了Flowable提供的丰富API及其灵活性,为后续学习驳回功能做了铺垫。
321 0
SpringBoot整合Flowable【06】- 查询历史数据
|
4月前
|
前端开发 Cloud Native Java
Java||Springboot读取本地目录的文件和文件结构,读取服务器文档目录数据供前端渲染的API实现
博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
Java||Springboot读取本地目录的文件和文件结构,读取服务器文档目录数据供前端渲染的API实现
|
5月前
|
Java 关系型数据库 MySQL
SpringBoot 通过集成 Flink CDC 来实时追踪 MySql 数据变动
通过详细的步骤和示例代码,您可以在 SpringBoot 项目中成功集成 Flink CDC,并实时追踪 MySQL 数据库的变动。
1146 43
|
easyexcel Java
SpringBoot集成EasyExcel的使用
SpringBoot集成EasyExcel的使用
1710 0
|
2月前
|
JavaScript 前端开发 Java
制造业ERP源码,工厂ERP管理系统,前端框架:Vue,后端框架:SpringBoot
这是一套基于SpringBoot+Vue技术栈开发的ERP企业管理系统,采用Java语言与vscode工具。系统涵盖采购/销售、出入库、生产、品质管理等功能,整合客户与供应商数据,支持在线协同和业务全流程管控。同时提供主数据管理、权限控制、工作流审批、报表自定义及打印、在线报表开发和自定义表单功能,助力企业实现高效自动化管理,并通过UniAPP实现移动端支持,满足多场景应用需求。
246 1
|
3月前
|
前端开发 Java 关系型数据库
基于Java+Springboot+Vue开发的鲜花商城管理系统源码+运行
基于Java+Springboot+Vue开发的鲜花商城管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的鲜花商城管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。技术学习共同进步
278 7