NodeJS读取并解析每行stdout

时间:2012-10-18 12:51:49

标签: javascript node.js

我有一个NodeJS脚本,'exec是一个子进程来捕获文件的cat转储:

var exec = require('child_process').exec;
var result = '';
var child = exec('./scripts/first.sh',function(err, stdout, stderr) {
    result = stdout.split("=");
});

如果文件不存在,我会转储另一个文件:

var result = '';
var child = exec('./scripts/first.sh',function(err, stdout, stderr) {
    result = stdout.split("=");
    if(stdout.indexOf('No such file or directory') != -1){
        var child = exec('./scripts/second.sh', function(err, stdout, stderr) {
            result = stdout.split("=");
    });
});

最后我记录结果变量的值:

console.log(result);

文件将包含如下所述的数据:

line_1 = 7888
line_2 = 8998
line_3 = 9090
line_4 = 9097

我需要解析并提取line_1和line_3的值吗?

结果变量不显示任何值。我的想法是将stdout数据放在字符串变量中并使用一些搜索机制。

虽然我不确定这种方法,因为我对JS / NodeJS没有多少经验。

== EDIT ==

请找到我写过的函数的副本。

var exec = require('child_process').exec;

function getdetail() {
        var result = '';
        var child = exec('./scripts/first.sh', function(err, stdout, stderr) {
                if(stdout.indexOf('No such file or directory') != -1){
                        var child = exec('./scripts/second.sh',function(err, stdout, stderr) {
                        result = stdout.toString().split("=");
                        console.log(result);
                        });
                }
                else
                {
                        result = stdout.toString().split("=");
                        console.log(result);
                }
        });
}

stdout流对象上的tostring()完成了这个技巧,但我得到了如下所述的控制台日志:

[ 'spawn ssh -o UserKnownHostsFile',
  '/dev/null -o StrictHostKeyChecking',
  'no user@www.mybox.com cat ver.txt\r\nWarning: Permanently added \'www.mybox.com,XX.XX.XX.XX\' (RSA) to the list of known hosts.\r\r\nuser@www.mybox.com\'s password: \r\line_1',
  '9400\r\nline_2',
  '3508\r\nline_3',
  '77f3\r\nline_4',
  '/tmp\r\nline_5',
  '/tmp/ramdisk/\r\nline_5',
  '77f3\r\n' ]

如何提取line_1和line_3的值?

1 个答案:

答案 0 :(得分:11)

exec是异步的。因此,如果您写的内容如下:

var result = '';
var child = exec('...'), function() { result = 'abc'; } );
console.log(result);

然后result可能为空,因为console.log(result)可以并且经常会在exec返回其回调之前执行并填写新值。

要解决此问题,您需要在exec的回调函数中异步处理结果。

此外,我不确定您检查错误的方式是否最好。您可以简单地测试err是否具有非空值,而不是检查“没有这样的文件或目录”:

if(err) {

总之,我们最终得到以下代码:

var exec = require('child_process').exec;

var result = '';
var processResult = function(stdout) {
    var result = stdout.split("=");
    console.log(result);
};

var child = exec('./scripts/first.sh',function(err, stdout, stderr) {
    if(err) {
        var child = exec('./scripts/second.sh', function(err, stdout, stderr) {                         
            processResult(stdout);
        });
    } else {            
        processResult(stdout);
    }
});

如果需要进一步处理stdout数据,则需要遍历它以找出包含“key = value”的所有可能出现的字符串。这是一个粗略的想法:

var processResult = function(stdout) {  
    var lines = stdout.toString().split('\n');
    var results = new Array();
    lines.forEach(function(line) {
        var parts = line.split('=');
        results[parts[0]] = parts[1];
    });

    console.log(results);
};

我希望这能让你开始。