需求如下:

前端拿到表格中的数据,对数据做以下判断,并将拿到的数据转换成以下json格式,传给后端。

具体实现:

  1. 下载npm包:npm install xlsx --save
  2. 在vue文件中引入依赖:import XLSX from "xlsx"
  3. 使用iviewui中的上传组件:
          <Upload class="row-mgr"
    :before-upload="handleUpload" accept=".xls" :show-upload-list="false"
    action="">
    <Button icon="ios-cloud-upload-outline">批量导入</Button>
    </Upload>
  4. js解析文件及对解析的数据进行处理:
        <script>
    import XLSX from "xlsx"
    export default {
    name: "deviceImport",
    props: ['deviceTypes'],
    data() {
    return {
    deviceTypesArry: []
    }
    },
    computed: {},
    methods: {
    // 获取excel第一行的内容获取表头
    getList1(wb){
    let wbData = wb.Sheets[wb.SheetNames[0]]; // 读取的excel单元格内容
    let re = /^[A-Z]1$/; // 匹配excel第一行的内容
    let arr1 = [];
    for (let key in wbData) { // excel第一行内容赋值给数组
    if (wbData.hasOwnProperty(key)) {
    if (re.test(key)) {
    arr1.push(wbData[key].w);
    }
    }
    }
    return arr1;
    },
    // 增加对应字段空白内容
    AddXlsxData(xlsxData, list1){
    let addData = null; // 空白字段替换值
    console.log(xlsxData)
    for (let i = 0; i < xlsxData.length; i++) { // 要被JSON的数组
    for (let j = 0; j < list1.length; j++) { // excel第一行内容
    if (!xlsxData[i][list1[j]]) {
    xlsxData[i][list1[j]] = addData;
    }
    }
    }
    return xlsxData;
    },
    handleUpload (file) {
    this.file = file;
    let fileend = file.name.substring(file.name.lastIndexOf("."))
    let isExcel = (fileend === '.xls' || file.type === 'application/vnd.ms-excel')
    if (!isExcel) {
    this.$Message.error('您只能上传.xls格式的文件!')
    return
    }
    const fileReader = new FileReader()
    fileReader.onload = (ev) => {
    try {
    const data = ev.target.result
    const workbook = XLSX.read(data, {
    type: 'binary' // 以字符编码的方式解析
    })
    const exlname = workbook.SheetNames[0] // 取第一张表
    let exl = XLSX.utils.sheet_to_json(workbook.Sheets[exlname]) // 生成json表格内容 const list1 = this.getList1(workbook);
    // debugger
    exl = this.AddXlsxData(exl, list1);
    const name_null = exl.filter(function (item) {
    if ((!item.name || item.name == '')||(!item.type || item.type == '')) {
    return item
    }
    })
    if(name_null.length!==0){
    this.$Message.error('name和type都不能为空,请检查表格内的数据')
    return
    }
    const _type = exl.filter((item) => {
    if (this.deviceTypesArry.indexOf(item.type) != -1) {
    return item
    }
    })
    //deviceTypes 判断表格中的 type必须包含在系统中的type(左上角下拉框)不能随便填
    if (_type.length !== exl.length) {
    this.$Message.error('type的值必须是包含在系统中的type,请检查表格内的数据')
    return
    }
    const jsonPrams = exl.map(item => {
    const obj = {
    name: item.name,
    type: item.type,
    label: item.label,
    token: item.token,
    additionalInfo: {
    gateway: item.gateway == true || item.gateway == 'TRUE' ? true : false,
    description: item.description
    }
    }
    return obj
    })
    console.log(jsonPrams)
    } catch (e) {
    console.log('出错了::')
    return false
    }
    }
    fileReader.readAsBinaryString(file)
    return isExcel;
    }, },
    mounted: function () {
    //先提取 deviceTypes中所有的type值
    this.deviceTypesArry = this.deviceTypes.map(item => {
    return item.type
    })
    }
    }
    </script>

    打印结果:

