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

詳解node如何將Excel導入數(shù)據(jù)庫

 更新時間:2024年11月05日 08:34:57   作者:JYeontu  
這篇文章主要為大家詳細介紹了node如何通過腳本實現(xiàn)將Excel導入mysql數(shù)據(jù)庫里,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下

說在前面

最近搞了一個網(wǎng)站用來記錄自己日常的一些東西,之前的數(shù)據(jù)都是用Excel表格記錄的,現(xiàn)在需要將之前記錄的Excel數(shù)據(jù)導入到mysql數(shù)據(jù)庫里,于是就想著用node寫一個簡單的腳本來處理,所以就有了這一篇文章。

比如現(xiàn)在我們有這樣一份Excel數(shù)據(jù):

我們需要將這些數(shù)據(jù)插入到名為t_user的表中去。

1、導入模塊

首先,代碼導入了xlsxfs模塊。xlsx模塊用于操作 Excel 文件,fs模塊用于文件系統(tǒng)操作。

const xlsx = require("xlsx");
const fs = require("fs");

2、讀取 Excel 文件

使用xlsx.readFile方法讀取指定路徑(./static/test.xlsx)的 Excel 文件,并將結果存儲在workBook變量中。

const workBook = xlsx.readFile("./static/test.xlsx");

3、獲取指定工作表并轉換為 JSON

  • workBook中獲取Sheet1的工作表,并存儲在sheet變量中。
  • 使用xlsx.utils.sheet_to_json方法將工作表轉換為 JSON 格式,并存儲在sheetJson變量中。
  • 最后,使用fs.writeFileSync方法將sheetJson以格式化的 JSON 字符串形式寫入到./file/sheetJson.text文件中。
const name = "Sheet1";
let sheet = workBook.Sheets[name];
const sheetJson = xlsx.utils.sheet_to_json(sheet);
fs.writeFileSync("./file/sheetJson.text", JSON.stringify(sheetJson, null, 2));

獲取到的json數(shù)據(jù)如下:

4、生成 SQL 插入語句

有了整理好的 JSON 數(shù)據(jù)后,我們就可以開始為將這些數(shù)據(jù)插入到數(shù)據(jù)庫中做準備了。

  • 首先創(chuàng)建一個空數(shù)組sqlList,用于存儲生成的 SQL 插入語句。
  • 遍歷sheetJson中的每個對象(代表 Excel 工作表中的一行數(shù)據(jù),就是一條完整的信息記錄。)。
  • 對于每個對象,使用for...in循環(huán)遍歷其屬性,構建 SQL 插入語句的列名部分(keyStr)和值部分(valStr)。將字符串值用單引號括起來。
  • 最后,將構建好的 SQL 插入語句(INSERT INTO t_user (${keyStr}) VALUES (${valStr});)添加到sqlList數(shù)組中。
let sqlList = [];
sheetJson.forEach((item) => {
 let keyStr = "",
   valStr = "";
 for (const key in item) {
   if (keyStr) keyStr += ",";
   keyStr += key;
   if (valStr) valStr += ",";
   valStr += `'${item[key]}'`;
 }
 sqlList.push(`INSERT INTO t_user (${keyStr}) VALUES (${valStr});`);
});

這里的t_user是需要插入數(shù)據(jù)的表名,可以根據(jù)實際情況進行調整。

5、寫入 SQL 語句到文件

使用fs.writeFileSync方法將sqlList數(shù)組中的所有 SQL 插入語句以換行符連接后寫入到./file/excel2Sql.text文件中。

fs.writeFileSync("./file/excel2Sql.text", sqlList.join("\n"));

生成的sql插入語句如下:

6、插入數(shù)據(jù)庫

我們有一個t_user表,現(xiàn)在表里是空的

執(zhí)行生成的插入語句,將腳本生成的sql插入語句復制到控制臺,執(zhí)行插入語句

成功執(zhí)行插入語句,我們就成功地將excel表中的數(shù)據(jù)都導入到數(shù)據(jù)庫中去了

7、完整代碼

const xlsx = require("xlsx");
const fs = require("fs");
const workBook = xlsx.readFile("./static/test.xlsx");

