java利用easyexcel实现导入与导出功能

作者:红姐最牛 时间:2022-09-29 06:40:16 

前言

poi的解析方式是dom解析,把结果一次都读入内存操作,这样的操作平时是不会有问题的,但是并发量上来的时候就会出现OOM,EasyExcel,底层对象其实还是使用poi包的那一套。它只是将poi包的一部分抽了出来,摒弃掉了大部分业务相关的属性。由于它关注的业务是导入导出这一块,所以在处理大数据量的导入导出能够通过本地缓存来避免OOM,在特定场景中,EasyExcel的表现能力还是可以的。

1先添加依赖

<!-- EasyExcel -->
       <dependency>
           <groupId>com.alibaba</groupId>
           <artifactId>easyexcel</artifactId>
           <version>2.2.0-beta2</version>
       </dependency>

2批量插入数据

再试下导入导出功能前,写批量插入数据的接口和查询数据的接口。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="cn.demo.mapper.MedicnesMapper">
   <insert id="saveMedicnesList" parameterType="cn.demo.entity.Medicnes">
       insert into medices
       (food,remark)
       values
       <foreach collection="list" item="rm" separator=",">
           (#{rm.food},#{rm.remark})
       </foreach>
   </insert>
   <select id="medicnesList" parameterType="cn.demo.entity.Medicnes" resultType="cn.demo.entity.Medicnes">
       SELECT
       food,
       remark
       FROM
       medices
   </select>
</mapper>

3创建需要导出数据实体类

package cn.demo.entity;

import com.alibaba.excel.annotation.ExcelProperty;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@AllArgsConstructor
@NoArgsConstructor
public class Medicnes {
   @ExcelProperty("食物名称")
   private String  food;

@ExcelProperty("食物产地")
   private String  remark;
}

4创建一个类ExcelListener

package cn.demo.config;

import cn.demo.entity.Medicnes;
import cn.demo.service.EmpService;
import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import org.springframework.beans.factory.annotation.Autowired;

import java.util.ArrayList;
import java.util.List;
/**
* 有个很重要的点 ExcelListener
* 不能被spring管理,要每次读取excel都要new,然后里面用到spring可以构造方法传进去
*/
public class ExcelListener extends AnalysisEventListener<Medicnes> {

private List<Medicnes> list = new ArrayList<>();

//每隔5条存储数据库,实际使用中可以3000条,然后清理list ,方便内存回收
   private static final int BATCH_COUNT = 5;

//假设这个是一个DAO,当然有业务逻辑这个也可以是一个service。当然如果不用存储这个对象用
   @Autowired
   private EmpService empService;
    /**
    * 如果使用了spring,请使用这个构造方法。
    * 每次创建Listener的时候需要把spring管理的类传进来
    */
   public ExcelListener(EmpService empService) {
       this.empService = empService;
   }
   /**
    * 这个每一条数据解析都会来调用
    */
   @Override
   public void invoke(Medicnes goods, AnalysisContext analysisContext) {
       System.out.println("解析到一条数据:========================"+goods.toString());
       // 数据存储到data,供批量处理或后续自己业务逻辑处理。
       list.add(goods);
       // 达到BATCH_COUNT了,需要去存储一次数据库,防止数据几万条数据在内存,容易OOM
       if(list.size() >= BATCH_COUNT){
           saveData();
           // 存储完成清理data
           list.clear();
       }

}
   /**
    * 所有数据解析完成了 都会来调用
    */
   @Override
   public void doAfterAllAnalysed(AnalysisContext analysisContext) {
       //确保所有数据都能入库
       saveData();
   }
   /**
    * 加上存储数据库
    */
   private void saveData() {
       System.out.println("=============================="+list.size()+"条数据,开始存储到数据库");
       empService.saveMedicnesList(list);
   }
}

5实现下载excel

接下来编写我们的工具类--帮助我们来实现下载excel

public class DownExcel {
   public static void download(HttpServletResponse response, Class t, List list) throws IOException, IllegalAccessException,InstantiationException {
       response.setContentType("application/vnd.ms-excel");// 设置文本内省
       response.setCharacterEncoding("utf-8");// 设置字符编码
       response.setHeader("Content-disposition", "attachment;filename=demo.xlsx"); // 设置响应头
       EasyExcel.write(response.getOutputStream(), t).sheet("模板").doWrite(list); //用io流来写入数据
   }
}

//导出为Excel
@RequestMapping("/downloadexcel.do")
public void getExcel(HttpServletResponse response) throws IllegalAccessException, IOException,
InstantiationException {
   List<Medicnes> list = sysUserService.medicnesList();
   DownExcel.download(response,Medicnes.class,list);
}

6控制器添加我们的导入操作代码

//导入Excel
@RequestMapping("/importexcel.do")
@ResponseBody
public String importexcel(@RequestParam(value = "excelFile") MultipartFile file) throws IOException{
   EasyExcel.read(file.getInputStream(), Medicnes.class, new ExcelListener(sysUserService)).sheet().doRead();
   return "success";
}

7导出效果如图

java利用easyexcel实现导入与导出功能

8导入直接调用

java利用easyexcel实现导入与导出功能

来源:https://blog.csdn.net/qq_40609490/article/details/125004176

标签:java,easyexcel,导入,导出,功能
0
投稿

猜你喜欢

  • Android 文件数据存储实例详解

    2023-07-28 17:08:03
  • C#用Topshelf创建Windows服务的步骤分享

    2022-10-19 00:47:58
  • java实现小猫钓鱼游戏

    2021-10-10 19:59:48
  • Android 验证码功能实现代码

    2023-06-12 23:19:06
  • Java从同步容器到并发容器的操作过程

    2021-10-14 05:26:58
  • Android中View的炸裂特效实现方法详解

    2022-07-25 17:59:28
  • 使用C#获取远程图片 Form用户名与密码Authorization认证的实现

    2022-01-22 21:44:06
  • 基于SpringBoot核心原理(自动配置、事件驱动、Condition)

    2023-08-23 01:46:31
  • Android SQLite数据库进行查询优化的方法

    2022-10-03 09:09:00
  • AndroidStudio 配置 AspectJ 环境实现AOP的方法

    2021-09-03 10:09:01
  • java使用HashMap实现斗地主(有序版)

    2021-08-30 10:24:10
  • 浅析C++中的函数与指针

    2022-03-13 11:04:28
  • java poi设置生成的word的图片为上下型环绕以及其位置的实现

    2023-05-23 03:12:08
  • 详解maven中央仓库连不上的解决办法

    2023-02-25 08:43:54
  • 程序猿必须要掌握的多线程安全问题之锁策略详解

    2021-10-19 04:57:17
  • 浅谈java常用的几种线程池比较

    2021-07-24 01:28:23
  • 举例说明Java设计模式编程中ISP接口隔离原则的使用

    2023-11-20 11:07:40
  • 解析C#中的私有构造函数和静态构造函数

    2021-11-27 07:13:15
  • Android activity堆栈及管理实例详解

    2022-07-28 01:17:14
  • Android开发文件存储实例

    2021-10-13 17:27:01
  • asp之家 软件编程 m.aspxhome.com