14、SpringBoot-easyexcel导出excle
系列导航
6、SpringBoot-mybatis分页实现pagehelper
9、SpringBoot-mybatis-druid多源数据多源数据
10、SpringBoot-mybatis-plus-druid多源数据
11、SpringBoot-mybatis-plus-druid多源数据事务
12、SpringBoot-mybatis-plus-ehcache
14、SpringBoot-easyexcel导出excle
完结
本文主要描述,springboot如何下载excle,上传解析excle,以及把上传excle中错误的数据在返回给用户一个并告知数据哪里错误这样一个功能。
1、pom.xml文件
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>2.0.5</version>
</dependency>
2、配置文件
# 应用名称
spring.application.name=demo
# 应用服务 WEB 访问端口
server.port=8080
3、工程结构

4、源码
package com.example.demo; import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication
public class DemoApplication { public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
} }
package com.example.demo.controller; import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.ExcelWriter;
import com.alibaba.excel.write.metadata.WriteSheet;
import com.example.demo.domain.Student;
import com.example.demo.service.ExeclService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile; import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;
import java.nio.charset.StandardCharsets;
import java.util.ArrayList;
import java.util.List; @Controller
@RequestMapping("/excle")
public class ExcelController { @Autowired
private ExeclService execlService; //将数据写入到excle文档里并且下载
@GetMapping("/down")
@ResponseBody
public void test(HttpServletResponse response) throws IOException {
List<Student> list = new ArrayList<>();
list.add(new Student("001","张三"));
list.add(new Student("002","李四"));
list.add(new Student("003","王五"));
//返回输出流。格式Excel
response.setContentType("application/vnd.ms-excel");
//设置表名称
String name = "学生信息表";
try {
//设置编码格式
name = URLEncoder.encode(name, StandardCharsets.UTF_8.toString());
// 设置输出名字 attachment附件
response.setHeader("Content-Disposition", "attachment;filename=" + name + ".xlsx"); //将输出流封装到excelWriter
ExcelWriter excelWriter = EasyExcel.write(response.getOutputStream()).build(); //定义工作表对象
WriteSheet sheet = EasyExcel.writerSheet(0,"sheet").head(Student.class).build();
//sheet.setTableStyle();
//往excel写入
excelWriter.write(list,sheet);
//关闭输出流
excelWriter.finish(); } catch (UnsupportedEncodingException e) {
e.printStackTrace();
} } //上传excle并解析
@PostMapping("/upload")
@ResponseBody
public void upload(@RequestParam("file") MultipartFile multipartFile, HttpServletResponse response) throws IOException {
execlService.upFile(multipartFile);
} //上传excle并解析,而且将有错误的数据返回给用户
@PostMapping("/uploadAndReturnError")
@ResponseBody
public void uploadAndReturnError(@RequestParam("file") MultipartFile multipartFile, HttpServletResponse response) throws IOException {
String result = execlService.upFileAndReturn(multipartFile,response);
System.out.println(result);
}
}
package com.example.demo.domain;
public class Employee {
private String noId;
private String empName;
private Integer empAge;
private String text;
public String getNoId() {
return noId;
}
public void setNoId(String noId) {
this.noId = noId;
}
public String getEmpName() {
return empName;
}
public void setEmpName(String empName) {
this.empName = empName;
}
public Integer getEmpAge() {
return empAge;
}
public void setEmpAge(Integer empAge) {
this.empAge = empAge;
}
public String getText() {
return text;
}
public void setText(String text) {
this.text = text;
}
@Override
public String toString() {
return "Employee{" +
"noId='" + noId + '\'' +
", empName='" + empName + '\'' +
", empAge=" + empAge +
", text='" + text + '\'' +
'}';
}
}
package com.example.demo.domain; import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.write.style.ColumnWidth;
import com.alibaba.excel.annotation.write.style.ContentRowHeight;
import com.alibaba.excel.annotation.write.style.HeadRowHeight; @ContentRowHeight(15) // 文本行高度
@HeadRowHeight(20) // 标题高度
@ColumnWidth(25) // 默认列宽度
public class EmployeeOther {
@ExcelProperty("员工id")
private String noId; @ExcelProperty("员工姓名")
private String empName; @ExcelProperty("员工年龄")
private Integer empAge; @ExcelProperty("错误提示")
private String text; public String getNoId() {
return noId;
} public void setNoId(String noId) {
this.noId = noId;
} public String getEmpName() {
return empName;
} public void setEmpName(String empName) {
this.empName = empName;
} public Integer getEmpAge() {
return empAge;
} public void setEmpAge(Integer empAge) {
this.empAge = empAge;
} public String getText() {
return text;
} public void setText(String text) {
this.text = text;
} @Override
public String toString() {
return "EmployeeOther{" +
"noId='" + noId + '\'' +
", empName='" + empName + '\'' +
", empAge=" + empAge +
", text='" + text + '\'' +
'}';
}
}
package com.example.demo.domain;
import com.alibaba.excel.annotation.ExcelProperty;
public class Student {
@ExcelProperty("学号")//指定字段名字
//@ExcelIgnore//忽略该字段
private String id;
@ExcelProperty(value="姓名",index = 0)
private String name;
public Student( String id,String name ) {
this.id = id;
this.name = name;
}
public Student() {
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
@Override
public String toString() {
return "Studen{" +
"name='" + name + '\'' +
", id='" + id + '\'' +
'}';
}
}
package com.example.demo.listener; import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener; import java.util.ArrayList;
import java.util.List; public class ReadListener extends AnalysisEventListener { private static List<Object> list = new ArrayList<>();
// 每读一行,会调用该invoke方法一次
@Override
public void invoke(Object data, AnalysisContext analysisContext) {
list.add(data);
System.out.println("解析到一条数据:" + data); } // 全部读完之后,会调用该方法
@Override
public void doAfterAllAnalysed(AnalysisContext context) {
System.out.println("全部解析完成");
} /**
* 返回读取到的数据集合
*
*/
public static List<Object> getList() {
return list;
} }
package com.example.demo.service; import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.read.builder.ExcelReaderBuilder;
import com.alibaba.excel.read.builder.ExcelReaderSheetBuilder;
import com.example.demo.domain.Employee;
import com.example.demo.domain.EmployeeOther;
import com.example.demo.listener.ReadListener;
import org.springframework.stereotype.Component;
import org.springframework.web.multipart.MultipartFile; import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.net.URLEncoder;
import java.nio.charset.StandardCharsets;
import java.util.ArrayList;
import java.util.List; @Component
public class ExeclService { //解析上传的excle数据
public void upFile(MultipartFile multipartFile) throws IOException { //headRowNumber(1)意思是第一行是表头
ExcelReaderBuilder workBook = EasyExcel.read(multipartFile.getInputStream(), Employee.class, new ReadListener()).headRowNumber(1);
// 封装工作表
ExcelReaderSheetBuilder sheet1 = workBook.sheet();
// 读取
sheet1.doRead(); List<Object> list = ReadListener.getList();
int size = list.size(); for (int i = 0; i < list.size(); i++) {
Employee employee = (Employee) list.get(i); String noId = employee.getNoId();
String empName = employee.getEmpName();
Integer empAge = employee.getEmpAge();
String text = employee.getText(); System.out.println("noId:" + noId);
System.out.println("empName:" + empName);
System.out.println("empAge:" + empAge);
System.out.println("text:" + text); }
} //解析上传的excle数据,并将错误数据返回给用户
public String upFileAndReturn(MultipartFile multipartFile, HttpServletResponse response) throws IOException {
//导入正确的数据
int correctNum = 0;
//导入错误的数据
int wrongNum = 0; //headRowNumber(1)意思是第一行是表头
ExcelReaderBuilder workBook = EasyExcel.read(multipartFile.getInputStream(), EmployeeOther.class, new ReadListener()).headRowNumber(1);
// 封装工作表
ExcelReaderSheetBuilder sheet1 = workBook.sheet();
// 读取
sheet1.doRead(); //获取读取的数据
List<Object> list = ReadListener.getList(); int size = list.size();
//错误数据里列表
List<EmployeeOther> wrongList = new ArrayList<>();
for (int i = 0; i < size; i++) {
EmployeeOther employeeOther = (EmployeeOther) list.get(i); String noId = employeeOther.getNoId();
String empName = employeeOther.getEmpName();
Integer empAge = employeeOther.getEmpAge();
String text = employeeOther.getText(); //设置noId 等于1或者2 是错误数据
if ("1".equals(noId)||"2".equals(noId) ){
employeeOther.setText("该数据错误");
wrongList.add(employeeOther);
wrongNum++;
}else {
System.out.println("noId:" + noId);
System.out.println("empName:" + empName);
System.out.println("empAge:" + empAge);
System.out.println("text:" + text);
correctNum++;
}
}
//清理list里的数据,不清理下一次之前导入的数据依然存在
list.clear();
//将错误信息导出
if(wrongList.size()!=0) {
String name = "errorDataList"; //生成错误数据的返回文件
response.setContentType("application/vnd.ms-excel;charset=UTF-8");// 设置文本内省
response.setCharacterEncoding("utf-8");// 设置字符编码
name = URLEncoder.encode(name, StandardCharsets.UTF_8.toString());
response.setHeader("Content-disposition", "attachment;filename="+name+".xlsx"); // 设置响应头
EasyExcel.write(response.getOutputStream(), EmployeeOther.class).sheet(name).doWrite(wrongList); //用io流来写入数据
response.getOutputStream().flush(); }
System.out.println("导入成功数据" + correctNum + "条,错误数据" + wrongNum + "条,错误数据请下载修改后重新上传!");
return "导入成功数据" + correctNum + "条,错误数据" + wrongNum + "条,错误数据请下载修改后重新上传!";
}
}
5、测试文件下载
(1)设置导出字段的表头

(2)忽略某字段设置

(3)指定导出的顺序

6、测试文件上传解析
导入的excle内容如下


7、测试文件上传解析并返回错误数据
导入的excle内容如下


14、SpringBoot-easyexcel导出excle的更多相关文章
- SpringBoot图文教程14—SpringBoot集成EasyExcel「上」
有天上飞的概念,就要有落地的实现 概念十遍不如代码一遍,朋友,希望你把文中所有的代码案例都敲一遍 先赞后看,养成习惯 SpringBoot 图文教程系列文章目录 SpringBoot图文教程1「概念+ ...
- 使用VUE+SpringBoot+EasyExcel 整合导入导出数据
使用VUE+SpringBoot+EasyExcel 整合导入导出数据 创建一个普通的maven项目即可 项目目录结构 1 前端 存放在resources/static 下 index.html &l ...
- 使导出excle文档实现ALT+Enter的效果()
JAVA中输入什么转义字符,使导出excle文档实现ALT+Enter的效果?或者有没有其他方法可以实现. 20 JAVA中输入什么转义字符,使导出excle文档实现ALT+Enter的效果?或者有没 ...
- easyExcel导出excel的简单使用
easyExcel导出excel的简单使用 Java解析.生成Excel比较有名的框架有Apache poi.jxl.但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定 ...
- vue下载模板、导出excle
1.下载模板是 下载模版比较简单,就是跳一个新的页面 2.导出excle 就是get请求,把自己要导出的参数一一拼接起来 }
- React+后端实现导出Excle表格的功能
最近在做一个基于React+antd前端框架的Excel导出功能,我主要在后端做了处理,根据以下步骤,可以很容易就实现导出Excel表格数据的功能. 在做这类导出文件的功能,其实,在后端进行处理,会更 ...
- 手把手教你springboot中导出数据到excel中
手把手教你springboot中导出数据到excel中 问题来源: 前一段时间公司的项目有个导出数据的需求,要求能够实现全部导出也可以多选批量导出(虽然不是我负责的,我自己研究了研究),我们的项目是x ...
- EasyExcel导出小结:动态标题、标题格式、相同值合并
1. 实列相关依赖 <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel& ...
- SpringBoot基于easyexcel导出和写入Excel
easyexcel是阿里巴巴旗下开源项目,主要用于Excel文件的导入和导出处理,今天我们利用SpringBoot和easyexcel实战演示如何导出和写入Excel文件. 一.加入我们需要的ea ...
- springboot使用EasyExcel,导出数据到Excel表格,并且将Excel表中数据导入
一.导出至Excel 1.导入依赖 导出方法需要使用到fastJson的依赖,这里也直接导入 点击查看代码 <!--阿里的easyexcel--> <dependency> & ...
随机推荐
- 掌握这些,轻松管理BusyBox:如何交叉编译和集成BusyBox
在嵌入式系统中,由于设备的资源限制,需要开发人员寻找一种轻量.小型且使用广泛的工具集.而 BusyBox 就是这样一个在嵌入式系统中非常实用的工具集.本文将介绍如何在 Ubuntu 22.04 平台上 ...
- 记录一个异常 Gradle打包项目Lombok不生效 No serializer found for class com.qbb.User and no properties discovered to create BeanSerializer......
完整的错误: 03-Dec-2022 16:57:22.941 涓ラ噸 [http-nio-8080-exec-5] org.apache.catalina.core.StandardWrapperV ...
- BigQuant*中金财富“启明星”创新量化交易大赛开启,月月都拿奖
来量化比赛,赢万元大奖!! 比赛时间 2022年8月1日-2023年3月31日 比赛地址 启明星创新量化交易大赛 比赛简介 BigQuant与中金财富联合举办的创新量化交易大塞正式启动了! 本次大赛旨 ...
- Vulkan学习笔记之开发环境搭建
一.概述 最近因为工作需要开始学习Vulkan的相关知识,作为初学者,发现相对较好的学习资料莫过于vulkan-tutorial,在自己学习Vulkan的过程中,决定将自己的理解记录下来,一是为了加深 ...
- 红日靶场5-wp
红日靶场5 环境搭建 win7 账密及域 leo@sun 123.com sun\Administrator dc123.com 双网卡模拟内外网 外网网卡:192.168.130.150 内网网卡: ...
- MySQL|主从延迟问题排查(二)
二.案例分享二 2.1 问题描述 主库执行insert select 批量写入操作,主从复制通过row模式下转换为批量的insert大事务操作,导致只读实例CPU资源以及延迟上涨 16:55-17: ...
- 太赞了!墙裂推荐这款网页版 Nginx 配置生成器,好用到爆!
之前民工哥也给大家介绍过一款Nginx配置生成器:强大!Nginx 配置在线一键生成"神器",不太了解的人可以去看一看. 最近民工哥又发现一款好用的网页版开源工具,同样它的功能也是 ...
- .NET Web应用配置本地IIS(实现Visual Studio离线运行与调试)
前言: 因为项目程序需要频繁的修改,然后每次修改以后都要重新编译才能查看到修改的效果.而且有时候前端也需要及时的对接我们的接口,导致每次修改一点东西都要发布一次,这样子对于开发者而言是十分的浪费时间, ...
- php +libcurl+nghttp2 实现高性能微服务架构
1.server端nginx编译时增加参数configure --with-http_v2_module server { listen 80 http2; ...
- Java 如何在PPT中设置形状组合、取消组合、编辑组合形状
PPT中支持插入多达9种不同类型的形状,每种类型下又包含数十种形状样式.针对如此多种类型的形状,为页面元素设计需要.方便形状操作管理的目的,可通过形状"组合"的方式来固定多个形状的 ...