antd本地上传excel文件并读取文件的数据转为json

1.写一个上传

这里直接用upload组件即可

javascript 复制代码
<Upload {...uploadProps} maxCount={1} accept={".xlsx"}>
                      <Button icon={<UploadOutlined />}>
                        {`${formatMessage({id: 'clk_upload'}, {file: formatMessage({id: 'excel_file'})})}`}
                      </Button>
                    </Upload>

2.写props

javascript 复制代码
const uploadProps: any = {
    onRemove: (file: any) => {
      const index = fileList.indexOf(file);
      const newFileList = fileList.slice();
      newFileList.splice(index, 1);
      setFileList(newFileList);
    },
    beforeUpload: (file: any) => {
      let reader = new FileReader();
      reader.onload = function(event: any) {
        let data = new Uint8Array(event.target.result);
        let workbook = XLSX.read(data, {type: 'array'});
        let worksheet = workbook.Sheets[workbook.SheetNames[0]];
        let jsonData = XLSX.utils.sheet_to_json(worksheet, {header: 1});
      reader.readAsArrayBuffer(file);
      setFileList(file?.name?.includes('xlsx') ? [file]: []);
      return false;
    },
    fileList
  };

beforeUpload函数里处理上传的数据转成Uint8Array,读取文件中的第一个表,使用.utils.sheet_to_json方法读出json数据,具体在进行处理即可。

相关推荐
Nick.Q14 小时前
CentOS 8 离线安装beyond compare
linux·centos
鹿鸣天涯14 小时前
openEuler学习笔记1-openEuler前世今生
linux·openeuler
pwn蒸鱼15 小时前
buuctf中的mrctf2020_shellcode
linux·安全
夕除15 小时前
java--1
linux·运维·服务器
重生之绝世牛码15 小时前
Linux软件安装 —— ClickHouse单节点安装(rpm安装、tar安装两种安装方式)
大数据·linux·运维·数据库·clickhouse·软件安装·clickhouse单节点
苏宸啊15 小时前
Linux下diy程序:进度条
linux·运维·服务器
70asunflower15 小时前
Python with 语句与上下文管理完全教程
linux·服务器·python
j_xxx404_15 小时前
Linux:调试器-gdb/cgdb使用
linux·运维·服务器
鸣弦artha16 小时前
TabBar标签页组件详解
linux·git·ubuntu
开开心心_Every16 小时前
A3试卷分割工具:免费转为A4格式可离线
游戏·随机森林·微信·pdf·excel·语音识别·最小二乘法