使用JavaScript讀取Excel文件

一、js讀取excel文件指定單元格

當我們使用JavaScript讀取Excel文件時,有時候需要讀取特定的單元格。可以使用以下代碼實現:

  let workbook = XLSX.read(data, { type: "binary" }); // data為Excel文件的二進位流
  let worksheet = workbook.Sheets[sheetName]; // sheetName為需要讀取的工作表名
  let cellValue = worksheet[address].v; // address為需要讀取的單元格地址

其中,worksheet[address].v代表單元格的值,v為Excel文件中每個單元格的屬性。更多的單元格屬性可以在worksheet[address]中找到。

二、js讀取excel文件日期格式錯誤

讀取Excel文件時,日期格式可能會出現錯誤,例如美國的日期格式為:月/日/年,而歐洲的日期格式為:日/月/年。可以使用以下代碼強制將日期轉換為合適的格式:

  let workbook = XLSX.read(data, { type: "binary", dateNF:"MM-DD-YYYY" }); // dateNF屬性允許設置日期的格式
  let worksheet = workbook.Sheets[sheetName];

其中,"MM-DD-YYYY"為合適的日期格式。此外,還可以使用"YYYY-MM-DD"或其他日期格式。

三、js讀取excel文件chrome

在使用Chrome瀏覽器時,可能會出現文件跨域的問題。可以在Chrome瀏覽器中,安裝一個插件如「Allow-Control-Allow-Origin: *」,就可以解決文件跨域問題。

四、js讀取excel文件內容

讀取Excel文件的內容非常簡單,只需要使用以下代碼:

  let workbook = XLSX.read(data, { type: "binary" });
  let worksheet = workbook.Sheets[sheetName];
  let jsonData = XLSX.utils.sheet_to_json(worksheet);

其中,jsonData為讀取到的Excel文件內容。可以使用console.log(jsonData)來列印讀取到的文件內容。

五、js讀取excel文件中的數據

讀取Excel文件中的數據非常方便,只需使用以下代碼即可:

  let workbook = XLSX.read(data, { type: "binary" });
  let worksheet = workbook.Sheets[sheetName];
  let range = worksheet["!ref"]; // 獲取數據範圍
  let rows = XLSX.utils.decode_range(range).e.r - XLSX.utils.decode_range(range).s.r + 1; // 獲取數據行數
  let cols = XLSX.utils.decode_range(range).e.c - XLSX.utils.decode_range(range).s.c + 1; // 獲取數據列數
  let data = new Array(rows); // 定義一個數組
  for(let i = 0; i < rows; i++) {
    data[i] = new Array(cols);
    for(let j = 0; j < cols; j++) {
      let cellAddress = XLSX.utils.encode_cell({ r: i + XLSX.utils.decode_range(range).s.r, c: j + XLSX.utils.decode_range(range).s.c });
      if(!worksheet[cellAddress]) continue; // 跳過沒有數據的單元格
      data[i][j] = worksheet[cellAddress].v; // 賦值操作
    }
  }

其中,data為讀取到的Excel文件中的數據。可以使用console.log(data)來列印讀取到的數據。

六、spss讀取excel文件

讀取SPSS文件格式的Excel文件,可以將Excel文件轉換為CSV文件。轉換代碼如下:

  let workbook = XLSX.read(data, { type: "binary" });
  let worksheet = workbook.Sheets[sheetName];
  let csvData = XLSX.utils.sheet_to_csv(worksheet);

其中,csvData為轉換後的CSV文件內容,可以使用console.log(csvData)列印出來。

七、js讀取excel文件時間格式錯誤

在讀取Excel文件的時間格式時,有時候會出現錯誤。可以使用以下代碼解決這個問題:

  let workbook = XLSX.read(data, { type: "binary", cellDates:true });
  let worksheet = workbook.Sheets[sheetName];
  let jsonData = XLSX.utils.sheet_to_json(worksheet);
  let dateString = XLSX.SSF.format("YYYY年MM月DD日 hh:mm:ss", jsonData[0].date); // date為讀取到的數據的date格式

其中,XLSX.SSF.format可以將日期轉換為需要的日期格式,"YYYY年MM月DD日 hh:mm:ss"為轉換後的格式。

八、js讀取excel文件20w

讀取Excel文件中的大量數據為實現非常重要的功能。可以使用以下代碼大大提高讀取Excel文件的效率:

  let workbook = XLSX.read(data, { type: "binary" });
  let worksheet = workbook.Sheets[sheetName];
  let range = worksheet["!ref"];
  let rows = XLSX.utils.decode_range(range).e.r - XLSX.utils.decode_range(range).s.r + 1;
  let cols = XLSX.utils.decode_range(range).e.c - XLSX.utils.decode_range(range).s.c + 1;
  let data = new Array(rows);
  for(let i = 0; i < rows; i++) {
    data[i] = new Array(cols);
  }
  for(let i = XLSX.utils.decode_range(range).s.r; i <= XLSX.utils.decode_range(range).e.r; i++) {
    for(let j = XLSX.utils.decode_range(range).s.c; j <= XLSX.utils.decode_range(range).e.c; j++) {
      let cellAddress = XLSX.utils.encode_cell({ r: i, c: j });
      if(!worksheet[cellAddress]) continue;
      data[i][j] = worksheet[cellAddress].v;
    }
  }

