日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

帶你使用Node讀寫txt和Excel文件


前端有時(shí)要處理一些數(shù)據(jù)(比如多語(yǔ)言文件內(nèi)容的替換),我們不要傻乎乎地干這種重復(fù)枯燥又浪費(fèi)時(shí)間的ctrl Cctrl V的工作,這種事情交給計(jì)算機(jī)做再合適不過(guò)了。

這篇文章只是簡(jiǎn)單地介紹前端如何通過(guò)Node來(lái)讀取Exceltxt文件中的數(shù)據(jù),然后寫入到txt文件中的方法。首先給出文件的內(nèi)容:test.txt文件只有一句話(我是txt文件的內(nèi)容);test.xlsx文件中,具體如圖所示:


帶你使用Node讀寫txt和Excel文件


讀取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)行如下:


帶你使用Node讀寫txt和Excel文件


還有一種是追加操作,就是在原來(lái)的基礎(chǔ)上添加數(shù)據(jù):

/** 引入Node的文件模塊 */
const fs = require("fs");
 
/** 測(cè)試寫入 */
fs.appendFile("write.txt", "測(cè)試寫入", (err, data) => {
    if (err) throw err;
});

運(yùn)行如下:


帶你使用Node讀寫txt和Excel文件


提示:這里需要注意的是,當(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é)果:


帶你使用Node讀寫txt和Excel文件


這時(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é)果如下:


帶你使用Node讀寫txt和Excel文件


為了使寫入格式更好看一點(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;
});


帶你使用Node讀寫txt和Excel文件


讀取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é)果:


帶你使用Node讀寫txt和Excel文件


解析后的內(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é)果如下:


帶你使用Node讀寫txt和Excel文件


至此,我們都知道了讀取以及寫入文件的方法,接下來(lái)任你折騰,想干嘛就干嘛,可以愉快地玩數(shù)據(jù)了~


分享到:
標(biāo)簽:Node讀寫txt Node讀寫Excel文件
用戶無(wú)頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過(guò)答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定