使用 nodejs 区分错误和标准终端日志



我在node js中使用ffmpeg。标准终端输出和错误似乎都被发送到 stdout,所以我不知道如何区分错误和成功......这是我的代码:

var convertToMp3 = function(filePath) {
  var ffmpeg = child_process.spawn('ffmpeg',['-i', filePath, '-y', 'output.mp3']);
  var err = '';
  ffmpeg.stderr
    .on('data', function(c) { err += c; })
    .on('end', function() { console.log('stderr:', err); });
  var d = '';
  ffmpeg.stdout
    .on('data', function(c){d +=c;})
    .on('end', function(){ console.log('stdout', d); });
}

无论转换成功还是失败,stdout 都是空的,stderr 包含如果我在终端中运行相应的命令会得到什么

Ffmpeg 将其所有日志记录数据输出到 stderr ,以便stdout腾出时间将输出数据管道传输到其他程序或其他 ffmpeg 实例。

当将ffmpeg作为自动进程运行时,通常很有用,可以选择

-loglevel error

这在正常情况下使其完全静音,并且仅输出错误数据(到 stderr),这通常是您对命令行程序的期望。

受到@aergistal评论的启发,这里有一个对我有用的解决方案,其中回调将在任务结束时执行,并像往常一样使用签名function(error, success)

var convertToMp3 = function(filePath, callback) {
  var ffmpeg = child_process.spawn('ffmpeg',['-i', filePath, '-y', 'output.mp3']);
  var err = '';
  ffmpeg.stderr.on('data', function(c) { err += c; }).on('end', function() { console.log('stderr:', err); });
  ffmpeg.on('exit', function(code) {
    if (code) {
      callback({code: code, message: err});
    } else {
      callback(null, {success: true, message: err});
    }
  });
}

或采用新的 js 样式:

const convertToMp3 = (filePath) => new Promise((resolve, reject) {
  const ffmpeg = child_process.spawn('ffmpeg', ['-i', filePath, '-y', 'output.mp3']);
  let output = '';
  ffmpeg.stderr
    .on('data', c => { output += c; });
  ffmpeg.on('exit', code => {
    if (code) {
      reject({ code: code, message: output });
    } else {
      resolve(output);
    }
  });
});
const ffmpegOutput = await convertToMp3('./video.mp4');
...

相关内容