国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專(zhuān)題視頻專(zhuān)題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專(zhuān)題1關(guān)鍵字專(zhuān)題50關(guān)鍵字專(zhuān)題500關(guān)鍵字專(zhuān)題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專(zhuān)題關(guān)鍵字專(zhuān)題tag2tag3文章專(zhuān)題文章專(zhuān)題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專(zhuān)題3
問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

Node.js+console輸出日志文件實(shí)例分析

來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 19:42:14
文檔

Node.js+console輸出日志文件實(shí)例分析

Node.js+console輸出日志文件實(shí)例分析:這次給大家?guī)?lái)Node.js+console輸出日志文件實(shí)例分析,Node.js+console輸出日志文件的注意事項(xiàng)有哪些,下面就是實(shí)戰(zhàn)案例,一起來(lái)看一下。我們首先創(chuàng)建如下文件:// index.js let fs = require('fs'); let options = {
推薦度:
導(dǎo)讀Node.js+console輸出日志文件實(shí)例分析:這次給大家?guī)?lái)Node.js+console輸出日志文件實(shí)例分析,Node.js+console輸出日志文件的注意事項(xiàng)有哪些,下面就是實(shí)戰(zhàn)案例,一起來(lái)看一下。我們首先創(chuàng)建如下文件:// index.js let fs = require('fs'); let options = {

這次給大家?guī)?lái)Node.js+console輸出日志文件實(shí)例分析,Node.js+console輸出日志文件的注意事項(xiàng)有哪些,下面就是實(shí)戰(zhàn)案例,一起來(lái)看一下。

我們首先創(chuàng)建如下文件:

// index.js
let fs = require('fs');
let options = {
 flags: 'a', // append模式
 encoding: 'utf8', // utf8編碼
};
let stdout = fs.createWriteStream('./stdout.log', options);
let stderr = fs.createWriteStream('./stderr.log', options);
// 創(chuàng)建logger
let logger = new console.Console(stdout, stderr);
for (let i = 0; i < 100; i++) {
 logger.log(`log message ${i}`);
 logger.error(`err message ${i}`);
}

在上面代碼中,我們其實(shí)是創(chuàng)建了一個(gè)console.Console類(lèi)的實(shí)例,該類(lèi)需要指定兩個(gè)參數(shù),即標(biāo)準(zhǔn)輸出流和標(biāo)準(zhǔn)錯(cuò)誤輸出流,正常情況下,實(shí)際上是對(duì)應(yīng)了process.stdout和process.stderr,以上的代碼中,我們將這兩個(gè)輸出流改為了文件輸出流,并指定為文件追加模式,這樣即可將日志信息輸出到指定的文件中去。運(yùn)行上面的代碼,會(huì)生成stdout.log和stderr.log兩個(gè)文件。

stdout.log文件內(nèi)容如下:

log message 0
log message 1
log message 2
log message 3
log message 4
log message 5
log message 6
log message 7
log message 8
log message 9
log message 10
...

stderr.log文件內(nèi)容如下:

err message 0
err message 1
err message 2
err message 3
err message 4
err message 5
err message 6
err message 7
err message 8
err message 9
err message 10
...

看上去信息還比較簡(jiǎn)單,不像是日志文件的樣子,我們或許得為每條日志添加一個(gè)時(shí)間才行,下面先為Date對(duì)象添加一個(gè)format的原型方法:

// 添加format方法
Date.prototype.format = function (format) {
 if (!format) {
 format = 'yyyy-MM-dd HH:mm:ss';
 }
 
 // 用0補(bǔ)齊指定位數(shù)
 let padNum = function (value, digits) {
 return Array(digits - value.toString().length + 1).join('0') + value;
 };
 // 指定格式字符
 let cfg = {
 yyyy: this.getFullYear(), // 年
 MM: padNum(this.getMonth() + 1, 2), // 月
 dd: padNum(this.getDate(), 2), // 日
 HH: padNum(this.getHours(), 2), // 時(shí)
 mm: padNum(this.getMinutes(), 2), // 分
 ss: padNum(this.getSeconds(), 2), // 秒
 fff: padNum(this.getMilliseconds(), 3), // 毫秒
 };
 return format.replace(/([a-z]|[A-Z])(\1)*/ig, function (m) {
 return cfg[m];
 });
}

然后再改寫(xiě)前面的主文件:

