利用xlsx.js讀取excel文件的詳細(xì)過程
需求:讀取一個excel文件。
一、 使用antd的Upload組件的 【customRequest】方法。
互斥。此方法跟【onChange】方法互斥,即:不可同時出現(xiàn)。
調(diào)用次數(shù)不一樣。onChange方法會根據(jù)文件當(dāng)前的上傳狀態(tài)從而被調(diào)用多次(讀取中,上傳中,上傳失敗、上傳完成等)。
customRequest方法是自定義讀取和上傳的文件,因此,onChange方法的幾個狀態(tài),【customRequest】方法默認(rèn)是沒有的,因此【customRequest】方法只會被調(diào)用1次參數(shù)不一樣。onChange方法在讀取完成后,會拿到一個數(shù)據(jù)。這個數(shù)據(jù)是 antd組件處理過后的數(shù)據(jù),包含了一些讀取狀態(tài)等其他屬性。(但是也無法直接看到文件里的內(nèi)容)。
【customRequest】方法拿到的file數(shù)據(jù)是未經(jīng)處理的,無法看到文件里的數(shù)據(jù)。
二. 如何讀取文件?
- readAsBinaryString 方法:按字節(jié)讀取文件內(nèi)容,結(jié)果為文件的二進(jìn)制串。 這個結(jié)果,會作為參數(shù) 傳遞給 fileReader的 onload方法 (此方法會被逐漸廢棄。不推薦使用。)
- readAsArrayBuffer 方法:同上,結(jié)果為ArrayBuffer (推薦使用)
數(shù)據(jù)轉(zhuǎn)化過程:
- upload組件拿到的 原始的文件數(shù)據(jù)(customRequest的參數(shù)file)
- 二進(jìn)制流 or ArrayBuffer 。readAsBinaryString的方式讀取后的數(shù)據(jù)為二進(jìn)制流。readAsArrayBuffer讀取出來的數(shù)據(jù)是ArrayBuffer
- webhooks.里面是真?zhèn)€表的所有信息。
- sheet。某個子表單的數(shù)據(jù)。里面是每個單元格的信息
- sheet_to_json 方法將 sheet 轉(zhuǎn)成 對象數(shù)組
import { read as xlsxRead, utils as xlsxUtils } from 'xlsx'; // 批量導(dǎo)入 const customRequest = (files) => { const { file } = files; // step1 :創(chuàng)建一個 fileReader對象 const fileReader = new FileReader(); // step2: onload方法是 讀完數(shù)據(jù)后 調(diào)用的方法。用來對讀取后的數(shù)據(jù)進(jìn)行一些處理 fileReader.onload = (event: any) => { try { const { result } = event.target; console.log('event', event); // 1 以二進(jìn)制流方式(buffer方式)讀取得到整份excel表格對象,cellDates設(shè)為true,將讀取到的天數(shù)的時間戳轉(zhuǎn)為時間格式 const workbook = xlsxRead(result, { type: 'binary',//?????? 如果readAsArrayBuffer方法讀取文件則type:'buffer'???? cellDates: true, }); console.log('workbook', workbook); // 2 遍歷每張工作表進(jìn)行讀?。ㄟ@里默認(rèn)只讀取第一張表)Sheets是個數(shù)組 const { Sheets } = workbook; const sheet0 = Sheets[Object.keys(Sheets)[0]]; console.log('sheet0', sheet0); // 4 利用 sheet_to_json 方法將 sheet 轉(zhuǎn)成 對象數(shù)組 const fileData = xlsxUtils.sheet_to_json(sheet0) // convertToData(fileData); } catch (e) { // 這里可以拋出文件類型錯誤不正確的相關(guān)提示 message.error(formatMessage({ id: 'create_order.fileError' })); } }; // step3: 使用 readAsBinaryString、或者 readAsArrayBuffer 來讀取 文件。 fileReader.readAsBinaryString(file); };
最后
二進(jìn)制的數(shù)據(jù)流解析后。長什么樣?
ArrayBuffer長什么樣子?如下圖。
到此這篇關(guān)于利用xlsx.js讀取excel文件的文章就介紹到這了,更多相關(guān)xlsx.js讀取excel文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript如何計算數(shù)組中某值的出現(xiàn)次數(shù)
這篇文章主要介紹了javascript如何計算數(shù)組中某值的出現(xiàn)次數(shù)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01JS+CSS實現(xiàn)可拖拽的漂亮圓角特效彈出層完整實例
這篇文章主要介紹了JS+CSS實現(xiàn)可拖拽的漂亮圓角特效彈出層,以完整實例形式分析了彈出層特效及圓角矩形的實現(xiàn)技巧,需要的朋友可以參考下2015-02-02