詳解node如何將Excel導入數(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、導入模塊
首先,代碼導入了xlsx和fs模塊。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ù)集成工具的方法,文中介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面跟著小編一起來學習學習吧。2017-06-06
詳解nodejs微信公眾號開發(fā)——4.自動回復各種消息
這篇文章主要介紹了詳解nodejs微信公眾號開發(fā)——4.自動回復各種消息,非常具有實用價值,需要的朋友可以參考下2017-04-04
深入理解Node.js 事件循環(huán)和回調函數(shù)
這篇文章主要介紹了深入理解Node.js 事件循環(huán)和回調函數(shù),詳細的介紹Node.js 事件循環(huán)和Node.js回調函數(shù),需要學習的可以參考一下。2016-11-11
Node.js中console.log()輸出彩色字體的方法示例
這篇文章主要給大家介紹了關于Node.js中console.log()輸出彩色字體的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Node.js具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-12-12

