SpringBoot+layui实现Excel导入操作

excel导入步骤

    • 第三方插件
      • 引入插件
    • 效果图 (方法1)
    • 代码实现(方法1)
      • Html代码( 公共)
        • 下载导入模板
      • js实现 (方法1)
        • 上传文件实现
      • 效果图(方法2)
      • 代码实现(方法2)这里主要改的是js部分
      • 后端代码(公共部分)
        • controller
        • Service
        • serviceImpl
        • mapper
        • mapper.xml

第三方插件

layui_Excel

引入插件

 layui.use(['form', 'table', 'notify', 'dtree', 'dropdown', 'excel', 'element', 'laytpl'], function () {var $ = layui.jquery,form = layui.form,table = layui.table;var notify = layui.notify;var util = layui.util;var laydate = layui.laydate;var excel = layui.excel;var laytpl = layui.laytpl;var element = layui.element;})

效果图 (方法1)

在这里插入图片描述

代码实现(方法1)

Html代码( 公共)

在这里插入图片描述

  <button class="layui-btn data-light-btn layui-btn-sm " lay-event="data-export-btn"><iclass="fa fa-download"></i> 导入</button>

在这里插入图片描述


<div id="file" style="display: none;padding:20px;"><div class="layui-form-item"><div class="layui-form-block"><input type="file" class="layui-btn data-white-btn" id="LAY-excel-import-excel"multiple="multiple"><!--提示--><p><div class="layui-form-mid layui-text-em"><span style="color: #FF5722;">*</span>仅允许导入“xls”或“xlsx”格式文件!<!--下载导入模板--><button class="layui-btn layui-btn-xs data-gray-btn" lay-on="LAY-excel-import-download"><i class="fa fa-file-excel-o"></i>下载模板</button></div></p></div></div>
</div>
下载导入模板

