EasyExcel

2.1 数据导入导出意义

后台管理系统是管理、处理企业业务数据的重要工具,在这样的系统中,数据的导入和导出功能是非常重要的,其主要意义包括以下几个方面:

1、提高数据操作效率:手动逐条添加或修改数据不仅费时费力,而且容易出错,此时就可以将大量数据从Excel等表格软件中导入到系统中时,通过数据导入功能,可以直接将表格中的数据批量导入到系统中,提高了数据操作的效率。

2、实现数据备份与迁移:通过数据导出功能,管理员可以将系统中的数据导出为 Excel 或其他格式的文件,以实现数据备份,避免数据丢失。同时,也可以将导出的数据文件用于数据迁移或其他用途。

3、方便企业内部协作:不同部门可能会使用不同的系统或工具进行数据处理,在这种情况下,通过数据导入和导出功能,可以方便地转换和共享数据,促进企业内部协作。

2.2 EasyExcel简介

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

EasyExcel 的主要特点如下:

1、高性能:EasyExcel 采用了异步导入导出的方式,并且底层使用 NIO 技术实现,使得其在导入导出大数据量时的性能非常高效。

2、易于使用:EasyExcel 提供了简单易用的 API,用户可以通过少量的代码即可实现复杂的 Excel 导入导出操作。

3、增强的功能“EasyExcel 支持多种格式的 Excel 文件导入导出,同时还提供了诸如合并单元格、数据校验、自定义样式等增强的功能。

4、可扩展性好:EasyExcel 具有良好的扩展性,用户可以通过自定义 Converter 对自定义类型进行转换,或者通过继承 EasyExcelListener 来自定义监听器实现更加灵活的需求。

2.3 入门案例

2.3.1 读取Excel数据

需求:对资料中的excel数据进行解析,将其存储到对应的List集合中,并遍历List集合

步骤:

1、在spzx-model的pom.xml文件中添加如下依赖:

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>easyexcel</artifactId>
    <version>3.1.0</version>
</dependency>

2、定义一个实体类来封装每一行的数据,如下所示:

// com.atguigu.spzx.model.vo.product
@Data
public class CategoryExcelVo {
​
    @ExcelProperty(value = "id" ,index = 0)
    private Long id;
​
    @ExcelProperty(value = "名称" ,index = 1)
    private String name;
​
    @ExcelProperty(value = "图片url" ,index = 2)
    private String imageUrl ;
​
    @ExcelProperty(value = "上级id" ,index = 3)
    private Long parentId;
​
    @ExcelProperty(value = "状态" ,index = 4)
    private Integer status;
​
    @ExcelProperty(value = "排序" ,index = 5)
    private Integer orderNum;
}

3、定义一个监听器,监听解析到的数据,如下所示:

public class ExcelListener<T> extends AnalysisEventListener<T> {
    
    //可以通过实例获取该值
    private List<T> datas = new ArrayList<>();
​
    @Override
    public void invoke(T o, AnalysisContext analysisContext) {  // 每解析一行数据就会调用一次该方法
        datas.add(o);//数据存储到list,供批量处理,或后续自己业务逻辑处理。
    }
​
    public List<T> getDatas() {
        return datas;
    }
​
    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
        // excel解析完毕以后需要执行的代码
    }
    
}

4、编写测试方法

public class EasyExcelTest {
​
    public static void main(String[] args) {
        readDateToExcel();
    }
​
    //读取方法
    public static void readDateToExcel() {
        String fileName = "D://分类数据.xlsx" ;
        // 创建一个监听器对象
        ExcelListener<CategoryExcelVo> excelListener = new ExcelListener<>();  
        EasyExcel.read(fileName, CategoryExcelVo.class, excelListener).sheet().doRead();         // 解析excel表格
        List<CategoryExcelVo> excelVoList = excelListener.getDatas();    //获取解析到的数据
        excelVoList.forEach(s -> System.out.println(s) );   // 进行遍历操作
    }
}

2.3.2 添加数据到Excel

需求:将如下的集合数据存储到Excel中文件中

List<CategoryExcelVo> list = new ArrayList<>() ;
list.add(new CategoryExcelVo(1L , "数码办公" , "",0L, 1, 1)) ;
list.add(new CategoryExcelVo(11L , "华为手机" , "",1L, 1, 2)) ;

代码实现:

public class EasyExcelTest {
​
    public static void main(String[] args) {
        writeDataToExcel();
    }
​
    public static void writeDataToExcel() {
        List<CategoryExcelVo> list = new ArrayList<>() ;
        list.add(new CategoryExcelVo(1L , "数码办公" , "",0L, 1, 1)) ;
        list.add(new CategoryExcelVo(11L , "华为手机" , "",1L, 1, 2)) ;
        EasyExcel.write("D://分类数据1.xlsx" , CategoryExcelVo.class).sheet("分类数据1").doWrite(list);
    }
}

相关推荐

  1. EasyExcel

    2024-03-23 05:24:06       64 阅读
  2. <span style='color:red;'>EasyExcel</span>

    EasyExcel

    2024-03-23 05:24:06      64 阅读
  3. EasyExcel

    2024-03-23 05:24:06       43 阅读
  4. EasyExcel

    2024-03-23 05:24:06       21 阅读
  5. <span style='color:red;'>easyExcel</span>

    easyExcel

    2024-03-23 05:24:06      24 阅读
  6. EasyPoi、EasyExcel

    2024-03-23 05:24:06       63 阅读
  7. easyexcel使用

    2024-03-23 05:24:06       25 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-23 05:24:06       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-23 05:24:06       101 阅读
  3. 在Django里面运行非项目文件

    2024-03-23 05:24:06       82 阅读
  4. Python语言-面向对象

    2024-03-23 05:24:06       91 阅读

热门阅读

  1. 把json文件转换成excel格式文件

    2024-03-23 05:24:06       40 阅读
  2. python与excel第五节 打印excel

    2024-03-23 05:24:06       37 阅读
  3. 在realsense D455相机上运行orb_slam3

    2024-03-23 05:24:06       41 阅读
  4. OpenCV自带颜色表

    2024-03-23 05:24:06       41 阅读
  5. cordova cordova-hot-code-push-plugin 插件热更新

    2024-03-23 05:24:06       36 阅读
  6. 图书管理借阅系统(SpringBoot项目)

    2024-03-23 05:24:06       33 阅读