【Java专题_04】集成EasyExcel进行Excel导入导出详细教程

简介: 【Java专题_04】集成EasyExcel进行Excel导入导出详细教程

最详细的教程------EasyExcel导入与导出功能整合

1、开发环境参数

name Value
开发工具 Intellij IDEA 2018
框架 SpringBoot(maven项目也可以)
版本 2.2.5.RELEASE

2、导入Maven依赖

<!--EasyExcel,导出或是导入Excel文档的依赖-->
    <dependency>
      <groupId>com.alibaba</groupId>
      <artifactId>easyexcel</artifactId>
      <version>2.1.6</version>
    </dependency>
    <!--lombok,可以简化get,set,toString的插件-->
    <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
    </dependency>

3、项目结构

4、开始代码部分

第一步:创建实体类

import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.format.DateTimeFormat;
import lombok.Data;
import java.util.Date;
/**
 * 学生实体类
 * 
 * 注意需要有@ExcelProperty注解
 */
@Data  //代替get,set方法
public class Student {
    @ExcelProperty(value = "学生id",index=0)//index是序号,valeu是对应excel表格的头部标题
    private Integer id;//学生id
    @ExcelProperty(value = "学生姓名",index=1)
    private String name;//学生姓名
    @ExcelProperty(value = "学生年级",index=2)
    private String grade;//学生年级
    @ExcelProperty(value = "创建时间",index=3)
    @DateTimeFormat(value = "yyyy-MM-dd")//优化时间导出格式
    private Date createTime;//创建时间
}

第二步:创建一个通用的BaseMapper,方便我们进行业务处理。

import org.springframework.stereotype.Repository;
import java.util.List;
@Repository
public class BaseMapper<T> {
    public void saveBath(List<T> t){
        System.out.println("进行模拟数据插入操作");
    }
}

第三步:创建一个导入excel文档的读取监听通用类,注意!注意!注意,不要使用@Autowired 注入BaseMapper,否则会报空指针异常,因为可能与POI冲突,因而你可以new 一个,或者使用构造方法进行注入,这里采用构造方法进行注入。

import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import com.xsy.easyexcel.Mapper.BaseMapper;
import java.util.ArrayList;
import java.util.List;
/**
 * Excel文档导入配置类,使用泛型封装
 */
public class EasyExcelListener<T> extends AnalysisEventListener<T> {
    //mapper层通用类,你也可以自己封装
    private BaseMapper<T> baseMapper;
    //由于存在poi冲突无法进行依赖注入,采取构造方法的方式注入其他类
    public EasyExcelListener(BaseMapper<T> baseMapper){
       this.baseMapper=baseMapper;
    }
    //设置最大读取行数
    private static final int BAStudentCH_COUNStudent = 5;
    //以List形式读取excel文档内容
    private List<T> list=new ArrayList<>();
    /**
     * @param t 传入对应的实体类,就是你需要进行导入数据的类,我这里是student类
     * @param analysisContext 用来解析excel文档的类,引入依赖的包已经帮我们封装了
     */
    //重写导入代理类
    @Override
    public void invoke(T t, AnalysisContext analysisContext) {
        list.add(t);
        if (list.size()>=BAStudentCH_COUNStudent){
            System.out.println("读取行数:"+list.size());
            //执行逻辑操作,比如说插入数据到数据库 saveBath(list)
            baseMapper.saveBath(list);
            list.clear(); //清理list占用内存空间,重新读取下一次
        }
    }
    /**
     * @param analysisContext 用来解析excel文档的类,
     */
    //必须重写这个类,否则最后一批数据不会被处理
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
        //跟上面一样,比如说插入数据 saveBath(list)
        System.out.println("最后读取行数:"+list.size());
        baseMapper.saveBath(list);
    }
}

第四步:编写控制层

import com.alibaba.excel.EasyExcel;
import com.xsy.easyexcel.Mapper.BaseMapper;
import com.xsy.easyexcel.entity.Student;
import com.xsy.easyexcel.utils.EasyExcelListener;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.ArrayList;
import java.util.Date;
/**
 * 控制层
 */
@RestController
@RequestMapping("/test")
public class StudentController {
    