以上方法區別在於,前一個方法需要對所有單元格進行遍歷,並且單元格為undefined時需要進行判斷,遍歷時間複雜度較高;後一個方法只遍歷有數據的單元格,大大提高讀取Excel文件的效率。

九、js讀取excel文件數據頁面顯示

在讀取Excel文件中的數據後,可以在頁面上顯示出來。可以使用以下代碼實現:

  let workbook = XLSX.read(data, { type: "binary" });
  let worksheet = workbook.Sheets[sheetName];
  let jsonData = XLSX.utils.sheet_to_json(worksheet);
  let output = document.getElementById("output");
  let html = "";
  /* 構建表頭 */
  html += "";
  for(let key in jsonData[0]) {
    html += "";
  }
  html += "";
  /* 構建表格內容 */
  html += "";
  for(let i = 0; i < jsonData.length; i++) {
    html += "";
    for(let key in jsonData[i]) {
      html += ""
    }
    html += "";
  }
  html += "";
  html += "
" + key + "
" + jsonData[i][key] + "
"; output.innerHTML = html;

其中,output為指定顯示Excel文件數據的頁面位置,可以根據需要進行指定。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/291043.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-24 13:13
下一篇 2024-12-24 13:13

相關推薦

  • vue下載無後綴名的文件被加上後綴.txt,有後綴名的文件下載正常問題的解決

    本文旨在解決vue下載無後綴名的文件被加上後綴.txt,有後綴名的文件下載正常的問題,提供完整的代碼示例供參考。 一、分析問題 首先,需了解vue中下載文件的情況。一般情況下,我們…

    編程 2025-04-29
  • 如何在Java中拼接OBJ格式的文件並生成完整的圖像

    OBJ格式是一種用於表示3D對象的標準格式,通常由一組頂點、面和紋理映射坐標組成。在本文中,我們將討論如何將多個OBJ文件拼接在一起,生成一個完整的3D模型。 一、讀取OBJ文件 …

    編程 2025-04-29
  • Python程序文件的拓展

    Python是一門功能豐富、易於學習、可讀性高的編程語言。Python程序文件通常以.py為文件拓展名,被廣泛應用於各種領域,包括Web開發、機器學習、科學計算等。為了更好地發揮P…

    編程 2025-04-29
  • 為什麼用cmd運行Java時需要在文件內打開cmd為中心

    在Java開發中,我們經常會使用cmd在命令行窗口運行程序。然而,有時候我們會發現,在運行Java程序時,需要在文件內打開cmd為中心,這讓很多開發者感到疑惑,那麼,為什麼會出現這…

    編程 2025-04-29
  • Python中讀入csv文件數據的方法用法介紹

    csv是一種常見的數據格式,通常用於存儲小型數據集。Python作為一種廣泛流行的編程語言,內置了許多操作csv文件的庫。本文將從多個方面詳細介紹Python讀入csv文件的方法。…

    編程 2025-04-29
  • Python zipfile解壓文件亂碼處理

    本文主要介紹如何在Python中使用zipfile進行文件解壓的處理,同時詳細討論在解壓文件時可能出現的亂碼問題的各種解決辦法。 一、zipfile解壓文件亂碼問題的根本原因 在P…

    編程 2025-04-29
  • Python將矩陣存為CSV文件

    CSV文件是一種通用的文件格式,在統計學和計算機科學中非常常見,一些數據分析工具如Microsoft Excel,Google Sheets等都支持讀取CSV文件。Python內置…

    編程 2025-04-29
  • Python如何導入py文件

    Python是一種開源的高級編程語言,因其易學易用和強大的生態系統而備受青睞。Python的import語句可以幫助用戶將一個模塊中的代碼導入到另一個模塊中,從而實現代碼的重用。本…

    編程 2025-04-29
  • Python合併多個相同表頭文件

    對於需要合併多個相同表頭文件的情況,我們可以使用Python來實現快速的合併。 一、讀取CSV文件 使用Python中的csv庫讀取CSV文件。 import csv with o…

    編程 2025-04-29
  • Python寫文件a

    Python語言是一種功能強大、易於學習、通用並且高級編程語言,它具有許多優點,其中之一就是能夠輕鬆地進行文件操作。文件操作在各種編程中都佔有重要的位置,Python作為開發人員常…

    編程 2025-04-29

發表回復

登錄後才能評論