我有这个简单的脚本:
var exec = require('child_process').exec;
exec('coffee -cw my_file.coffee', function(error, stdout, stderr) {
console.log(stdout);
});
在这里,我只需执行一个命令即可编译咖啡脚本文件。但是stdout永远不会显示在控制台中,因为该命令永远不会结束(因为coffee的-
w选项)。如果我直接从控制台执行命令,则会收到如下消息:
18:05:59 - compiled my_file.coffee
我的问题是:是否可以使用node.js exec显示这些消息?如果是,怎么办?!
谢谢
不要使用exec
。使用spawn
哪个是EventEmmiter
对象。然后,您可以在事件
发生时 收听stdout
/ stderr
event(spawn.stdout.on('data',callback..)
)。 __
从NodeJS文档中:
var spawn = require('child_process').spawn,
ls = spawn('ls', ['-lh', '/usr']);
ls.stdout.on('data', function (data) {
console.log('stdout: ' + data.toString());
});
ls.stderr.on('data', function (data) {
console.log('stderr: ' + data.toString());
});
ls.on('exit', function (code) {
console.log('child process exited with code ' + code.toString());
});
exec
缓冲输出,通常在命令完成执行后将其返回。
问题内容: 在Linux 3.0 / C ++下: 我想要一个执行以下操作的函数: 显然上述方法不起作用,但是您可以理解。我有一个字符串s,我希望将其作为应用程序“ foo”的子进程执行的标准输入传递,然后将其标准输出记录到字符串r中,然后将其返回。 我应该使用linux syscall或posix函数的什么组合? 问题答案: eerpini提供的代码无法正常工作。请注意,例如,之后将使用在父级中
我的问题是什么时候使用 方法时,my.jar没有执行并显示其输出
我是Java的初学者。学习罗伯特·塞奇威克的《Java导论》 我尝试在Netbeans中编译以下代码。 } 我收到了这个错误。我已将文件放置在标准位置。java 线程“main”java.lang.RuntimeException中的异常:无法编译的源代码-错误的sym类型:示例。StdIn.is在示例中为空。verage.main(verage.java:16)Java结果:1 BUILD SU
我正在做我的家庭作业,那就是用C语言复制unix命令shell。 我已经实现了直到后台运行的单个命令执行( 现在我正处于实现管道的阶段,我面临这个问题,对于大于1的管道,带有管道的子命令已经完成,但是最终输出不会显示在stdout上(最后一个命令的标准输入被替换为最后一个管道的读取) 我也在家长那里尝试了。 我的程序的出口是CONTROL-D,当我按下该键时,将显示输出(也将退出,因为我对CONT
和之前 inputs/stdin 插件一样,outputs/stdout 插件也是最基础和简单的输出插件。同样在这里简单介绍一下,作为输出插件的一个共性了解。 配置示例 output { stdout { codec => rubydebug workers => 2 } } 解释 输出插件统一具有一个参数是 workers。Logstash 为输
回顾一下我们写的第一个 Rust 程序就是带副作用的,其副作用就是向标准输出(stdout),通常是终端或屏幕,输出了 Hello, World! 让屏幕上这几个字符的地方点亮起来。println! 宏是最常见的输出,用宏来做输出的还有 print!,两者都是向标准输出(stdout)输出,两者的区别也一眼就能看出。至于格式化输出,基础运算符和字符串格式化小节有详细说明,这里就不再啰嗦了。 更通用