前端组件

<hd-flex>
<el-dialog v-model="isUploadDialog" width="50%" lock-scroll=false>
<el-upload
class="upload-demo"
drag
:action="url"
:on-success="success"
:on-error="error"
:headers="uploadHeaders"
:limit="1"
:on-exceed="handleExceed"
:file-list="fileList"
accept=".xlsx,.xls">
<i class="el-icon-upload"></i>
<div class="el-upload__text"><em>点击上传</em></div>
<div class="el-upload__tip" slot="tip">只能上传xlsx/xls文件,且不超过500kb</div>
</el-upload>
</el-dialog>
</hd-flex>

//变量
url: `${conf.BASE_URL}/core/ssqd/importS`,
isUploadDialog: false,
fileList: [],

// 方法
//导入
async importS() {
this.fileList=[];
this.isUploadDialog=true;
},
success(response, file, fileList){
if(response.code=='500'){
this.$hd.message.error(response.errorBody.errorMessage);
}
if(response.code=='200'){
this.$hd.message.ok('导入成功!');
this.isUploadDialog=false;
this.$refs.table.onSearch();
}

},
error(err, file, fileList){
this.$hd.message.error(err);

},
handleRemove(file, fileList) {
console.log(file, fileList)
},
handlePreview(file) {
console.log(file)
},
handleExceed(files, fileList) {
this.$message.warning(
`当前限制选择 1 个文件,本次选择了 ${files.length} 个文件,共选择了 ${
files.length + fileList.length
} 个文件`
)
},
beforeRemove(file, fileList) {
return this.$confirm(`确定移除 ${file.name}?`)
},

Java

Controller 
	@ApiOperation("上传")
@ApiImplicitParams({
@ApiImplicitParam(name = "file",value = "文件",dataTypeClass = MultipartFile.class,required = true,paramType = "")
})
@PostMapping ("/importS")
public RestResponse<String> uploadExcel(MultipartFile file)throws IOException {
String HZ = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf("."));
if(".xlsx.xls".indexOf(HZ) < 0){
throw new BaseException("500","导入的文件类型不正确,只能导入Excel文件");
}
EasyExcel.read(file.getInputStream(), SsqdVO.class,new UploadListenerBySsqd(iSsqdService)).sheet() .doRead();;
return new RestResponse<> ("ok");
} 

javaBean

package com.hopedove.coreserver.vo.sygl;

import com.alibaba.excel.annotation.ExcelProperty;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import java.io.Serializable;
import java.math.BigDecimal;
import java.util.Date; import com.hopedove.commons.vo.BaseModel;
import lombok.Data; /**
* 璇曠罕娓呭崟
* @TableName T_JS_SYGL_SSQD
*/
@TableName(value ="T_JS_SYGL_SSQD")
@Data
public class SsqdVO extends BaseModel implements Serializable {
/**
* 璇曠罕娓呭崟ID
*/
@TableId
private String SSQDID;
/**
* 坯布类型
*/
@ExcelProperty(value ="试纱类型", index = 0)
private String PBLX; /**
* 布号
*/
@ExcelProperty(value ="布号", index = 1)
private String BH; /**
* 支数
*/
@ExcelProperty(value ="支数", index = 2)
private String ZS; /**
* 产地
*/
@ExcelProperty(value ="产地", index = 3)
private String CD; /**
* 批号
*/
@ExcelProperty(value ="批号", index = 4)
private String PH; /**
* 重量
*/
@ExcelProperty(value ="重量", index = 5)
private BigDecimal ZL; /**
* 备注
*/
@ExcelProperty(value ="备注", index = 6)
private String REMARK; @TableField(exist = false)
private String GY; }

  监听器: 判断上传表格是否符合要求

package com.hopedove.coreserver.service.impl.sygl;

