前端有時(shí)要處理一些數(shù)據(jù)(比如多語(yǔ)言文件內(nèi)容的替換),我們不要傻乎乎地干這種重復(fù)枯燥又浪費(fèi)時(shí)間的ctrl C
+ ctrl V
的工作,這種事情交給計(jì)算機(jī)做再合適不過(guò)了。
這篇文章只是簡(jiǎn)單地介紹前端如何通過(guò)Node來(lái)讀取Excel
或txt
文件中的數(shù)據(jù),然后寫入到txt
文件中的方法。首先給出文件的內(nèi)容:test.txt文件只有一句話(我是txt文件的內(nèi)容);test.xlsx文件中,具體如圖所示:
讀取txt文件
廢話不多說(shuō),show me your code:
/** 引入Node的文件模塊 */ const fs = require("fs"); /** 獲取要讀取的文件的路徑 */ const path = "./test.txt"; /** 判斷該文件是否存在 */ const isExist = fs.existsSync(path); /** 讀取文件的內(nèi)容 */ const data = isExist ? fs.readFileSync(path, "utf-8") : ""; /** 測(cè)試讀取 */ console.log("test.txt的內(nèi)容:", data) // test.txt的內(nèi)容: 我是txt文件的內(nèi)容
寫入txt文件
/** 引入Node的文件模塊 */ const fs = require("fs"); /** 測(cè)試寫入 */ fs.writeFile("write.txt", "測(cè)試寫入", (err, data) => { if (err) throw err; });
這里我們并不需要主動(dòng)創(chuàng)建write.txt
,代碼會(huì)自動(dòng)判斷這個(gè)文件是否存在,如果不存在則自動(dòng)創(chuàng)建該文件。注意,如果該文件存在,調(diào)用writeFile
(該方法的完整使用可以參考這)時(shí),將會(huì)用新的內(nèi)容替換掉原有的內(nèi)容。運(yùn)行如下:
還有一種是追加操作,就是在原來(lái)的基礎(chǔ)上添加數(shù)據(jù):
/** 引入Node的文件模塊 */ const fs = require("fs"); /** 測(cè)試寫入 */ fs.appendFile("write.txt", "測(cè)試寫入", (err, data) => { if (err) throw err; });
運(yùn)行如下:
提示:這里需要注意的是,當(dāng)我們向文件中直接寫入的是JS對(duì)象的時(shí)候,結(jié)果并不符合我們的預(yù)期:
/** 引入Node的文件模塊 */ const fs = require("fs"); const obj = { name: 'cc', age: 15 } /** 測(cè)試寫入 */ fs.writeFile("write.txt", obj, (err, data) => { if (err) throw err; });
運(yùn)行結(jié)果:
這時(shí)可以通過(guò)JSON.stringify()
字符串化對(duì)象,即可:
/** 引入Node的文件模塊 */ const fs = require("fs"); const obj = { name: 'cc', age: 15 } /** 測(cè)試寫入 */ fs.writeFile("write.txt", JSON.stringify(obj), (err, data) => { if (err) throw err; });
結(jié)果如下:
為了使寫入格式更好看一點(diǎn),可以往JSON.stringify()
方法中添加一些參數(shù)(JSON.stringify()
方法的使用可以參考這),比如添加一個(gè)Tab
縮進(jìn):
/** 引入Node的文件模塊 */ const fs = require("fs"); const obj = { name: 'cc', age: 15 } /** 測(cè)試寫入 */ fs.writeFile("write.txt", JSON.stringify(obj, null, '\t'), (err, data) => { if (err) throw err; });
讀取Excel文件
/** 引入Node的文件模塊 */ const fs = require("fs"); /** 引入Excel文件處理模塊(若沒安裝,安裝一下即可) */ const xlsx = require('node-xlsx'); /** 解析excel文檔 */ const sheets = xlsx.parse('./test.xlsx'); console.log("sheets data:", sheets)
可以看到輸出的結(jié)果:
解析后的內(nèi)容sheets
是一個(gè)數(shù)組,每一個(gè)sheet表以一個(gè)對(duì)象{ name: 'xxx', data: [...]}
的形式作為數(shù)組的元素。
完整的樣子如下:
/** sheets的完整內(nèi)容 */ [{ name: 'Sheet1', /** sheet頁(yè)名稱 */ data: [ ['name', 'age'], /** 第一個(gè)元素為表頭 */ ['Tom', 11], ['Bob', 13] ] }, { name: 'Sheet2', /** sheet頁(yè)名稱 */ data: [ ['animal', 'legs'], /** 第一個(gè)元素為表頭 */ ['cat', 4], ['dog', 4], ['duck', 2] ] }]
寫入Excel文件
從上面我們知道了讀取Excel
后的文件的格式,那么寫入也只要按照這種格式構(gòu)建好,再調(diào)用函數(shù)寫入就行啦~
/** 引入Node的文件模塊 */ const fs = require("fs"); /** 引入Excel文件處理模塊 */ const xlsx = require('node-xlsx'); /** 構(gòu)建數(shù)據(jù) */ const myData = [{ name: '我的表格1', data: [ ['name', 'age'], ['Tom', 11], ['Bob', 13] ] }, { name: '我的表格2', data: [ ['animal', 'legs'], ['cat', 4], ['dog', 4], ['duck', 2] ] }] /** 構(gòu)建數(shù)據(jù)流 */ const buffer = xlsx.build(myData); /** 將數(shù)據(jù)寫入write.xlsx */ fs.writeFile('./write.xlsx', buffer, err => { if (err) { throw err; } });
同理,write.xlsx
文件如果不存在的話也會(huì)自動(dòng)創(chuàng)建。運(yùn)行結(jié)果如下:
至此,我們都知道了讀取以及寫入文件的方法,接下來(lái)任你折騰,想干嘛就干嘛,可以愉快地玩數(shù)據(jù)了~