const name = "Sheet1";
let sheet = workBook.Sheets[name];
const sheetJson = xlsx.utils.sheet_to_json(sheet);
fs.writeFileSync("./file/sheetJson.text", JSON.stringify(sheetJson, null, 2));
let sqlList = [];
sheetJson.forEach((item) => {
  let keyStr = "",
    valStr = "";
  for (const key in item) {
    if (keyStr) keyStr += ",";
    keyStr += key;
    if (valStr) valStr += ",";
    valStr += `'${item[key]}'`;
  }
  sqlList.push(`INSERT INTO t_user (${keyStr}) VALUES (${valStr});`);
});
fs.writeFileSync("./file/excel2Sql.text", sqlList.join("\n"));

這是一個將Excel數(shù)據(jù)轉為sql插入語句的簡單腳本,大家可以根據(jù)自己的需求進行微調后使用,也可以在node中直接連接數(shù)據(jù)庫,省去手動執(zhí)行的步驟,不過我覺得手動插入也不麻煩,就直接生成插入語句然后手動執(zhí)行語句來插入了

以上就是詳解node如何將Excel導入數(shù)據(jù)庫的詳細內容,更多關于node Excel導入數(shù)據(jù)庫的資料請關注腳本之家其它相關文章!

相關文章

  • Node.js環(huán)境下Koa2添加travis ci持續(xù)集成工具的方法

    Node.js環(huán)境下Koa2添加travis ci持續(xù)集成工具的方法

    這篇文章主要給大家介紹了在Node.js環(huán)境下Koa2添加travis ci持續(xù)集成工具的方法,文中介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面跟著小編一起來學習學習吧。
    2017-06-06
  • 整理幾個關鍵節(jié)點深入理解nodejs

    整理幾個關鍵節(jié)點深入理解nodejs

    這篇文章主要介紹了整理幾個關鍵節(jié)點深入理解nodejs,文章圍繞主題展開詳細的內容介紹,需要的小伙伴可以參考一下,需要的小伙伴可以參考一下
    2022-07-07
  • 詳解nodejs微信公眾號開發(fā)——4.自動回復各種消息

    詳解nodejs微信公眾號開發(fā)——4.自動回復各種消息

    這篇文章主要介紹了詳解nodejs微信公眾號開發(fā)——4.自動回復各種消息,非常具有實用價值,需要的朋友可以參考下
    2017-04-04
  • Node.js之readline模塊的使用詳解

    Node.js之readline模塊的使用詳解

    這篇文章主要介紹了Node.js之readline模塊的使用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-03-03
  • 深入理解Node.js 事件循環(huán)和回調函數(shù)

    深入理解Node.js 事件循環(huán)和回調函數(shù)

    這篇文章主要介紹了深入理解Node.js 事件循環(huán)和回調函數(shù),詳細的介紹Node.js 事件循環(huán)和Node.js回調函數(shù),需要學習的可以參考一下。
    2016-11-11
  • 淺析Node.js實現(xiàn)HTTP文件下載

    淺析Node.js實現(xiàn)HTTP文件下載

    本文介紹如何用Node.js來實現(xiàn)HTTP文件下載,文章以實例演示所以很詳細,有需要的小伙伴們可以參考學習。
    2016-08-08
  • node.js讀寫json文件的方法

    node.js讀寫json文件的方法

    這篇文章介紹了node.js讀寫json文件的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • Node.js中console.log()輸出彩色字體的方法示例

    Node.js中console.log()輸出彩色字體的方法示例

    這篇文章主要給大家介紹了關于Node.js中console.log()輸出彩色字體的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Node.js具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-12-12
  • Windows上安裝Node-RED的實現(xiàn)

    Windows上安裝Node-RED的實現(xiàn)

    Node-RED是一個用于物聯(lián)網(wǎng)編程的工具,提供了一個基于瀏覽器的編程環(huán)境和豐富的節(jié)點類型,本文就來介紹一下Windows上安裝Node-RED的實現(xiàn),感興趣的可以了解一下
    2025-02-02
  • 詳解nodejs異步I/O和事件循環(huán)

    詳解nodejs異步I/O和事件循環(huán)

    本篇文章主要介紹了nodejs異步I/O和事件循環(huán),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06

最新評論