有没有办法从Ruby显示运行(shell)命令,但也捕获输出?也许在一些宝石的帮助下?
显示的意思不是在最后打印,而是在显示时,用户可以获得运行慢速命令时所发生情况的反馈。
答案 0 :(得分:76)
您可以像这样运行系统调用:
`sleep --help`
或者像这样
system "sleep --help"
或者
%x{ sleep --help }
如果是system
,它将打印输出并返回true
或nil
,其他两种方法将返回输出
PS 哦。这是关于实时显示。
因此。你可以使用这样的东西:
system("ruby", "-e 100.times{|i| p i; sleep 1}", out: $stdout, err: :out)
实时打印数据并将其存储在变量中:
output = []
r, io = IO.pipe
fork do
system("ruby", "-e 3.times{|i| p i; sleep 1}", out: io, err: :out)
end
io.close
r.each_line{|l| puts l; output << l.chomp}
#=> 0
#=> 1
#=> 2
p output
#=> ['0', '1', '2']
或使用popen
output = []
IO.popen("ruby -e '3.times{|i| p i; sleep 1}'").each do |line|
p line.chomp
output << line.chomp
end
#=> '0'
#=> '1'
#=> '2'
p output
#=> ['0', '1', '2']
答案 1 :(得分:14)
您可以重定向输出
system 'uptime > results.log'
或保存结果。
result = `uptime`
result = %x[uptime]
见here。获取进度信息或output in realtime更复杂,我怀疑有一个简单的解决方案。也许可以使用process management functions之类的高级Open3.popen3。您还可以尝试使用pseudo terminal with pty和grap the output there。
答案 2 :(得分:9)
我使用open3
从ruby代码中捕获已执行shell命令的输出。
require 'open3'
stdout, stdeerr, status = Open3.capture3("ls")
puts stdout
答案 3 :(得分:0)
如果您愿意探索标准库之外的解决方案,您也可以使用Mixlib::ShellOut
来流输出并捕获它:
require 'mixlib/shellout'
cmd = 'while true; do date; sleep 2; done'
so = Mixlib::ShellOut.new(cmd)
so.live_stream = $stdout
so.run_command
out = so.stdout