前端解析excel表格的更多相关文章

  1. 使用PHPExcel解析Excel表格

    安装类库 从GitHub上下载PHPExcel类库 地址:https://github.com/PHPOffice/PHPExcel 解压后将Classes文件夹移动到ThinkPHP的extend目 ...

  2. JXL解析Excel表格内容到数据库

    java中常用的解析Excel表格的工具一种是POI一种是JXL,POI功能强大,相比JXL稍嫌复杂,对表格样式的处理非常好:而JXL解析简单方便,对中文支持比较好. 工作中解析Excel内容上传到数 ...

  3. H5纯前端生成Excel表格

    H5纯前端生成Excel表格方法如下: <!DOCTYPE html> <html> <head> <title></title> < ...

  4. Java使用POI解析Excel表格

    概述 Excel表格是常用的数据存储工具,项目中经常会遇到导入Excel和导出Excel的功能. 常见的Excel格式有xls和xlsx.07版本以后主要以基于XML的压缩格式作为默认文件格式xlsx ...

  5. AngularJS之前端解析excel文件

    之前发现一款比较强大的js解析excel插件SheetJS js-xlsx,一直未投入到生产中使用.最近有批量导入的需求,大致看了下文档,使用比较方便快捷,容易上手,现在以AngularJS为例,介绍 ...

  6. java后台读取/解析 excel表格

    需求描述 前台需要上传excel表格,提交到后台,后台解析并返回给前台,展示在前台页面上! 前台部分代码与界面 <th style="padding: 7px 1px;width:15 ...

  7. vue 纯前端导出 excel 表格

    在开发后台管理系统的时候,很多地方都要用到导出excel 表格,比如将table中的数据导出到本地,那么实现这种需求往往有两种方案: 一.后端开发一个下载链接,前端将这个链接放到 a 标签的 href ...

  8. 前端导出excel表格

    前言近期项目有个新需求--将折线图表的数据加一个下载成excel表格的功能.以前下载功能都是调后台接口的,但是这个迭代,后台压力比较重,部分就交给了前端自己实现,下面就记录一下前端如何实现excel表 ...

  9. vue 利用xlsx、xlsx-style、file-saver实现前端导出excel表格 (包括设置单元格居中、边框等样式) antdesignvue、elementui、vxetable 等都适用

    我用的方法是在表格的根组件外层赋一个div用来导出整个表格,所以antdesignvue.elementui.vxetable 或者原生的table写法应该全都适用,此处我用的框架为antdesign ...

  10. php解析Excel表格并且导入MySQL数据库

    最近根据客户需求,需要增加一个导入Excel表格的功能,Excel中存放的是知识库中医知识的分类体系目录.是在thinkphp框架下编写的代码,用的是phpexcel第三方包.测试环境用的是xampp ...

随机推荐

  1. 熟悉又陌生的package.json

    前言 随着前端的不断发展,package.json可谓是在前端项目中无处不在,它不仅在项目根目录会有,而且在 node_modules 中也存在.那么这个文件到底是干嘛的,又有什么作用?很多人对它的认 ...

  2. 从零开始实现放置游戏(十七)——完结篇(附DEMO地址)

    大家好,时隔2年多,我来填坑啦! 之前用的技术.设计思路都不成熟,所以直接干掉重做了. 由于从头教学实在太啰嗦,精力也有限,咱们还是直接上源码吧. DEMO地址: http://212.129.154 ...

  3. C#利用Refit实现JWT自动续期

    前言 笔者之前开发过一套C/S架构的桌面应用,采用了JWT作为用户的登录认证和授权.遇到的唯一问题就是JWT过期了该怎么办?设想当一个用户正在进行业务操作,突然因为Token过期失效,莫名其妙地跳转到 ...

  4. 【译】Silverlight 不会消亡 XAML for Blazor 到来

    Userware 正在使用早已消失的.令人怀念的微软 Silverlight Web 开发平台的遗留来支持其新的"XAML for Blazor"产品,该产品允许 .NET 开发人 ...

  5. 一文了解Gin对Cookie的支持

    1. 引言 本文将从Web应用程序处理请求时需要用户信息,同时HTTP又是无状态协议这个矛盾点出发.从该问题出发,简单描述了解决该问题的Token 机制,进而引出Cookie的实现方案. 基于此我们将 ...

  6. JAVA-Springboot实践项目-用户注册

    Smiling & Weeping ----我本没喜欢的人, 见你的次数多了, 也就有了. 1.创建数据表 1.1.选中数据表: use store 1.2.创建t_user表: 2创建用户实 ...

  7. 每日一库:lumberjack -- 日志轮换和管理

    在开发应用程序时,记录日志是一项关键的任务,以便在应用程序运行时追踪问题.监视性能和保留审计记录.Go 语言提供了灵活且强大的日志记录功能,可以通过多种方式配置和使用.其中一个常用的日志记录库是 gi ...

  8. xxl-job初学转载,不断更新

    参考:https://blog.csdn.net/xhmico/article/details/122324950 官网与源码下载地址 官网:https://www.xuxueli.com/xxl-j ...

  9. 研发效能|DevOps 是运维还是开发?

    DevOps 到底是 Dev还是Ops?答:属于研发工程师序列,偏向研发域,而不是运维域. DevOps是研发工程师 DevOps 主要服务的对象就是所有产研团队的人员,与产研团队打交道比较多,相互配 ...

  10. golang Context应用举例

    Context本质 golang标准库里Context实际上是一个接口(即一种编程规范. 一种约定). type Context interface { Deadline() (deadline ti ...