// index.js
let fs = require('fs');
let options = {
 flags: 'a', // append模式
 encoding: 'utf8', // utf8編碼
};
let stdout = fs.createWriteStream('./stdout.log', options);
let stderr = fs.createWriteStream('./stderr.log', options);
// 創(chuàng)建logger
let logger = new console.Console(stdout, stderr);
// 添加format方法
Date.prototype.format = function (format) {
 if (!format) {
 format = 'yyyy-MM-dd HH:mm:ss';
 }
 
 // 用0補(bǔ)齊指定位數(shù)
 let padNum = function (value, digits) {
 return Array(digits - value.toString().length + 1).join('0') + value;
 };
 // 指定格式字符
 let cfg = {
 yyyy: this.getFullYear(), // 年
 MM: padNum(this.getMonth() + 1, 2), // 月
 dd: padNum(this.getDate(), 2), // 日
 HH: padNum(this.getHours(), 2), // 時(shí)
 mm: padNum(this.getMinutes(), 2), // 分
 ss: padNum(this.getSeconds(), 2), // 秒
 fff: padNum(this.getMilliseconds(), 3), // 毫秒
 };
 return format.replace(/([a-z]|[A-Z])(\1)*/ig, function (m) {
 return cfg[m];
 });
}
for (let i = 0; i < 100; i++) {
 let time = new Date().format('yyyy-MM-dd HH:mm:ss.fff');
 logger.log(`[${time}] - log message ${i}`);
 logger.error(`[${time}] - err message ${i}`);
}

重新運(yùn)行程序,然后查看兩個(gè)日志文件的內(nèi)容。

stdout.log內(nèi)容如下:

[2018-04-27 07:30:54.309] - log message 0
[2018-04-27 07:30:54.312] - log message 1
[2018-04-27 07:30:54.312] - log message 2
[2018-04-27 07:30:54.312] - log message 3
[2018-04-27 07:30:54.312] - log message 4
[2018-04-27 07:30:54.312] - log message 5
[2018-04-27 07:30:54.312] - log message 6
[2018-04-27 07:30:54.312] - log message 7
[2018-04-27 07:30:54.312] - log message 8
[2018-04-27 07:30:54.312] - log message 9
[2018-04-27 07:30:54.312] - log message 10
...

stderr.log內(nèi)容如下:

[2018-04-27 07:30:54.309] - err message 0
[2018-04-27 07:30:54.312] - err message 1
[2018-04-27 07:30:54.312] - err message 2
[2018-04-27 07:30:54.312] - err message 3
[2018-04-27 07:30:54.312] - err message 4
[2018-04-27 07:30:54.312] - err message 5
[2018-04-27 07:30:54.312] - err message 6
[2018-04-27 07:30:54.312] - err message 7
[2018-04-27 07:30:54.312] - err message 8
[2018-04-27 07:30:54.312] - err message 9
[2018-04-27 07:30:54.312] - err message 10
...

相信看了本文案例你已經(jīng)掌握了方法,更多精彩請(qǐng)關(guān)注Gxl網(wǎng)其它相關(guān)文章!

推薦閱讀

Node.js文件編碼格式轉(zhuǎn)換方式匯總

如何給微信小程序內(nèi)添加客服按鈕

聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

Node.js+console輸出日志文件實(shí)例分析

Node.js+console輸出日志文件實(shí)例分析:這次給大家?guī)?lái)Node.js+console輸出日志文件實(shí)例分析,Node.js+console輸出日志文件的注意事項(xiàng)有哪些,下面就是實(shí)戰(zhàn)案例,一起來(lái)看一下。我們首先創(chuàng)建如下文件:// index.js let fs = require('fs'); let options = {
推薦度:
標(biāo)簽: 文件 文件夾 文檔
  • 熱門(mén)焦點(diǎn)

最新推薦

猜你喜歡

熱門(mén)推薦

專(zhuān)題
Top
主站蜘蛛池模板: 亚洲一区二区三区免费 | 欧美亚洲另类在线观看 | 欧美精品久久天天躁 | 欧美三级在线 | 免费一区二区 | 日韩视频免费在线观看 | 国产成人三级经典中文 | 伊人久久亚洲综合天堂 | 亚洲精国产一区二区三区 | 国产一区二区久久精品 | 日韩欧美一二区 | 亚洲视频一区在线 | 国内精品视频一区二区三区 | 欧美日韩在线第一页 | 精品一区二区三区的国产在线观看 | 精品在线网站 | 国内偷自第一二三区 | 在线播放精品一区二区啪视频 | 国产在线精品成人一区二区三区 | 中文字幕日韩欧美 | 高清亚洲 | 日本a级片在线观看 | 91精品国产91久久综合 | 可以免费观看的毛片 | 亚洲狼人香蕉香蕉在线28 | 欧美日韩精品一区二区 | 国产91精品对白露脸全集观看 | 亚洲三级电影网 | 国产淫视频 | 国产在线精品一区二区 | 亚洲精品98久久久久久中文字幕 | 日韩精品一区二区三区在线观看l | 最新国产在线播放 | 欧美日韩亚洲一区二区 | 一级欧美日韩 | 国产精品第1页在线观看 | 日韩欧| 亚洲1页 | 美日韩在线 | 日韩精品在线观看免费 | a毛片免费|