"process.stdout. "在node.js中写入“和”console.log“?
EDIT:使用console.log作为变量显示了许多不可读的字符,而使用process.stdout.write显示了一个对象。
为什么呢?
"process.stdout. "在node.js中写入“和”console.log“?
EDIT:使用console.log作为变量显示了许多不可读的字符,而使用process.stdout.write显示了一个对象。
为什么呢?
当前回答
Console.log()使用格式化输出调用process.stdout.write。具体实现请参见console.js中的format()。
目前(v0.10.ish):
Console.prototype.log = function() {
this._stdout.write(util.format.apply(this, arguments) + '\n');
};
其他回答
Console.log()使用格式化输出调用process.stdout.write。具体实现请参见console.js中的format()。
目前(v0.10.ish):
Console.prototype.log = function() {
this._stdout.write(util.format.apply(this, arguments) + '\n');
};
我刚刚注意到,在获得https帮助后,在研究这个问题时。申请邮寄方式。我想分享一些帮助你理解的信息。
Process.stdout.write不会添加新行,而console.log会,就像其他人提到的那样。但是还有一个例子更容易解释。
var req = https.request(options, (res) => {
res.on('data', (d) => {
process.stdout.write(d);
console.log(d)
});
});
process.stdout.write (d);将正确地打印数据而不需要新行。然而console.log(d)将打印一个新行,但数据不会正确显示,给出这个<Buffer 12 34 56…为例。
为了使console.log(d)正确地显示信息,我必须这样做。
var req = https.request(options, (res) => {
var dataQueue = "";
res.on("data", function (d) {
dataQueue += d;
});
res.on("end", function () {
console.log(dataQueue);
});
});
所以:
Process.stdout.write在检索数据时连续打印信息,不添加新行。 log打印在检索点获得的信息,并添加新行。
我只能这么解释了。
这里的答案很好。下面将详述console.log格式化函数的重要性。尚未提到的格式化特性之一是组级别,日志将支持组级别,但stdout不支持组级别。
console.log('Begin...')
console.group()
console.log('Line 2 (console.log)')
process.stdout.write('Line 3 (process.stdout)\n')
console.log('Line 4 (console.log)')
process.stdout.write('Line 5 (process.stdout)') // no newline
console.groupEnd()
console.log('...done')
输出:
Begin...
Line 2 (console.log)
Line 3 (process.stdout)
Line 4 (console.log)
Line 5 (process.stdout)...done
注意,stdout不支持控制台。组格式,并始终写入行首,其中console.log表示分组并适当缩进。
只对日志语句(和一个额外的组)执行相同的操作:
console.log('Begin...')
console.group()
console.log('Line 2 (console.log)')
console.log('Line 3 (console.log)')
console.log('Line 4 (console.log)')
console.log('Line 5 (console.log)')
console.group()
console.log('Line 6 (console.log)')
console.log('Line 7 (console.log)')
console.groupEnd()
console.groupEnd()
console.log('...done')
输出:
Begin...
Line 2 (console.log)
Line 3 (console.log)
Line 4 (console.log)
Line 5 (console.log)
Line 6 (console.log)
Line 7 (console.log)
...done
简单的区别是: Console.log()方法自动添加新的行字符。这意味着如果我们循环遍历并打印结果,每个结果将在新行中打印。
Process.stdout.write()方法不会追加新的行字符。适用于打印图案。
对于那些喜欢Deno的人,我可以通过使用下面的ANSI转义序列和Deno版本的process.stdout.write来实现这一点。
ESC[2K clears entire line
ESC[#G moves cursor to column #
Code
/*
Console.log() to the same line
Supported in Deno 1.8.1
*/
const myTextEncoder : TextEncoder = new TextEncoder();
let counter : number = 0;
while(counter < 100000) {
// ESC[2K clears entire line
await Deno.stdout.write(myTextEncoder.encode(`\x1b[2K`));
// ESC[#G moves cursor to column #
await Deno.stdout.write(myTextEncoder.encode(`\x1b[0G`));
// OUTPUT incremented counter
await Deno.stdout.write(myTextEncoder.encode(`COUNTER: ${counter++}`));
}