我想从rubyrake脚本运行一个可执行文件,比如foo.exe我希望将foo.exe的STDOUT和STDERR输出直接写入我正在运行rake任务的控制台.当进程完成时,我想将退出代码捕获到一个变量中。我如何实现这一目标?我一直在玩backticks、process.spawn、system但我无法获得我想要的所有行为,只有部分更新:我在Windows上,在标准命令提示符下,而不是cygwin 最佳答案 system获取您想要的STDOUT行为。它还返回true作为零退出代码,这可能很有用。$?填充了有关最后一次system调
我目前可以将stdout重定向到ruby/rails中的字符串变量,只需在bash中运行命令并将结果设置为我的字符串变量,如下所示。val=%x[#{cmd}]其中cmd是表示bash命令的字符串。但是,这仅捕获stdout,因为我想捕获stderr并将其设置为ruby中的字符串——有什么想法吗? 最佳答案 简单地重定向它:val=%x[#{cmd}2>&1]如果您只想从stderr捕获输出,请在将其复制到fd2后关闭stdout的文件描述符。val=%x[#{cmd}2>&1>/dev/null]
在bash中,这给出了预期顺序的输出:ruby-e"puts'one';raise'two'"one-e:1:in`':two(RuntimeError)但是如果我将STDERR重定向到STDOUT,我会在输出之前收到错误,这是我不想要的:ruby-e"puts'one';raise'two'"2>&1|cat-e:1:in`':two(RuntimeError)one我想将输出重定向到一个文本文件(它的行为方式与上面的cat相同)并获得输出和异常,但顺序与查看我的输出时的顺序相同终端。这能实现吗? 最佳答案 发生这种情况是因为行缓
我有一个Logger实例:require'logger'logger=Logger.new('foo.log','weekly')我也想将运行时错误(stderr输出)重定向到日志中。我找到了thisforumthread其中有建议:new_fd=logger.get_logger_file_descriptor$stderr.reopennew_fd但是,Logger没有实例方法get_logger_file_descriptor,我也找不到任何公开的获取日志设备或文件访问权限的方法。如何让所有$stderr输出进入日志? 最佳答案
是否可以使用RSpec在Ruby中测试警告?像这样:classMyClassdefinitializewarn"Somethingiswrong"endendit"shouldwarn"doMyClass.new.shouldwarn("Somethingiswrong")end 最佳答案 warn在Kernel中定义,它包含在每个对象中。如果您在初始化期间没有发出警告,您可以指定这样的警告:obj=SomeClass.newobj.should_receive(:warn).with("SomeMessage")obj.metho
这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Ruby$stdoutvs.STDOUTSTDERR通常比使用$stderr更受青睐,还是相反?那么STDOUT与$stdout又如何呢?
我正在从ProgrammingRuby1.9学习这门语言,他们将STDERR.puts扔进了本书开头的代码块中,但没有解释他们为什么使用它或它与puts有何不同。我用谷歌搜索和维基搜索了这个术语,但我从我的研究中所能收集到的只是它与诊断有关。ProgrammingRuby提供的代码中似乎没有指向错误异常处理的链接。这是代码。require_relative'csv_reader'reader=CsvReader.newARGV.eachdo|csv_file_name|STDERR.puts"Processing#{csv_file_name}"reader.read_in_csv_d
如何将stderr和stdout重定向到Ruby脚本文件? 最佳答案 在Ruby脚本中,您可以使用IO#reopen重定向stdout和stderr方法。#a.rb$stdout.reopen("out.txt","w")$stderr.reopen("err.txt","w")puts'normaloutput'warn'somethingtostderr'$lsa.rb$rubya.rb$lsa.rberr.txtout.txt$caterr.txtsomethingtostderr$catout.txtnormaloutput
我正在测试将一些消息(带有puts、p警告等)放在控制台上的类。我只是想知道在RSpec测试期间是否有任何抑制此输出的能力? 最佳答案 我通过将$stout重定向到文本文件来抑制类中的puts输出。这样,如果我出于任何原因需要查看输出,它就在那里,但不会混淆我的测试结果。#spec_helper.rbRSpec.configuredo|config|config.before(:all,&:silence_output)config.after(:all,&:enable_output)endpublic#Redirectsstde
我想在一个block的持续时间内在Ruby脚本中临时重定向stderr,确保在block结束时将其重置为其原始值。我在ruby文档中找不到如何执行此操作。 最佳答案 在Ruby中,$stderr指的是当前作为标准错误的输出流,而STDERR是默认标准错误流。将不同的输出流临时分配给$stderr很容易。require"stringio"defcapture_stderr#TheoutputstreammustbeanIO-likeobject.Inthiscasewecaptureitin#anin-memoryIOobject