    /**
     * 以流方式响应回给客户端,返回值类型设置成void
     *
     * @param response 输出excel表格,让用户下载
     */
    @GetMapping("/exportExcel")
    public void exportExcel(HttpServletResponse response){
        try {
            //设置响应头,指定输出格式
            //attachment指定独立文件下载  不指定则回浏览器中直接打开
            response.setHeader("Content-Disposition","attachment;filename="+new String("学生信息表.xlsx".getBytes(),"ISO-8859-1"));
            //输出文件流  调用服务层方法,获取excel对象放入输出流
            ArrayList<Student> list = new ArrayList<>();
            Student student = new Student();
            student.setId(201624122);
            student.setName("xiaosongyeu");
            student.setGrade("大学四年级");
            student.setCreateTime(new Date());
            for (int i = 0; i <13 ; i++) {
                list.add(student);
            }
            //导出excel
            EasyExcel.write(response.getOutputStream(), Student.class).sheet("学生信息表").doWrite(list);
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    /**
     * ajax文件上传,前端传递的文件对象为file
     *
     * @param file 前端上传的excel文件
     * @return
     */
    @PostMapping("/importExcel")
    public String importExcel(MultipartFile file){
        //从解析器中获取excel文件流,传入到服务层进行读取处理
        try {
           EasyExcel.read(file.getInputStream(),Student.class,new EasyExcelListener(new BaseMapper())).sheet("学生信息表").doRead();
        } catch (IOException e) {
            e.printStackTrace();
            return "导入失败";
        }
        return "导入成功";
    }
}

第五步:进行测试

(1)导出excel文档:浏览器直接访问localhost:8080/test/exportExcel

(2)导入Excel文档:使用PostMan工具测试

选择post请求—选择form-data----key填file,value选择文件,让后send,可以查看控制台输出

六、若是遇到什么问题,可以一起交流学习,这个demo代码也一并奉上,直接下载即可运行。

相关文章
|
6月前
|
Oracle Java 关系型数据库
Java 简单教程
Java是跨平台、面向对象的编程语言,广泛用于企业开发、Android应用等。本教程涵盖环境搭建、基础语法、流程控制、面向对象、集合与异常处理,助你快速入门并编写简单程序,为进一步深入学习打下坚实基础。
480 0
|
7月前
|
安全 Java
Java之泛型使用教程
Java之泛型使用教程
447 10
|
8月前
|
Java 关系型数据库 数据库
Java 项目实战教程从基础到进阶实战案例分析详解
本文介绍了多个Java项目实战案例,涵盖企业级管理系统、电商平台、在线书店及新手小项目,结合Spring Boot、Spring Cloud、MyBatis等主流技术,通过实际应用场景帮助开发者掌握Java项目开发的核心技能,适合从基础到进阶的学习与实践。
1175 4
|
9月前
|
缓存 安全 Java
Java 并发新特性实战教程之核心特性详解与项目实战
本教程深入解析Java 8至Java 19并发编程新特性,涵盖CompletableFuture异步编程、StampedLock读写锁、Flow API响应式流、VarHandle内存访问及结构化并发等核心技术。结合电商订单处理、缓存系统、实时数据流、高性能计数器与用户资料聚合等实战案例,帮助开发者高效构建高并发、低延迟、易维护的Java应用。适合中高级Java开发者提升并发编程能力。
414 0
|
10月前
|
Oracle Java 关系型数据库
java 编程基础入门级超级完整版教程详解
这份文档是针对Java编程入门学习者的超级完整版教程,涵盖了从环境搭建到实际项目应用的全方位内容。首先介绍了Java的基本概念与开发环境配置方法,随后深入讲解了基础语法、控制流程、面向对象编程的核心思想,并配以具体代码示例。接着探讨了常用类库与API的应用,如字符串操作、集合框架及文件处理等。最后通过一个学生成绩管理系统的实例,帮助读者将理论知识应用于实践。此外,还提供了进阶学习建议,引导学员逐步掌握更复杂的Java技术。适合初学者系统性学习Java编程。资源地址:[点击访问](https://pan.quark.cn/s/14fcf913bae6)。
1145 2
|
SQL druid Oracle
【YashanDB知识库】yasdb jdbc驱动集成druid连接池,业务(java)日志中有token IDENTIFIER start异常
客户Java日志中出现异常,影响Druid的merge SQL功能(将SQL字面量替换为绑定变量以统计性能),但不影响正常业务流程。原因是Druid在merge SQL时传入null作为dbType,导致无法解析递归查询中的`start`关键字。
|
SQL Java 中间件
【YashanDB知识库】yasdb jdbc驱动集成BeetISQL中间件,业务(java)报autoAssignKey failure异常
在BeetISQL 2.13.8版本中,客户使用batch insert向yashandb表插入数据并尝试获取自动生成的sequence id时,出现类型转换异常。原因是beetlsql在prepareStatement时未指定返回列,导致yashan JDBC驱动返回rowid(字符串),与Java Bean中的数字类型tid不匹配。此问题影响业务流程,使无法正确获取sequence id。解决方法包括:1) 在batchInsert时不返回自动生成的sequence id;2) 升级至BeetISQL 3,其已修正该问题。
【YashanDB知识库】yasdb jdbc驱动集成BeetISQL中间件,业务(java)报autoAssignKey failure异常
|
JavaScript NoSQL Java
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
774 96
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
|
6月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
313 1
|
6月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
321 1
下一篇
开通oss服务