亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

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

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

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

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

    本文主要介紹javascript如何定義對象數(shù)組,兩種方法,比較實用,希望能給大家做一個參考。
    2016-06-06
  • JS實現(xiàn)的DOM插入節(jié)點操作示例

    JS實現(xiàn)的DOM插入節(jié)點操作示例

    這篇文章主要介紹了JS實現(xiàn)的DOM插入節(jié)點操作,結(jié)合實例形式分析了javascript針對頁面dom元素動態(tài)操作相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2018-04-04
  • javascript 密碼強(qiáng)弱度檢測萬能插件

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

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

    JSON生成Form表單的方法示例

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

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

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

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

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

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

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

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

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

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

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

最新評論