import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import com.alibaba.nacos.common.utils.CollectionUtils;
import com.hedu.sweet.starter.utils.exception.BusinException;
import com.hopedove.coreserver.service.sygl.ISsqdService;
import com.hopedove.coreserver.vo.sygl.SsqdVO; import java.util.ArrayList;
import java.util.List;
import java.util.Map; public class UploadListenerBySsqd extends AnalysisEventListener<SsqdVO> { private ISsqdService iSsqdService; public UploadListenerBySsqd(ISsqdService iSsqdService) {
this.iSsqdService = iSsqdService;
} private List<SsqdVO> list = new ArrayList<>(100); @Override
public void invoke(SsqdVO ssqdVO, AnalysisContext analysisContext) {
//业务判断
System.out.println("***"+ssqdVO+"***");
list.add(ssqdVO);
// if (list.size() > 100) {
// wjgbpclService.saveData(list);//保存到数据库
// list = ListUtils.newArrayListWithExpectedSize(100);
// }
} @Override
public void doAfterAllAnalysed(AnalysisContext analysisContext) {
if (CollectionUtils.isNotEmpty(list)) {
System.out.println("***结束***");
System.out.println(list);
iSsqdService.saveData(list);
}else{
throw new BusinException("500","导入的文件为空,请填写信息后重新导入。");
}
}
/**
* 在这里进行模板的判断
* @param headMap 存放着导入表格的表头,键是索引,值是名称
* @param context
*/
@Override
public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {
String isNull = "";
if (context.readRowHolder().getRowIndex() == 0) {
String[] headList = {"试纱类型","布号","支数","产地","批号","重量","备注"};
for (int i = 0; i < headList.length; i++) {
try {
if (!headMap.get(i).equals(headList[i])) {
isNull = "导入模板不正确,请重新导入";
break;
}
} catch (Exception e) {
isNull = "导入模板不正确,请重新导入";
break;
}
}
}
if(isNull!=""){
throw new BusinException("500",isNull);
} } }

  实现类

	@Override
