关于EasyExcel的数据导入和单sheet和多sheet导出
读写Excel基本代码
直接复制不一定能用
实体类
@ExcelIgnore 在导出操作中不会被导出
@ExcelProperty 在导入过程中 可以根据导入模板自动匹配字段, 在导出过程中可用于设置导出的标题名字
@Getter
@Setter
public class Material{
@ExcelIgnore
private Long id;
/** 所属部门 */
@ExcelProperty(value = {"一级合并标题","所属部门"})
private String department;
/** 所属部室/项目部/站区 */
@ExcelProperty(value = {"一级合并标题","所属部室/项目部/站区"})
private String area;
}
监听类
监听类控制导入数据的规则限制,监听类继承AnalysisEventListener<Object>类实现接口。
监听中无法调用Spring接口,使用反序列化注入Bean工厂中使用
public class MaterialListener extends AnalysisEventListener<Material> {
// 反序列化注入bean工厂
ISysDictDataService dictDataService = SpringUtils.getBean(ISysDictDataService.class);
//可以通过实例获取该值
private List<Material> datas = new ArrayList<>();
//错误信息
private List<String> errorInfo = new ArrayList<>();
@Override
public void invoke(Material material, AnalysisContext analysisContext) {
doSomething(material,analysisContext);//根据自己业务做处理
datas.add(material);//数据存储到list,供批量处理,或后续自己业务逻辑处理。
}
private void doSomething(Material object, AnalysisContext analysisContext) {
//获取当前行数
Integer row = analysisContext.readRowHolder().getRowIndex();
SysDictData sysDictData=new SysDictData();
if (ObjectUtils.isBlank(object.getType())){
errorInfo.add(" 第" + (row+1) + "行:物资种类不能为空,请重新填写后再导入!<br>");
}else {
sysDictData.setDictType("material_type");
sysDictData.setDictLabel(object.getType());
List<SysDictData> list3= dictDataService.selectDictDataList(sysDictData);
if (ObjectUtils.isBlank(list3)){
errorInfo.add(" 第" + (row+1) + "行:物资种类:"+object.getType()+"未在数据字典中找到,请先填写后再导入!<br>");
}
}
}
//返回结果集对象
public List<Material> getDatas() {
return datas;
}
public void setDatas(List<Material> datas) {
this.datas = datas;
}
//返回错误消息
public List<String> getErrorInfo() {
return errorInfo;
}
public void setErrorInfo(List<String> errorInfo) {
this.errorInfo = errorInfo;
}
@Override
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
}
}
控制器
导入数据方法
在materialService.saveList(materialList)中进行处理导入获取过来的数据,用于存取业务数据
@PostMapping("/importData")
@ResponseBody
public AjaxResult importData(@RequestParam MultipartFile file) throws Exception
{
MaterialListener excelListener = new MaterialListener();
// 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭
//EasyExcel.read(哪个文件).sheet(那张sheet表).head(表头什么样子).headRowNumber(表头占几行).registerReadListener(处理数据的监听器类).doRead()
EasyExcel.read(file.getInputStream(), Material.class, excelListener).sheet().head(Material.class).headRowNumber(2).doRead();
if(ObjectUtils.isBlank(excelListener.getErrorInfo())){
if(ObjectUtils.isNotBlank(excelListener.getDatas())){
List<Material> materialList = excelListener.getDatas();
materialService.saveList(materialList);
}
return AjaxResult.success(1);
}else{
return AjaxResult.error("操作失败",excelListener.getErrorInfo());
}
}
导出数据方法
单sheet导出在注释的方法出,多sheet导出如下所示
@GetMapping("/exportData")
public void exportData(Material material, HttpServletResponse response){
//换方法连表查询
// List<Material> list = materialService.selectMaterialListByDict(material);
List<Material> materialList=new ArrayList<>();
List<Material> list = materialService.selectMaterialList(material);
String[] ids=new String[list.size()];
for (Material p:list) {
//用于修改导出的数据
String list7= dictDataService.selectDictLabel("material_type",p.getType());
if (ObjectUtils.isNotBlank(list7)){
p.setType(list7);
}
materialList.add(p);
}
List<MaterialSolid> materialSolidList=new ArrayList<>();
List<MaterialSolid> materialSolidListS = materialSolidService.selectMaterialSolidListByIds(ids);
for (MaterialSolid solid:materialSolidListS) {
String list7= dictDataService.selectDictLabel("material_type",solid.getType());
if (ObjectUtils.isNotBlank(list7)){
solid.setType(list7);
}
materialSolidList.add(solid);
}
try {
response.setContentType("application/vnd.ms-excel");
response.setCharacterEncoding("utf-8");
// 这里URLEncoder.encode可以防止中文乱码 当然和EASYEXCEL没有关系
String fileName = URLEncoder.encode("物料信息台账", "UTF-8");
response.setHeader("Content-disposition", "attachment;filename="+ fileName + ".xlsx");
//调用方法进行写的操作
// EasyExcel.write(response.getOutputStream(),Material.class).sheet("物料信息台账").doWrite(materialList);
//多sheet页导出
ExcelWriter excelWriter = EasyExcel.write(response.getOutputStream()).build();
WriteSheet writeSheet1 = EasyExcel.writerSheet(0, "物料信息总账").head(Material.class).build();
WriteSheet writeSheet2 = EasyExcel.writerSheet(1, "物料信息详情").head(MaterialSolid.class).build();
excelWriter.write(materialList, writeSheet1);
excelWriter.write(materialSolidList, writeSheet2);
excelWriter.finish();
} catch (Exception e) {
e.printStackTrace();
}
}
关于EasyExcel的数据导入和单sheet和多sheet导出的更多相关文章
- SpringMVC 实现POI读取Excle文件中数据导入数据库(上传)、导出数据库中数据到Excle文件中(下载)
读取Excale表返回一个集合: package com.shiliu.game.utils; import java.io.File; import java.io.FileInputStream; ...
- 解析csv数据导入mysql的方法
mysql自己有个csv引擎,可以通过这个引擎来实现将csv中的数据导入到mysql数据库中,并且速度比通过php或是python写的批处理程序快的多. 具体的实现代码示例: 代码如下: load d ...
- SpringCloud微服务实战——搭建企业级开发框架(三十):整合EasyExcel实现数据表格导入导出功能
批量上传数据导入.数据统计分析导出,已经基本是系统必不可缺的一项功能,这里从性能和易用性方面考虑,集成EasyExcel.EasyExcel是一个基于Java的简单.省内存的读写Excel的开源项 ...
- springboot使用EasyExcel,导出数据到Excel表格,并且将Excel表中数据导入
一.导出至Excel 1.导入依赖 导出方法需要使用到fastJson的依赖,这里也直接导入 点击查看代码 <!--阿里的easyexcel--> <dependency> & ...
- java基于xml配置的通用excel单表数据导入组件(四、DAO主处理类)
package XXXXX.manage.importexcel; import java.beans.IntrospectionException; import java.io.BufferedR ...
- Logstash学习之路(四)使用Logstash将mysql数据导入elasticsearch(单表同步、多表同步、全量同步、增量同步)
一.使用Logstash将mysql数据导入elasticsearch 1.在mysql中准备数据: mysql> show tables; +----------------+ | Table ...
- java基于xml配置的通用excel单表数据导入组件(五、Action处理类)
package xxxxxx.manage.importexcel; import java.io.File; import java.util.HashMap; import java.util.M ...
- Java实现大批量数据导入导出(100W以上) -(二)导出
使用POI或JXLS导出大数据量(百万级)Excel报表常常面临两个问题: 1. 服务器内存溢出: 2. 一次从数据库查询出这么大数据,查询缓慢. 当然也可以分页查询出数据,分别生成多个Excel打包 ...
- Java实现大批量数据导入导出(100W以上) -(三)超过25列Excel导出
前面一篇文章介绍大数据量导出实现: Java实现大批量数据导入导出(100W以上) -(二)导出 这篇文章在Excel列较少时,按以上实际验证能很快实现生成.但如果列较多时用StringTemplat ...
- excel表格数据导入导出
/** * 导出数据到excel表格 * Created by shenjianhua on 2018-12-28 */ package com.luer.comm.excel; import jav ...
随机推荐
- CSS3-transform位移实现双开门效果
transform可以用于实现位移,旋转,缩放等效果. 位移:transform: translate(水平距离,垂直距离); 这里先借助其位移属性实现双开门的效果,鼠标hover的时候最上面的图片向 ...
- python 处理CAD文件
注意:如下的两个脚本都是我自己亲自试过的,可以运行得到结果!可以直接运行!可以直接运行! 网上的中文api能找到的不够全,工作中有用到部分功能,自己从中文英文资料里面找到一些,这里做一些总结. 画图a ...
- C# 内存回收
开发完成之后发现自己写的程序内存占用太高,找到如下解决方案 使用了一个timer每2s调用一次ClearMemory() #region 内存回收 [DllImport("kernel32. ...
- <雪山飞狐><飞狐外传 >合辑剧情+随笔
严格而言雪山飞狐与飞狐外传的剧情并不相关,前者写作与前,然后飞狐外传算是对雪山飞狐中形象并不饱满的胡斐作进一步补充描述,同时对二十余年前苗人凤与胡一刀之间故事的补充,以及众人叙述中的一些补充.因此虽然 ...
- windows ftp 简单搭建, wget ftp
事情起因: 公司客户一台数据库服务器突然连不上了,一开始以为是密码过期了,联系学校的老师给改了密码之后,还是连不上,然后就怀疑是不是ssh服务有问题.然后发现这台服务器上没有安装包,yum 命令也不好 ...
- jetbrain 全套激活
关于 jetbrain 专业版激活的教程很多,发现很多实际操作不太友好,本人亲测可激活经理 1.下载 ja-ja-netfilter-all https://github.com/byebai95/j ...
- bert一些思考
bert结构 首先是embdding lookup,[batch * seq]-->[batch, seq, hidden] 然后是加个mask embdding和type embdding和p ...
- spring boot2.3.0集成 thymelaf
配置pom 如果是2.x的直接配置一个starter即可 <!-- ThymeLeaf 依赖 --><dependency> <groupId>org.spri ...
- 解决mikumikudance丢失dxdx_43.dll问题
首先是MMD软件下载 我的操作系统是win10-x64 设备是19版小新pro13 mmd官网地址https://learnmmd.com/downloads/ 或者戳这里 链接:https://pa ...
- 一种典型的不知循环次数的c语言循环问题
问题如图 代码如下 1 #define _CRT_SECURE_NO_WARNINGS 1 2 #include<stdio.h> 3 int main() 4 { 5 puts(&quo ...