系列导航

springBoot项目打jar包

1、springboot工程新建(单模块)

2、springboot创建多模块工程

3、springboot连接数据库

4、SpringBoot连接数据库引入druid

5、SpringBoot连接数据库引入mybatis

6、SpringBoot-mybatis分页实现pagehelper

7、SpringBoot-mybatis-plus引入

8、SpringBoot 事务

9、SpringBoot-mybatis-druid多源数据多源数据

10、SpringBoot-mybatis-plus-druid多源数据

11、SpringBoot-mybatis-plus-druid多源数据事务

12、SpringBoot-mybatis-plus-ehcache

13、SpringBoot-配置文件里密码加密

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的更多相关文章

  1. SpringBoot图文教程14—SpringBoot集成EasyExcel「上」

    有天上飞的概念,就要有落地的实现 概念十遍不如代码一遍,朋友,希望你把文中所有的代码案例都敲一遍 先赞后看,养成习惯 SpringBoot 图文教程系列文章目录 SpringBoot图文教程1「概念+ ...

  2. 使用VUE+SpringBoot+EasyExcel 整合导入导出数据

    使用VUE+SpringBoot+EasyExcel 整合导入导出数据 创建一个普通的maven项目即可 项目目录结构 1 前端 存放在resources/static 下 index.html &l ...

  3. 使导出excle文档实现ALT+Enter的效果()

    JAVA中输入什么转义字符,使导出excle文档实现ALT+Enter的效果?或者有没有其他方法可以实现. 20 JAVA中输入什么转义字符,使导出excle文档实现ALT+Enter的效果?或者有没 ...

  4. easyExcel导出excel的简单使用

    easyExcel导出excel的简单使用 Java解析.生成Excel比较有名的框架有Apache poi.jxl.但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定 ...

  5. vue下载模板、导出excle

    1.下载模板是 下载模版比较简单,就是跳一个新的页面 2.导出excle 就是get请求,把自己要导出的参数一一拼接起来 }

  6. React+后端实现导出Excle表格的功能

    最近在做一个基于React+antd前端框架的Excel导出功能,我主要在后端做了处理,根据以下步骤,可以很容易就实现导出Excel表格数据的功能. 在做这类导出文件的功能,其实,在后端进行处理,会更 ...

  7. 手把手教你springboot中导出数据到excel中

    手把手教你springboot中导出数据到excel中 问题来源: 前一段时间公司的项目有个导出数据的需求,要求能够实现全部导出也可以多选批量导出(虽然不是我负责的,我自己研究了研究),我们的项目是x ...

  8. EasyExcel导出小结:动态标题、标题格式、相同值合并

    1. 实列相关依赖 <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel& ...

  9. SpringBoot基于easyexcel导出和写入Excel

      easyexcel是阿里巴巴旗下开源项目,主要用于Excel文件的导入和导出处理,今天我们利用SpringBoot和easyexcel实战演示如何导出和写入Excel文件. 一.加入我们需要的ea ...

  10. springboot使用EasyExcel,导出数据到Excel表格,并且将Excel表中数据导入

    一.导出至Excel 1.导入依赖 导出方法需要使用到fastJson的依赖,这里也直接导入 点击查看代码 <!--阿里的easyexcel--> <dependency> & ...

随机推荐

  1. MongoDB 6.0 单实例基于用户角色实现授权登录

    现代数据库系统能够存储和处理大量数据.因此,由任何一个用户单独负责处理与管理数据库相关的所有活动的情况相对较少.通常,不同的数据库用户需要对数据库的某些部分具有不同级别的访问权限:某些用户可能只需要读 ...

  2. python函数定义、调用、参数、返回

    python函数定义语法: 定义: Def foo(): print('bar') print('bar2') 如果函数内容特别少,可以一行定义 : Def foo():   print('bar') ...

  3. 生命体征监测VSM

    参考来源:ADI官网技术文章.知乎(hxl695822705.深圳加1健康科技 ) 缩写 全称 翻译 VSM Vital Signs Monitor 生命体征监测 ECG ElectroCardioG ...

  4. jdk10的var局部变量类型推理

    注:本人参考了openjdk官网,由于openjdk是开源的,所以不存在侵权行为,本章只为学习,我觉得没有什么比官网更具有话语权 1.jdk10的var的类型推测:就是这种处理将仅限于具有初始值设定项 ...

  5. Codeforces Round 906 (Div. 2)A-E1

    A. Doremy's Paint 3 记数组中数的种类数为\(k\),当\(k=1\)时,答案为\(yes\):当\(k=2\)时,记两个种类的数的个数差为\(d\),当\(d≤1\)时,答案为\( ...

  6. [ABC262G] LIS with Stack

    Problem Statement There is an empty sequence $X$ and an empty stack $S$. Also, you are given an inte ...

  7. 带圆角的虚线边框?CSS 不在话下

    今天,我们来看这么一个非常常见的切图场景,我们需要一个带圆角的虚线边框,像是这样: 这个我们使用 CSS 还是可以轻松解决的,代码也很简单,核心代码: div { border-radius: 25p ...

  8. MongoDB副本集的搭建和管理(高可用)

    使得mongodb具备自动故障转移.高可用.读写分离. 副本集默认情况下读写都只是通过主库,副节点只是备份数据而已,但是可以设置副节点允许读操作,这样就可以做成读写分离. 使用pymongo的时候也可 ...

  9. MySQL|mysql-索引

    1.索引是什么 1.1索引简介 索引是表的目录,是数据库中专门用于帮助用户快速查询数据的一种数据结构.类似于字典中的目录,查找字典内容时可以根据目录查找到数据的存放位置,以及快速定位查询数据.对于索引 ...

  10. react+antd选择框输入

    react+antd选择框输入 const onSearch=(fn,value)=>{ if(value){//这个if无比重要 form.setFieldsValue({"Owne ...