React 全面解析excel文件
更新时间:2022年09月15日 09:31:34 作者:摸鱼第一人
这篇文章主要介绍了React 全面解析excel文件,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
React解析excel文件
首先安装安装xlsx插件
yarn add xlsx
使用xlsx解析
/** * 上传文件并解析成json */ const HandleImportFile = (info) => { let files = info.file; // 获取文件名称 let name = files.name // 获取文件后缀 let suffix = name.substr(name.lastIndexOf(".")); let reader = new FileReader(); reader.onload = (event) => { try { // 判断文件类型是否正确 if (".xls" != suffix && ".xlsx" != suffix) { message.error("选择Excel格式的文件导入!"); return false; } let { result } = event.target; // 读取文件 let workbook = XLSX.read(result, { type: 'binary' }); let data = []; // 循环文件中的每个表 for (let sheet in workbook.Sheets) { if (workbook.Sheets.hasOwnProperty(sheet)) { // 将获取到表中的数据转化为json格式 data = data.concat(XLSX.utils.sheet_to_json(workbook.Sheets[sheet])); } } console.log('data:', data); } catch (e) { message.error('文件类型不正确!'); } } reader.readAsBinaryString(files); setIsLoading(false); }
使用antd的Upload组件上传文件
<Upload accept=".xls , .xlsx" maxCount={1} showUploadList={false} customRequest={HandleImportFile} > <Button icon={<UploadOutlined />} type="primary">上传文件</Button> </Upload>
React上传excel预览
import React from 'react'; import * as XLSX from 'xlsx'; import {message, Table, Upload} from 'antd'; const { Dragger } = Upload; export class UploadFile extends React.Component { state = { tableData: [], tableHeader: [] }; toReturn = () => { this.props.close(); }; toSubmit = () => { const _this = this; console.log(_this.state.tableData); }; render() { return ( <div> <Dragger name="file" accept=".xls,.xlsx" maxCount={1} beforeUpload={function () { return false; }} onChange={this.uploadFilesChange.bind(this)} showUploadList={false}> <p className="ant-upload-text"> <span>点击上传文件</span> 或者拖拽上传 </p> </Dragger> <Table columns={this.state.tableHeader} dataSource={this.state.tableData} style={{marginTop: '20px'}} pagination={false} /> </div> ); } uploadFilesChange(file) { // 通过FileReader对象读取文件 const fileReader = new FileReader(); // 以二进制方式打开文件 fileReader.readAsBinaryString(file.file); fileReader.onload = event => { try { const {result} = event.target; // 以二进制流方式读取得到整份excel表格对象 const workbook = XLSX.read(result, {type: 'binary'}); // 存储获取到的数据 let data = {}; // 遍历每张工作表进行读取(这里默认只读取第一张表) for(const sheet in workbook.Sheets) { let tempData = []; // esline-disable-next-line if(workbook.Sheets.hasOwnProperty(sheet)) { // 利用 sheet_to_json 方法将 excel 转成 json 数据 console.log(sheet); data[sheet] = tempData.concat(XLSX.utils.sheet_to_json(workbook.Sheets[sheet])); } } const excelData = data.Sheet1; const excelHeader = []; // 获取表头 for(const headerAttr in excelData[0]) { const header = { title: headerAttr, dataIndex: headerAttr, key: headerAttr }; excelHeader.push(header); } // 最终获取到并且格式化后的 json 数据 this.setState({ tableData: excelData, tableHeader: excelHeader, }); console.log(this.state); } catch(e) { // 这里可以抛出文件类型错误不正确的相关提示 console.log(e); message.error('文件类型不正确!'); } }; } } export default UploadFile;
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
利用React Router4实现的服务端直出渲染(SSR)
这篇文章主要介绍了利用React Router4实现的服务端直出渲染(SSR),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2019-01-01ReactHooks批量更新state及获取路由参数示例解析
这篇文章主要介绍了React Hooks如何实现批量更新state以及获取路由参数的示例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助2021-10-10基于Cloud Studio构建React完成点餐H5页面(腾讯云 Cloud Studio 实战训练营)
最近也是有机会参与到了腾讯云举办的腾讯云Cloud Studio实战训练营,借此了解了腾讯云Cloud Studio产品,下面就来使用腾讯云Cloud Studio做一个实战案例来深入了解该产品的优越性吧,感兴趣的朋友跟随小编一起看看吧2023-08-08
最新评论