NodeJS spawn stdout string format

时间秒杀一切 提交于 2019-12-21 07:26:08

问题


I'm spawning a process in node and tracking the output of the command like this:

proc.stdout.on("data", function (data) {
    console.log(data.toString());
});

It works well, however, the output seems to be splitting the lines:

npm http
 304 https://registry.npmjs.org/underscore

The above is just one line out of the response from an npm install. Typically this is all in one line, it's also adding line breaks before and after the response. Is there a way to get the data output to look like the standard run, i.e. line-by-line?


回答1:


Streams are buffered and emit data events whenever they please (so to speak), not on strict boundaries like lines of text.

But you can use the readline module to parse the buffers into lines for you:

var child_process = require('child_process');
var readline      = require('readline');
var proc          = child_process.spawn(...);

readline.createInterface({
  input     : proc.stdout,
  terminal  : false
}).on('line', function(line) {
  console.log(line);
});



回答2:


There are 3 solutions which come to mind:

// solution #1
process.stdout.write(data);

// solution #2
console.log(data.toString().replace(/[\n\r]/g, ""));

// solution #3
var child_process = require('child_process');
var readline = require('readline');
var proc = child_process.spawn(...);
readline.createInterface({
  input: proc.stdout,
  terminal: false
}).on('line', function(line) {
  console.log(line);
});


来源:https://stackoverflow.com/questions/20270973/nodejs-spawn-stdout-string-format

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!