利用xlsx.js讀取excel文件的詳細(xì)過程
需求:讀取一個(gè)excel文件。
一、 使用antd的Upload組件的 【customRequest】方法。
互斥。此方法跟【onChange】方法互斥,即:不可同時(shí)出現(xiàn)。
調(diào)用次數(shù)不一樣。onChange方法會(huì)根據(jù)文件當(dāng)前的上傳狀態(tài)從而被調(diào)用多次(讀取中,上傳中,上傳失敗、上傳完成等)。
customRequest方法是自定義讀取和上傳的文件,因此,onChange方法的幾個(gè)狀態(tài),【customRequest】方法默認(rèn)是沒有的,因此【customRequest】方法只會(huì)被調(diào)用1次參數(shù)不一樣。onChange方法在讀取完成后,會(huì)拿到一個(gè)數(shù)據(jù)。這個(gè)數(shù)據(jù)是 antd組件處理過后的數(shù)據(jù),包含了一些讀取狀態(tài)等其他屬性。(但是也無法直接看到文件里的內(nèi)容)。
【customRequest】方法拿到的file數(shù)據(jù)是未經(jīng)處理的,無法看到文件里的數(shù)據(jù)。
二. 如何讀取文件?
- readAsBinaryString 方法:按字節(jié)讀取文件內(nèi)容,結(jié)果為文件的二進(jìn)制串。 這個(gè)結(jié)果,會(huì)作為參數(shù) 傳遞給 fileReader的 onload方法 (此方法會(huì)被逐漸廢棄。不推薦使用。)
- 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。某個(gè)子表單的數(shù)據(jù)。里面是每個(gè)單元格的信息
- sheet_to_json 方法將 sheet 轉(zhuǎn)成 對(duì)象數(shù)組
import { read as xlsxRead, utils as xlsxUtils } from 'xlsx'; // 批量導(dǎo)入 const customRequest = (files) => { const { file } = files; // step1 :創(chuàng)建一個(gè) fileReader對(duì)象 const fileReader = new FileReader(); // step2: onload方法是 讀完數(shù)據(jù)后 調(diào)用的方法。用來對(duì)讀取后的數(shù)據(jù)進(jìn)行一些處理 fileReader.onload = (event: any) => { try { const { result } = event.target; console.log('event', event); // 1 以二進(jìn)制流方式(buffer方式)讀取得到整份excel表格對(duì)象,cellDates設(shè)為true,將讀取到的天數(shù)的時(shí)間戳轉(zhuǎn)為時(shí)間格式 const workbook = xlsxRead(result, { type: 'binary',//?????? 如果readAsArrayBuffer方法讀取文件則type:'buffer'???? cellDates: true, }); console.log('workbook', workbook); // 2 遍歷每張工作表進(jìn)行讀?。ㄟ@里默認(rèn)只讀取第一張表)Sheets是個(gè)數(shù)組 const { Sheets } = workbook; const sheet0 = Sheets[Object.keys(Sheets)[0]]; console.log('sheet0', sheet0); // 4 利用 sheet_to_json 方法將 sheet 轉(zhuǎn)成 對(duì)象數(shù)組 const fileData = xlsxUtils.sheet_to_json(sheet0) // convertToData(fileData); } catch (e) { // 這里可以拋出文件類型錯(cuò)誤不正確的相關(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)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS實(shí)現(xiàn)的DOM插入節(jié)點(diǎn)操作示例
這篇文章主要介紹了JS實(shí)現(xiàn)的DOM插入節(jié)點(diǎn)操作,結(jié)合實(shí)例形式分析了javascript針對(duì)頁面dom元素動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-04-04javascript 密碼強(qiáng)弱度檢測(cè)萬能插件
網(wǎng)上用的比較多的一種用來檢測(cè)用戶輸入密碼的強(qiáng)度檢測(cè),其實(shí)就是把一些常用的拼音,英文單詞, 純數(shù)字,純字母等。2009-02-02javascript如何計(jì)算數(shù)組中某值的出現(xiàn)次數(shù)
這篇文章主要介紹了javascript如何計(jì)算數(shù)組中某值的出現(xiàn)次數(shù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01JS如何讓你的移動(dòng)端交互體驗(yàn)更加優(yōu)秀
現(xiàn)在在手機(jī)等移動(dòng)端設(shè)備訪問的人越來越多,我們前端開發(fā)者一直致力于將設(shè)計(jì)稿還原成頁面,供用戶訪問。但除高度還原設(shè)計(jì)稿外,交互上的良好體驗(yàn)也是我們應(yīng)該做到的。2021-05-05JS+CSS實(shí)現(xiàn)可拖拽的漂亮圓角特效彈出層完整實(shí)例
這篇文章主要介紹了JS+CSS實(shí)現(xiàn)可拖拽的漂亮圓角特效彈出層,以完整實(shí)例形式分析了彈出層特效及圓角矩形的實(shí)現(xiàn)技巧,需要的朋友可以參考下2015-02-02