js读取上传的excel的内容

js读取上传的excel的内容

  1. 安装
npm i js-xlsx xlsx  xlsx-style   --save

封装在util中

import XLSX from "js-xlsx";

export const readfileByExcel = async (file) => {
  return new Promise((resolve, reject) => {
    var fileReader = new FileReader();
    fileReader.onload = function(ev) {
      let workbook;
      let persons = []; // 存储获取到的数据
      try {
        var data = ev.target.result;
        workbook = XLSX.read(data, {
          type: "binary" // 以二进制流方式读取得到整份excel表格对象
        });
      } catch (e) {
        reject(e)
        return;
      }

      // 遍历每张表读取
      for (var sheet in workbook.Sheets) {
        if (workbook.Sheets.hasOwnProperty(sheet)) {
          persons = persons.concat(
            XLSX.utils.sheet_to_json(workbook.Sheets[sheet])
          );
          // break; // 如果只取第一张表,就取消注释这行
        }
      }
      resolve(persons);
    };

    // 以二进制方式打开文件
    fileReader.readAsBinaryString(file);
  });
};

使用

<script>
import {readfileByExcel} from "@/util/common"

readfileByExcel(file).then((res) => {
        console.log(res);
      })
</script>
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值