我在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');
...