vue读取本机的excel文件的两种方式

news/2024/4/30 16:08:05/文章来源:https://blog.csdn.net/qq_26599807/article/details/127281864

安装依赖

npm install xlsx --save

引入

import XLSX from ‘xlsx’

更新:2022-04-26
最新的xlsx依赖包引入方式改变,以前的直接引入失败了,切换成以下依赖方式:

import { read, utils } from 'xlsx'

如果有使用elementUI,个人建议使用第二种:直达

第一种:input通常方式

template中加入input

<input type="file" ref="upload" accept=".xls,.xlsx" class="outputlist_upload">

data中声明变量

data() {return {outputs: []}
},

mounted中绑定事件

 mounted() {this.$refs.upload.addEventListener('change', e => {//绑定监听表格导入事件this.readExcel(e);})},
readExcel(e) {var that = this;const files = e.target.files;// 如果没有文件名if(files.length<=0){return false;}else if(!/\.(xls|xlsx)$/.test(files[0].name.toLowerCase())){this.$Message.error('上传格式不正确,请上传xls或者xlsx格式');return false;}const fileReader = new FileReader();fileReader.onload = (ev) => {try {const data = ev.target.result;// 切换为新的调用方式const workbook = read(data, {type: 'binary'});// 取第一张表const wsname = workbook.SheetNames[0];// 切换为新的调用方式 生成json表格内容const ws = utils.sheet_to_json(workbook.Sheets[wsname]);console.log(ws);// 后续为自己对ws数据的处理} catch (e) {return false;}};fileReader.readAsBinaryString(files[0]);
}

第二种:结合element UI 的upload控件实现读取文件并生成数组

PS:以前使用的是element的on-change监听,但是会触发两次读取,因此改成before-upload,只会触发一次读取


<el-upload ref="excel_upload" action="#" :auto-upload="true" :multiple="false":drag="true" :show-file-list="false" :before-upload="upload" accept=".xlsx,.xls"><span class="c_bbb">拖拽excel文件到这或</span><el-button size="mini" type="text">打开</el-button>
</el-upload>

upload绑定函数

upload(file,fileList){console.log("file",file);console.log("fileList",fileList);let files = {0: file}this.readExcel1(files);return false; //false表示不需要上传~
}

readExcel1主函数

// 表格导入
readExcel1(files) {var that = this;console.log(files);// 此处判断不严谨,思路只是根据传入的参数校验数据的完整性,可根据自己需求修改// 如果没有文件名if(files.length <= 0){return;}if(!/\.(xls|xlsx)$/.test(files[0].name.toLowerCase())){this.$Message.error('上传格式不正确,请上传xls或者xlsx格式');return;}const fileReader = new FileReader();fileReader.onload = (ev) => {try {const data = ev.target.result;const workbook = read(data, {type: 'binary'});// 取第一张表const wsname = workbook.SheetNames[0];// 生成json表格内容const ws = utils.sheet_to_json(workbook.Sheets[wsname]);console.log(ws);// 后续为自己对ws数据的处理} catch (e) {return false;}};fileReader.readAsBinaryString(files[0]);
},



文章背景:

最近在做一个vue读取本机的excel文件的两种方式的需求,即本地浏览器将用户上传的excel文件解析出来并展示给用户查看,再调用接口保存到数据库。

1、表格:
在这里插入图片描述

2、预览页面
在这里插入图片描述

不需要用户选中再导入的需求时,可以更快捷的技巧:

1.为数据记录一个importDataIndex,当读取数据时,赋值为0
2.点击一键导入时,从importDataIndex开始,到数据长度length的数据,都要一条一条保存,并且importDataIndex要随之累加
3.记得判断importDataIndex是否超过了集合大小,如果是,表示已经全部导入完成了。

最后:

本文参考并部分摘抄于[墨色梧桐]的文章:https://blog.csdn.net/liyi_mowu/article/details/84768140

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

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

相关文章

JavaScript基础万字总结---重点

目录JavaScript简介什么是JavaScript浏览器执行JS过程JS的组成JS的引入方式函数与作用域arguments的使用全局变量与局部变量预解析对象创建对象的三种方式1.利用字面量创建对象2.利用 new Object 创建对象3.利用构造函数创建对象遍历对象属性变量、属性、函数、方法总结new关键…

0053 Exception异常

/*异常Java语言中&#xff0c;将程序执行中发生的不正常情况称为"异常"。&#xff08;语法错误和逻辑错误不是异常&#xff09;执行过程中所发生的异常可分为两类1.Error&#xff1a;Java虚拟机无法解决的严重问题&#xff0c;程序会崩溃如&#xff1a;JVM系统内部错…

如何免费使用GPU进行加速?(两种方法)

文章目录如何使用免费的GPU?Kaggle使用免费GPUGoogle Colab 使用免费GPU小结如何使用免费的GPU? 我是学生党&#xff0c;最近在学习深度学习&#xff0c;需要用到GPU加速&#xff0c;现分享两个免费使用GPU的方法。 1、使用 Kaggle 的免费GPU&#xff0c;Kaggle每周可以赠送…

Android 最全Ignore文件 : 解决部分不必要文件上传到Git的问题

1. 背景 我们新建一个Android项目&#xff0c;默认会生成一个.ignore文件 *.iml .gradle /local.properties /.idea/caches /.idea/libraries /.idea/modules.xml /.idea/workspace.xml /.idea/navEditor.xml /.idea/assetWizardSettings.xml .DS_Store /build /captures .ex…

简单了解一下C语言main函数的参数

目录 一、main函数的参数 argc 和 argv 运行效果 需要注意的两个个点 一、main函数的参数 main函数有三个参数&#xff0c;argc、argv和envp&#xff0c;envp参数的应用场景不多&#xff0c;这里就不多介绍&#xff0c;感兴趣的可以自己去了解一下 它的标准写法如下&#x…

<初识Python及编程环境搭建>——《Python》

目录 1. Python 的背景知识&#xff1a; 2. Python 的用途&#xff1a; 3. Python 的优缺点 &#xff1a; 4. 搭建 Python 编程环境&#xff1a; 4.1 安装 Python (1) 找到官方网站 (2) 找到下载页面 (3) 双击安装包 (4) 运行 hello world 4.2 安装 PyCharm 后记&a…

tensorflow多层感知机+mnist数据集

这里写目录标题keras与tensorflow建立模型的不同加载mnisttensorflow多层感知机构建全连接层函数定义感知机各层的输入和输出损失函数、优化器模型准确率计算模型训练参数定义训练开始模型训练效果可视化模型评分利用模型进行预测显示混淆矩阵keras与tensorflow建立模型的不同 …

两栏布局与三栏布局(圣杯布局与双飞翼布局)

两栏布局 右侧绝对定位的写法 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta http-equiv"X-UA-Compatible" content"IEedge" /><meta name"viewport" content&qu…

浅析某城商行手机银行水平授权漏洞问题

-问题现象描述 据报道&#xff0c;某黑客通过软件抓包、PS身份证等非法手段&#xff0c;在某城商行手机银行APP内使用虚假身份信息注册银行Ⅱ、Ⅲ类账户。 其操作方法具体来说&#xff0c;是在注册账户过程中&#xff0c;先输入本人身份信息&#xff0c;待进行人脸识别步骤时…

Flask学习笔记(十二)-Flask-Migrate实现数据库迁移详解

一、定义flask-migrate是基于Alembic的一个封装,并集成到Flask中 所有的迁移操作其实都是Alembic做的,能跟踪模型的变化,并将变化映射到数据库中。二、Flask-Migrate安装pip install flask-migrate三、使用Flask-Migrate步骤  实例展示: 目录结构:  flask_SQLalchemy:. …

MindSpore体验--在Windows10中源码安装

MindSpore体验--在Windows10中源码安装&#xff08;反面教材&#xff09; 一直以来安装包都是直接pip intall&#xff0c;发现安装MindSpore的操作流程中教学了源码编译安装&#xff0c;借此学习一下使用源码安装。 环境创建 为了方便管理环境&#xff0c;此处我新创建了一个…

多测师肖sir_高级讲师_第2个月第27讲解jmeter性能测试jmeter性能实战

jmeter性能实战 一、单接口性能测试 1、先建接口cms 登录接口 2、在监听器中添加聚合报告 3、设置线程组 &#xff08;1&#xff09;线程组&#xff1a;一个线程组中有若干个请求 &#xff08;2&#xff09;线程 &#xff1a;一个虚拟用户就是一个线程 &#xff08;3&#…

webpack的一些常用打包配置

1.webpack 是什么&#xff1f; webpack 是一个模块化打包工具 2.模块是什么&#xff1f; 模块我理解就是 import xx 后面导入的文件就是一个模块 它可以是js css 图片 等等 3&#xff0c;webpack的配置文件的作用&#xff1f; 就是根据需求自定义配置webpack webpack默认只能打…

轻轻松松搞定分布式Token校验

文章目录前言token存储Token 存储实体login 业务代码枚举类修改存储效果客户端存储token验证前端提交后端校验自定义注解切面处理使用总结前言 没想到前天小水了一篇博文&#xff0c;竟然就火了&#xff1f;&#xff01;&#xff01;既然如此&#xff0c;那我再来一篇&#xf…

第7章 单行函数

1.函数的理解 *函数可以把我们经常使用的代码封装起来&#xff0c;需要的时候直接调用即可。这样既提高了代码效率&#xff0c;又提高了可维护性。在SQL中我们也可以使用函数对检索出来的数据进行函数操作。使用这些函数&#xff0c;可以极大地提高用户对数据库的管理效率。 …

微信小程序|基于小程序实现打卡功能

文章目录一、文章前言二、开发流程及准备三、开发步骤一、文章前言 此文主要在小程序内实现打卡功能&#xff0c;可根据用户位置与公司设定的打卡范围实时判断打卡场景。 二、开发流程及准备 2.1、注册微信公众平台账号。 2.2、准备腾讯地图用户Key。 三、开发步骤 3.1、访问…

【面试题常考!!!】JZ39 数组中出现次数超过一半的数字【五种方法解决】

欢迎观看我的博客&#xff0c;如有问题交流&#xff0c;欢迎评论区留言&#xff0c;一定尽快回复&#xff01;&#xff08;大家可以去看我的专栏&#xff0c;是所有文章的目录&#xff09; 字体风格&#xff1a; 红色文字表示&#xff1a;重难点 蓝色文字表示&#xff1a;思路以…

神经网络模型数据处理,神经网络模型参数辨识

1、有哪些深度神经网络模型&#xff1f; 目前经常使用的深度神经网络模型主要有卷积神经网络(CNN) 、递归神经网络(RNN)、深信度网络(DBN) 、深度自动编码器(AutoEncoder) 和生成对抗网络(GAN) 等。 递归神经网络实际.上包含了两种神经网络。一种是循环神经网络(Recurrent Neu…

STM32F4单片机读取AT24c02

​STM32F4是由ST&#xff08;意法半导体&#xff09;开发的一种高性能微控制器系列。其采用了90nm的NVM工艺和ART技术&#xff08;自适应实时存储加速器&#xff0c;Adaptive Real-Time MemoryAccelerator™&#xff09; AT24C02是Atmel公司出品的一个2K位串行CMOS E2PROM&…

【k8s】五、Pod生命周期(一)

目录 前言 Pod生命周期 Pod 相位 状态值 挂起&#xff08;Pending&#xff09; 运行中&#xff08;Running&#xff09; 成功&#xff08;Succeeded&#xff09; 失败&#xff08;Failed&#xff09; 未知&#xff08;Unknown&#xff09; Init Containers Init Cont…