public void saveData(List<SsqdVO> list) {
//出现空的数据行,只有边框没有值-处理
list = tableNullLineRemove(list);
String msg = "";
if(list.size() > 0){ if (StringUtil.isEmpty(msg)) {
// 验证输入数据重复性
msg = checkMxList(list);
} if (StringUtil.isEmpty(msg)) {
// excel数据插入数据库
List<SsqdVO> arr = new ArrayList<>(100);
for (int i = 0; i < list.size(); i++) {
SsqdVO bean= list.get(i);
bean = nullToString(bean);
arr.add(bean);
}
if (CollectionUtils.isNotEmpty(list)) {
if(!importAdd(list)){//导入
throw new BusinException("500","导入的文件有效记录数超过1000条,请分批次多次导入");
}
}
}
}
if(!StringUtil.isEmpty(msg)){
throw new BusinException("500",msg);
}
} /**
* 验证输入数据重复性
* @param list
* @return
*/
private String checkMxList(List<SsqdVO> list) {
List<String> errMsgList = new ArrayList<String>();
String msg = "";
if (list.size() > 0) {
// 把页面的数据进行重复性检验
for (int i = 0; i < list.size(); i++) {
SsqdVO mxModel = list.get(i);
String PBLX = StringUtil.nullToSring(mxModel.getPBLX());
String BH = StringUtil.nullToSring(mxModel.getBH());
String ZS = StringUtil.nullToSring(mxModel.getZS());
String ZL = StringUtil.nullToSring(mxModel.getZL());
//当纱织类型,布号,支数和重量都为空,那么这条记录既不交验,也不添加
if(StringUtil.isEmpty(PBLX) && StringUtil.isEmpty(BH) && StringUtil.isEmpty(ZS) && StringUtil.isEmpty(ZL)){
continue;
}
for (int j = 1; j < list.size(); j++) { if (i != j) {
SsqdVO mxModelSec = list.get(j);
String PBLXsec = mxModelSec.getPBLX();
String BHsec = StringUtil.nullToSring(mxModelSec.getBH());
String ZSsec = StringUtil.nullToSring(mxModelSec.getZS());
String ZLsec = StringUtil.nullToSring(mxModelSec.getZL());
//当纱织类型,布号,支数和重量都为空,那么这条记录既不交验,也不添加
if(StringUtil.isEmpty(PBLXsec) && StringUtil.isEmpty(BHsec) && StringUtil.isEmpty(ZSsec) && StringUtil.isEmpty(ZLsec)){
continue;
}
if(PBLX.equals(PBLXsec) && "2".equals(PBLX)){
if ((StringUtil.nullToSring(mxModelSec.getBH()))
.equals(StringUtil.nullToSring(mxModel.getBH()))
&& (StringUtil.nullToSring(mxModelSec.getZS()))
.equals(StringUtil.nullToSring(mxModel.getZS()))
&& (StringUtil.nullToSring(mxModelSec.getZL()))
.equals(StringUtil.nullToSring(mxModel.getZL()))
&& (StringUtil.nullToSring(mxModelSec.getSC()))
.equals(StringUtil.nullToSring(mxModel.getSC()))
&& (StringUtil.nullToSring(mxModelSec.getSH()))
.equals(StringUtil.nullToSring(mxModel.getSH()))
&& (StringUtil.nullToSring(mxModelSec.getGY()))
.equals(StringUtil.nullToSring(mxModel.getGY()))) {
msg="导入文档第" + (i+1) + "行数据记录与第" + (j+1)
+ "行数据记录重复</br>";
/*errMsgList.add("导入文档第" + (i+1) + "行数据记录与第" + j
+ "行数据记录重复</br>");*/
}
} else {
if ((StringUtil.nullToSring(mxModelSec.getBH()))
.equals(StringUtil.nullToSring(mxModel.getBH()))
&& (StringUtil.nullToSring(mxModelSec.getZS()))
.equals(StringUtil.nullToSring(mxModel.getZS()))
&& (StringUtil.nullToSring(mxModelSec.getZL()))
.equals(StringUtil.nullToSring(mxModel.getZL()))) {
msg="导入文档第" + (i+1) + "行数据记录与第" + (j+1)
+ "行数据记录重复</br>";
/*errMsgList.add("导入文档第" + (i+1) + "行数据记录与第" + j
+ "行数据记录重复</br>")*/;
}
}
}
}
}
} return msg;
} private Boolean importAdd(List<SsqdVO> list) {
UserDTO userBean = UserUtil.getUserInfo();
int index = 0 ;
List <Map <String, String>> addList = new ArrayList <Map <String, String>>();
for (int i = 0; i < list.size(); i++) {
SsqdVO entry = list.get(i);
//保存的处理逻辑 }
iSsqdDao.insertSSQD(addList);
iSsqdDao.insertSSRZGY(addList);
return true;
}
private SsqdVO nullToString(SsqdVO params) {
Map<String,Object> map = new HashMap<>();
Field[] fields = params.getClass().getDeclaredFields();
try {
for (Field field : fields
) {
//设置允许通过反射访问私有变量
field.setAccessible(true);
map.put(field.getName(),field.get(params)==null? "":field.get(params));
} }catch (Exception e){
e.printStackTrace();
}
return MapUntil.mapToBean(map,new SsqdVO());
}
private List<SsqdVO> tableNullLineRemove(List<SsqdVO> list) {
List<SsqdVO> l = new ArrayList<>();
//当纱织类型,布号,支数和重量都为空,那么这条记录既不交验,也不添加
for (SsqdVO model:list
) {
if(model.getPBLX()==null && model.getBH() ==null&&model.getZS()==null &&model.getZL()==null){
continue;
}else{
l.add(model);
}
}
return l;
}

  SQL  oracle数据库批量新增

    <insert id="insertSSQD" parameterType="list">
insert all
<foreach collection="list" item="item">
<![CDATA[
into T_JS_SYGL_SSQD
(
SSQDID,
RSQDBH,
BH,
PBLX,
PBMC,
ZS,
CREATER,
CRENAME,
UPDATER,
BMXXID,
BMMC,
JGXXID,
JGMC,
ZTXXID,
ZTMC
]]>
<if test=" item.ZL != null and item.ZL != '' ">,ZL </if>
<if test=" item.SH != null and item.SH != '' ">,SH </if>
<if test=" item.ZFMYQ != null and item.ZFMYQ != '' ">,ZFMYQ </if>
<if test=" item.XSYQ != null and item.XSYQ != '' ">,XSYQ </if>
<if test=" item.SG != null and item.SG != '' ">,SG </if>
<if test=" item.REMARK != null and item.REMARK != '' ">,REMARK </if>
<if test=" item.CD != null and item.CD != '' ">,CD </if>
<if test=" item.PH != null and item.PH != '' ">,PH </if>
<if test=" item.SC != null and item.SC != '' ">,SC </if>
) VALUES(
<![CDATA[
#{item.SSQDID},
#{item.RSQDBH},
#{item.BH},
#{item.PBLX},
#{item.PBMC},
#{item.ZS},
#{item.CREATER},
#{item.CRENAME},
#{item.UPDATER},
#{item.BMXXID},
#{item.BMMC},
#{item.JGXXID},
#{item.JGMC},
#{item.ZTXXID},
#{item.ZTMC}
]]>
<if test=" item.ZL != null and item.ZL != '' ">,#{item.ZL} </if>
<if test=" item.SH != null and item.SH != '' ">,#{item.SH} </if>
<if test=" item.ZFMYQ != null and item.ZFMYQ != '' ">,#{item.ZFMYQ} </if>
<if test=" item.XSYQ != null and item.XSYQ != '' ">,#{item.XSYQ} </if>
<if test=" item.SG != null and item.SG != '' ">,#{item.SG} </if>
<if test=" item.REMARK != null and item.REMARK != '' ">,#{item.REMARK} </if>
<if test=" item.CD != null and item.CD != '' ">,#{item.CD} </if>
<if test=" item.PH != null and item.PH != '' ">,#{item.PH} </if>
<if test=" item.SC != null and item.SC != '' ">,#{item.SC} </if>
) </foreach>
select * from dual
</insert>

elment UI + EasyExcel 实现 导入的更多相关文章

  1. SpringBoot 整合文件上传 elment Ui 上传组件

    SpringBoot 整合文件上传 elment Ui 上传组件 本文章记录 自己学习使用 侵权必删! 前端代码 博主最近在学 elment Ui 所以 前端使用 elmentUi 的 upload ...

  2. Elment UI的使用说明

    一. Elment UI 1. 简介 Element UI是饿了么团队提供的一套基于Vue2.0的组件库,可以快速搭建网站,提高开发效率,就如同bootstrap. 2.组件分类 ElementUI  ...

  3. 使用Layui、Axios、Springboot(Java) 实现EasyExcel的导入导出(浏览器下载)

    实现EasyExcel的导入导出(浏览器下载) 实现三个按钮的功能,但是却花费了一天的时间包括总结. 使用到的技术:springboot layui axios EasyExcel mybatis-p ...

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

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

  5. 2 Elment Ui 日期选择器 格式化问题

    Elment Ui 日期选择器 格式化问题 在前后端联调过程中 我们常常会遇到日期无法被反序列化 这个问题 会有点头疼 下面以我这边为例 后端使用的是springboot 默认集成了jackjson ...

  6. 5、基于EasyExcel的导入导出

    一.Apach POI处理Excel的方式: 传统Excel操作或者解析都是利用Apach POI进行操作,POI中处理Excel有以下几种方式: 1.HSSFWorkbook: HSSFWorkbo ...

  7. SpringBoot+Mybatis-plus整合easyExcel批量导入Excel到数据库+导出Excel

    一.前言 今天小编带大家一起整合一下easyExcel,之所以用这个,是因为easyExcel性能比较好,不会报OOM! 市面上常见的导入导出Excel分为三种: hutool easyExcel p ...

  8. easyExcel用于导入导出

    1.添加依赖: <!-- 现在已经更新到1.1.2-beta5 --> <dependency> <groupId>com.alibaba</groupId& ...

  9. EasyExcel实现导入excel

    https://blog.csdn.net/rexueqingchun/article/details/91870372 1.pom.xml配置依赖包 <!-- xls格式excel依赖包 -- ...

  10. jquery与各种UI框架的导入要注意的地方

    前端的处理我们会使用easyUI,amazeUI,bootstrap等等框架,然而每个页面都要导入这些js   css 文件,所以我们将要导入的文件提取出来,写在一个页面上,每次只要倒入该页面就行,如 ...

随机推荐

  1. 使用EFCore的Code First和MySql数据库迁移

    1. 感慨一下 随着.net core的持续更新和升级,至少对于从事.net开发的人员和即将踏入这个领域的人来说,我相信大家的热情还是持续高涨的.国内的.net开发生态相比于之前来说,还是大有所好转的 ...

  2. Windows无线连接路由器成功但无法网

    Windows10连接Wifi成功,任务栏无线图标没有感叹号,但是无法连接到网络,重启电脑才能连接上,手机连接这个网络却可以一直联通.本人使用的是intel 9260无线网卡,经过测试,我通过这个方法 ...

  3. Redis系列12:Redis 的事务机制

    Redis系列1:深刻理解高性能Redis的本质 Redis系列2:数据持久化提高可用性 Redis系列3:高可用之主从架构 Redis系列4:高可用之Sentinel(哨兵模式) Redis系列5: ...

  4. oracle问题ORA-00600[729][space leak]

    故障现象 ORA-00600: 内部错误代码, 参数: [729], [33600], [space leak], [], [], [], [], [], [], [], [], [] 故障分析 根据 ...

  5. [MAUI 项目实战] 手势控制音乐播放器(三): 动画

    @ 目录 吸附动画 确定位置 平移动画 回弹动画 使用自定义缓动函数 多重动画 点击动画 项目地址 上一章节我们创建了手势容器控件PanContainer,它对拖拽物进行包装并响应了平移手势和点击手势 ...

  6. mysql的查询--子查询,order by,group by,having

    一. 1.多表查询 格式1: select 字段列表 from 表1 join 表2 on 表1.字段1=表2.字段1 where 查询条件 格式2: select 字段列表 from 表1 join ...

  7. 【Note】贪心

    感谢 $ \text{orzws/chy} $ 倾情授课. 目录 -1. 证明方式 0. 朴素贪心 AT2557 [ARC073C] Ball Coloring P2587 [ZJOI2008]泡泡堂 ...

  8. 解密prompt系列5. APE+SELF=自动化指令集构建代码实现

    上一章我们介绍了不同的指令微调方案, 这一章我们介绍如何降低指令数据集的人工标注成本!这样每个人都可以构建自己的专属指令集, 哈哈当然我也在造数据集进行时~ 介绍两种方案SELF Instruct和A ...

  9. 最新版新款影视直播粉红色UI的CMS源码/带教程/支付已接

    demo软件园每日更新资源,请看到最后就能获取你想要的: 1.最新版新款影视直播粉红色UI的麻豆CMS源码/带教程/支付已接 基于苹果CMS v10影视系统框架开发的前端模板,带会员中心,可设置试看付 ...

  10. 一篇博客上手request和response

    概念 request:获取请求数据 response:设置响应数据 Request request继承体系 ServletRequest--Java提供的请求对象根接口 HttpServletRequ ...