vue项目如何利用xlsx组件,读取复杂表格的数据

直接上代码

一、封装的工具类

  // 表格文件转json
  xlsxToJson(file) {
    return new Promise((resolve, reject) => {
      const XLSX = require("xlsx");
      const fileReader = new FileReader();
      fileReader.onload = e => {
        try {
          const data = e.target.result; // 获取的数据
          const workBook = XLSX.read(data, { type: 'binary' }) // data转xlsx数据对象
          let sheetNames = workBook.SheetNames || []
          let sheetDatas = workBook.Sheets || []
          let datas = sheetDatas[sheetNames[0]];
          let result = XLSX.utils.sheet_to_json(datas, { range: 2, defval: ' ' });// range: 2代表从第几行开始读取,defval是为空属性设置默认值
          resolve(result);
        } catch (error) {
          reject(error)
          Toast(error);
        }
      }
      fileReader.readAsBinaryString(file);
    })
  },

二、界面调用

import Utils from "../../../src/plugins/utils";
 // 导入文件,选中文件后的回调  界面接上一篇文章
    onFileChanged(e) {
      let that = this;
      this.cardList = [];
      let files = e.target.files || [];
      let file;
      if (files.length > 0) {
        file = files[0];
      } else {
        Toast("请选择导入内容!");
        return;
      }
      if (file && file.name.match(/xls|xlsx/)) {
        Utils.xlsxToJson(file)
          .then((res) => {
            for (let i = 0; i < res.length; i++) {
              let cardObj = {};
              let item = res[i];
              cardObj.xm = item["姓名"];
              cardObj.bm = item["部门"];
              cardObj.gh = item["工号"];
              cardObj.zw = item["职位"];
              that.cardList.push(cardObj);
            }
            console.log("打卡数据:", that.cardList);
            that.upCardData(that.cardList);
          })
          .catch(() => {
            Toast.fail("导入信息失败!");
          })
          .finally(() => {
            e.target.value = "";
          });
      } else {
        Toast.fail("请选择正确的模板!");
        return;
      }
    },

上一篇文章

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值