欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用xlsx.js讀取excel文件的詳細(xì)過程

 更新時(shí)間:2025年04月02日 08:26:29   作者:這個(gè)昵稱也不能用嗎?  
如果你需要在瀏覽器端處理Excel文件,那么xlsx.js可能是一個(gè)不錯(cuò)的選擇,這篇文章主要介紹了利用xlsx.js讀取excel文件的詳細(xì)過程,文中通過代碼介紹的非常詳細(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)文章

  • transport.js和jquery沖突問題的解決方法

    transport.js和jquery沖突問題的解決方法

    這篇文章主要介紹了transport.js和jquery沖突問題的解決方法,需要的朋友可以參考下
    2015-02-02
  • javascript如何定義對(duì)象數(shù)組

    javascript如何定義對(duì)象數(shù)組

    本文主要介紹javascript如何定義對(duì)象數(shù)組,兩種方法,比較實(shí)用,希望能給大家做一個(gè)參考。
    2016-06-06
  • JS實(shí)現(xiàn)的DOM插入節(jié)點(diǎ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-04
  • javascript 密碼強(qiáng)弱度檢測(cè)萬能插件

    javascript 密碼強(qiáng)弱度檢測(cè)萬能插件

    網(wǎng)上用的比較多的一種用來檢測(cè)用戶輸入密碼的強(qiáng)度檢測(cè),其實(shí)就是把一些常用的拼音,英文單詞, 純數(shù)字,純字母等。
    2009-02-02
  • JSON生成Form表單的方法示例

    JSON生成Form表單的方法示例

    JSON表單是一個(gè)基于React的抽象組件,它可以把JSON數(shù)據(jù)格式描述的表單轉(zhuǎn)換成項(xiàng)目中的表單,這篇文章主要介紹了JSON生成Form表單的方法示例,感興趣的小伙伴們可以參考一下
    2018-11-11
  • javascript如何計(jì)算數(shù)組中某值的出現(xiàn)次數(shù)

    javascript如何計(jì)算數(shù)組中某值的出現(xiàn)次數(shù)

    這篇文章主要介紹了javascript如何計(jì)算數(shù)組中某值的出現(xiàn)次數(shù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • JS如何讓你的移動(dòng)端交互體驗(yàn)更加優(yōu)秀

    JS如何讓你的移動(dòng)端交互體驗(yàn)更加優(yōu)秀

    現(xiàn)在在手機(jī)等移動(dòng)端設(shè)備訪問的人越來越多,我們前端開發(fā)者一直致力于將設(shè)計(jì)稿還原成頁面,供用戶訪問。但除高度還原設(shè)計(jì)稿外,交互上的良好體驗(yàn)也是我們應(yīng)該做到的。
    2021-05-05
  • JS+CSS實(shí)現(xiàn)可拖拽的漂亮圓角特效彈出層完整實(shí)例

    JS+CSS實(shí)現(xiàn)可拖拽的漂亮圓角特效彈出層完整實(shí)例

    這篇文章主要介紹了JS+CSS實(shí)現(xiàn)可拖拽的漂亮圓角特效彈出層,以完整實(shí)例形式分析了彈出層特效及圓角矩形的實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2015-02-02
  • 微信小程序子組件向父組件傳值的兩種方法

    微信小程序子組件向父組件傳值的兩種方法

    本文介紹了微信小程序中子組件向父組件傳值的兩種方法,這兩種方法都能有效地實(shí)現(xiàn)子組件向父組件的數(shù)據(jù)傳遞,對(duì)于開發(fā)微信小程序的開發(fā)者來說,掌握這些技巧非常重要,感興趣的朋友跟隨小編一起看看吧
    2024-09-09
  • JS在數(shù)組頭部添加元素的3種方法

    JS在數(shù)組頭部添加元素的3種方法

    JS數(shù)組是一種特殊的對(duì)象,JS沒有真正的數(shù)組,只是用對(duì)象模擬數(shù)組,下面這篇文章主要給大家介紹了關(guān)于JS在數(shù)組頭部添加元素的3種方法,需要的朋友可以參考下
    2023-10-10

最新評(píng)論