在这里插入图片描述

  util.on("lay-on", {"LAY-excel-import-download": function () {//导入Excel//下载导入模板window.location.href = "../dist/erpInfo/用户数据导入模板.xlsx";//设置下载名称var fileName = "用户数据导入模板.xlsx";}})

js实现 (方法1)

上传文件实现

在这里插入图片描述

 table.on('toolbar(userInfoTableFilter)', function (obj) {var id = obj.config.id;var checkStatus = table.checkStatus(id);var dataArr = checkStatus.data;//用于删除var data = checkStatus.data[0]; //获取选中行数据var othis = lay(this);switch (obj.event) {case 'data-export-btn':layer.open({type: 1,title: '导入数据',shadeClose: true,content: $('#file'),skin: 'class-layer-sea',btn: ['<i class="fa fa-check"></i> 导入', '<i class="fa fa-times"></i> 取消'],yes: function (index) {//判断当前是否有文件if (document.getElementById('LAY-excel-import-excel').files.length === 0) {notify.info('请选择需要导入的文件文件', "vcenter", "shadow", false, 1000);return false;}//判断文件格式是否xls”或“xlsxif (document.getElementById('LAY-excel-import-excel').files[0].name.split('.')[1] !== 'xls' && document.getElementById('LAY-excel-import-excel').files[0].name.split('.')[1] !== 'xlsx') {notify.warning('仅允许导入“xls”或“xlsx”格式文件!', "vcenter", "shadow", false, 1000);return false;}//获取当前文件var files = document.getElementById('LAY-excel-import-excel').files;//读取文件excel.importExcel(files, {// 可以在读取数据同时梳理数据}, function (data, book) {// 也可以全部读取出来再进行数据梳理data = excel.filterImportData(data, {'nickname': 'A', 'account': 'B', 'email': 'C', 'deptId': 'D', 'postId': 'E', 'gender': 'F', 'status': 'G'})let getdata;//选择的表数据$.each(data[0], function (index, value) {if (getdata == undefined) {getdata = data[0][index];//从第二行开始获取数据}})//tab选择,采集上传数据element.on('tab(test)', function (d) {getdata = data[0][this.getAttribute('lay-id')];//第一个表格数据});// 打印测试数据:console.log(JSON.stringify(getdata.slice(1)))// 判断是否为空数据if (JSON.stringify(getdata.slice(1))==='[]'){notify.warning('不能导入空数据!', "vcenter", "shadow", false, 1000);return false;}notify.loading('正在导入数据,请稍后...', "vcenter", "shadow", false)setTimeout(function () {notify.destroyAll();//关闭加载框$.ajax({url: '/user/importUserInfo',type: 'post',data: {name: JSON.stringify(getdata.slice(1))},success: function (res) {if (res.code === 0) {notify.success(res.msg, "vcenter", "shadow", false, 1000);}else if (res.code === 1) {notify.warning(res.msg, "vcenter", "shadow", false, 1000);}else {notify.error(res.msg, "vcenter", "shadow", false, 1000);}}}).done(function () {setTimeout(function () {notify.destroyAll();layer.closeAll();parent.location.reload();//重载页面}, 500);});},2000)})},btn2: function () {$('#file').find('input').val('');layer.closeAll();window.location.reload();return false;}});break;};});

效果图(方法2)

在这里插入图片描述

代码实现(方法2)这里主要改的是js部分

 table.on('toolbar(userInfoTableFilter)', function (obj) {var id = obj.config.id;var checkStatus = table.checkStatus(id);var dataArr = checkStatus.data;//用于删除var data = checkStatus.data[0]; //获取选中行数据var othis = lay(this);switch (obj.event) {case 'data-export-btn':layer.open({type: 1,title: '导入数据',shadeClose: true,content: $('#file'),skin: 'class-layer-sea',btn: ['<i class="fa fa-times"></i> 取消'],success: function () {$(function () {// 监听上传文件的事件$('#LAY-excel-import-excel').change(function (e) {// 注意:这里直接引用 e.target.files 会导致 FileList 对象在读取之前变化,导致无法弹出文件var files = Object.values(e.target.files)uploadExcel(files)// 变更完清空,否则选择同一个文件不触发此事件e.target.value = ''})// 文件拖拽document.body.ondragover = function (e) {e.preventDefault()}document.body.ondrop = function (e) {e.preventDefault()var files = e.dataTransfer.filesuploadExcel(files)}})},btn2: function () {$('#file').find('input').val('');layer.closeAll();window.location.reload();return false;}});break;};});/*** 上传excel的处理函数,传入文件对象数组* @param  {FileList} files [description]* @return {[type]}       [description]* 方法2:*/function uploadExcel(files) {try {excel.importExcel(files, {// 可以在读取数据同时梳理数据}, function (data, book) {// 也可以全部读取出来再进行数据梳理data = excel.filterImportData(data, {'nickname': 'A', 'account': 'B', 'email': 'C', 'deptId': 'D', 'postId': 'E', 'gender': 'F', 'status': 'G'})let getdata;$.each(data[0], function (index, value) {if (getdata == undefined) {getdata = data[0][index];//从第二行开始获取数据}})//tab选择,采集上传数据element.on('tab(test)', function (d) {getdata = data[0][this.getAttribute('lay-id')];//第一个表格数据});// 如果不需要展示直接上传,可以再次 $.ajax() 将JSON数据通过 JSON.stringify() 处理后传递到后端即可layer.open({title: '文件转换结果检阅',closeBtn: false,skin: 'class-layer-yellow',area: ['630px', '300px'],tipsMore: true,content: laytpl($('#LAY-excel-export-ans').html()).render({data: data, files: files}),success: function () {element.render('tab');layui.code({});// 处理合并for (var file_index in book) {if (!book.hasOwnProperty(file_index)) {continue;}// 遍历每个Sheetfor (var sheet_name in book[file_index].Sheets) {if (!book[file_index].Sheets.hasOwnProperty(sheet_name)) {continue;}var sheetObj = book[file_index].Sheets[sheet_name];// 仅在有合并参数时进行操作if (!sheetObj['!merges']) {continue;}// 遍历每个Sheet中每个 !mergesfor (var merge_index = 0; merge_index < sheetObj['!merges'].length; merge_index++) {var mergeObj = sheetObj['!merges'][merge_index];// 每个合并参数的 s.c 表示左上角单元格的列,s.r 表示左上角单元格的行,e.c 表示右下角单元格的列,e.r 表示右下角单元格的行,计算时注意 + 1$('#table-export-' + file_index + '-' + sheet_name + '-' + mergeObj.s.r + '-' + mergeObj.s.c).prop('rowspan', mergeObj.e.r - mergeObj.s.r + 1).prop('colspan', mergeObj.e.c - mergeObj.s.c + 1);for (var r = mergeObj.s.r; r <= mergeObj.e.r; r++) {for (var c = mergeObj.s.c; c <= mergeObj.e.c; c++) {// 排除左上角if (r === mergeObj.s.r && c === mergeObj.s.c) {continue;}$('#table-export-' + file_index + '-' + sheet_name + '-' + r + '-' + c).remove();}}}}}},btn: ['立即导入', '放弃导入'],yes: function (index, layero) {if (JSON.stringify(getdata.slice(1))==='[]'){notify.warning('不能导入空数据!', "vcenter", "shadow", false, 1000);return false;}notify.loading('正在导入数据,请稍后...', "vcenter", "shadow", false)setTimeout(function () {notify.destroyAll();//关闭加载框$.ajax({url: '/user/importUserInfo',type: 'post',data: {name: JSON.stringify(getdata.slice(1))},success: function (res) {if (res.code === 0) {notify.success(res.msg, "vcenter", "shadow", false, 1000);}else if (res.code === 1) {notify.warning(res.msg, "vcenter", "shadow", false, 1000);}else {notify.error(res.msg, "vcenter", "shadow", false, 1000);}}}).done(function () {setTimeout(function () {notify.destroyAll();layer.closeAll();parent.location.reload();//重载页面}, 500);});},2000)return false;},btn2: function (index, layero) {// 点击取消按钮的回调函数layer.msg("取消上传成功!");layer.close(index); // 关闭弹窗}});})} catch (e) {layer.alert(e.message)}}

后端代码(公共部分)

controller

这里处理JSON的依赖

 <!--阿里巴巴fastjson依赖--><dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.83_noneautotype</version></dependency>
/** 数据导入操作* @importUserInfo* */@PostMapping("/importUserInfo")public  Map<String, Object> importUserInfo(@RequestParam("name") String data) {// 创建一个HashMap对象,用于存储返回的结果Map<String, Object> resultMap = new HashMap<>();System.out.println("导入用户信息");try {// 解析前端传递的JSON数据List<UserEntity> userEntities = JSON.parseArray(data, UserEntity.class);// 判断导入的文件中手机号是否在数据库中存在for (UserEntity user : userEntities) {// 判断导入的文件中手机号是否在数据库中存在UserEntity existingUser = userInfoService.selectByAccount(user.getAccount());if (existingUser != null) {resultMap.put("code", 1);resultMap.put("msg", "该"+ user.getAccount()+"账户已存在!");return resultMap;}// 设置创建时间user.setCreateTime(new Date());// 设置默认头像user.setAvatar(user.getGender() == 1 ? "images/avatar/69292338265a201591b9412c9feb6c192788f21a.jpeg" : "images/avatar/89219682b88c376bddc145ca9a9f6d66fddbbd28.jpeg");//设置密码为手机号后六位user.setPassword(MD5Util.encrypt(user.getAccount().substring(5)));//System.out.println(user.getAccount().substring(5));// 设置角色IDuser.setRoleId(3);}// 调用Service层方法将数据插入数据库userInfoService.insertUserInfoExcel(userEntities);resultMap.put("code", 0);resultMap.put("msg", "数据导入成功!");} catch (Exception e) {resultMap.put("msg", "文件不合法,导入失败!" + e.getMessage());}return resultMap;}
Service
   /** excel导入* */void insertUserInfoExcel(List<UserEntity> userEntities);
serviceImpl
/** excel导入* */@Overridepublic void insertUserInfoExcel(List<UserEntity> userEntities) {userMapper.insertUserInfoExcel(userEntities);}
mapper
  /** excel导入* @insertUserInfoExcel* */void insertUserInfoExcel(List<UserEntity> userEntities);
mapper.xml
  <!--excel导入--><insert id="insertUserInfoExcel" parameterType="java.util.List">insert into sys_user (nickname,account,email,dept_id,post_id,gender,status,password,roleId,avatar,createTime)values<foreach item="item" collection="list" separator=",">(#{item.nickname},#{item.account},#{item.email},#{item.deptId},#{item.postId},#{item.gender},#{item.status},#{item.password},#{item.roleId},#{item.avatar},#{item.createTime})</foreach></insert>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/22209.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

多语言大模型 Aya-23 开源!覆盖23种语言,性能刷新SOTA

文章目录 1. Aya-23 技术特点1.1 预训练阶段1.2 指令微调阶段 2. Aya-23 性能表现3. Aya-23 多语言任务评估4. Aya-23 支持 23 种语言5. Aya-23 应用场景 近年来&#xff0c;多语言大模型&#xff08;MLLM&#xff09;发展迅速&#xff0c;但大多数模型的性能依然存在显著差距&…

“滴滴打车,用友入账”,YonSuite商旅费控助力企业“降低成本”更进一步

在当今竞争激烈的商业环境中&#xff0c;企业对于成本控制和效率提升的需求日益迫切。特别是在商旅管理方面&#xff0c;如何有效整合资源、优化流程、降低费用&#xff0c;成为了成长型企业关注的焦点。用友YonSuite商旅费控作为用友集团旗下的重要产品&#xff0c;凭借其卓越…

ctfshow pwn17-18

毛坯的人生和精装的朋友圈 pwn17 while ( 1 ){menu();v4 0;puts("\nEnter the command you want choose:(1.2.3.4 or 5)\n");__isoc99_scanf("%d", &v4);switch ( v4 ){case 1:system("id");break;case 2:puts("Which directory?(/,…

卡尔曼滤波算法的matlab实现

卡尔曼滤波算法的matlab实现 figure; hold on;Z(1:1:100); %观测值&#xff1a;第一秒观测1m 第二秒观测两米 匀速运动, 每秒1m, 最后拟合的也是速度 1m/splot(Z); plot([0,100], [1,1]);noiserandn(1,100)*0.5; %生成方差为1的高斯噪声 ZZnoise; % 加入噪声plot(Z);X[0;…

LabVIEW动态力传感器校准系统

LabVIEW动态力传感器校准系统 开发了一种基于LabVIEW的动态力传感器校准系统。系统主要用于动态力的测量和校准&#xff0c;通过高度集成化和自动化的设计&#xff0c;显著提升校准的效率和精确度。系统采用冲击法进行动态校准&#xff0c;涵盖了完整的硬件设计和软件开发流程…

智能体应用开发:构建各类垂直领域的ai智能体应用

最近在做个类似的项目&#xff0c;有用到这方面的知识&#xff0c;顺便做一些记录和笔记吧&#xff0c;希望能帮到大家了解智能体应用开发 目录 引言 AI原生应用的兴起 智能体在AI中的角色 实现原理详解 机器学习基础 数据管理与关联数据库 数据结构 Embedding 检索方…

卫星位置解算

前言&#xff1a; 本章节代码均在Gitee中开源&#xff1a; 卫星位置计算代码https://gitee.com/Ehundred/navigation-engineering/tree/master/%E5%8D%AB%E6%98%9F%E5%AF%BC%E8%88%AA%E5%8E%9F%E7%90%86/GPS%E5%8D%AB%E6%98%9F%E4%BD%8D%E7%BD%AE%E8%A7%A3%E7%AE%97/Satellit…

心怀希望の光栅化

还记得什么是光栅化咩&#xff1f; 将三维空间的几何形体显现在屏幕上&#xff0c;这就是光栅化&#xff08;游戏、实时图形学的应用&#xff09; Perspective Projection 在正交投影里如何定义三维空间中的立方体呢&#xff1f; 用x轴的覆盖&#xff08;左、右&#xff09;…

【UML用户指南】-02-UML基本元素的介绍(二)

目录 1、语法和语义规则 2、UML中的公共机制 &#xff08;1&#xff09;规约 &#xff08;2&#xff09;修饰 &#xff08;3&#xff09;通用划分 &#xff08;4&#xff09;扩展机制 衍型/版型/类型&#xff08;stereotype&#xff09; 标记值 &#xff08;tagged val…

Java编程常见问题汇总四

系列文章目录 文章目录 系列文章目录前言一、忽略所有异常二、重复包装RuntimeException三、不正确的传播异常四、用日志记录异常五、异常处理不彻底 前言 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。…

[C/C++]_[初级]_[在Windows和macOS平台上导出动态库的一些思考]

场景 最近看了《COM本质论》里关于如何设计基于抽象基类作为二进制接口,把编译器和链接器的实现隐藏在这个二进制接口中,从而使用该DLL时不需要重新编译。在编译出C接口时,发现接口名直接是函数名,比如BindNativePort,怎么不是_BindNativePort?说明 VC++导出的函数默认是使…

Google Earth Engine精度评价方法

今天讲讲如何在GEE中做最后的精度评价。主要是因为在和许多读者或通过交流群&#xff0c;或通过私聊沟通过程中&#xff0c;发现很多人还不是很理解在GEE中分类后精度评价的问题。 在进行评价之前&#xff0c;需要明晰在GEE中精度评价分为哪几种情况。我们这里说的是两种情况。…

收藏品NFT的开发流程

开发收藏品NFT的流程涉及多个阶段&#xff0c;从概念化和设计到技术实现和市场推广。以下是详细的开发步骤&#xff0c;通过这些步骤&#xff0c;可以成功开发和发布收藏品NFT项目&#xff0c;吸引用户和投资者&#xff0c;并确保项目的持续运营和成功。北京木奇移动技术有限公…

Fiddler入门(接口抓包及APP测试)

目录 一、Fiddler基础介绍 二、Fiddler的作用 三、Fiddler安装 四、Fiddler界面功能介绍 1、界面介绍 1&#xff09;、菜单栏介绍 2&#xff09;、工具栏介绍 3&#xff09;、会话栏介绍 五、Fiddler抓取https数据 &#xff08;面试题&#xff09; 六、Fiddler…

【刷题(17)】技巧

一 技巧基础 二 136. 只出现一次的数字 1 题目 2 解题思路 哈希表map 其实看到题目数组中某个元素出现的次数也可以直接用unordered_map容器统计每一个元素出现的次数&#xff0c;然后在遍历整个map容器查看是否有元素出现的次数等于1 3 code class Solution { public:in…

商城项目【尚品汇】07分布式锁-2 Redisson篇

1 Redisson功能介绍 基于自定义setnx实现的分布式锁存在下面的问题&#xff1a; 重入问题&#xff1a;重入问题是指 获得锁的线程可以再次进入到相同的锁的代码块中&#xff0c;可重入锁的意义在于防止死锁&#xff0c;比如HashTable这样的代码中&#xff0c;他的方法都是使用…

将HTML页面中的table表格元素转换为矩形,计算出每个单元格的宽高以及左上角坐标点,输出为json数据

export function huoQuTableElement() {const tableData []; // 存储表格数据的数组let res [];// 获取到包含表格的foreignObject元素const foreignObject document.getElementById(mydctable);if (!foreignObject){return ;}// 获取到表格元素let oldTable foreignObject…

Nativefier : 将网址打包成exe桌面程序

1、需求场景 在日常开发中&#xff0c;需要针对一些网页在一体机上使用&#xff0c;同时在浏览器上也可以使用&#xff0c;这里推荐大家用nativefier&#xff0c;对网址进行打包。以下是nativefier安装命令&#xff1a; npm install nativefier -g 2、使用方法 --arch 系统 …

《混凝土坝监测仪器系列型谱》修订中监测仪器分类方案解读

随着科技的不断进步和监测需求的日益增加&#xff0c;对监测仪器分类方案进行修订已成为必然的趋势。本文旨在探讨《混凝土坝监测仪器系列型谱》中对现有仪器分类方式的修订&#xff0c;以及监测仪器选用的相关内容。希望对大家中有所帮助&#xff1a; 一、取消过时条目&#x…

java中方法引用

目录 方法引用&#xff1a; 引用静态方法 引用成员方法 引用构造方法 使用类名引用成员方法 引用数组的构造方法 练习 方法引用&#xff1a; 把已经有的方法拿过来用&#xff0c;当做函数式接口中抽象方法的方法体 在Java中&#xff0c;方法引用是一种简化Lambda表达式的…