Tag: argv

使用ARGF在Ruby脚本中捕获Ctrl-D

我目前正在使用ARGV.gets从命令行捕获用户输入。 我想允许Ctrl-D终止脚本,但不知道如何使用Signal.trap或通过error handling来完成此操作。 我试图找到像Ctrl-D这样的陷阱代码列表,但无法找到我想要的东西。 同样,抢救Exception不起作用,因为Ctrl-D不会引发exception。 是否有Ctrl-D的陷阱代码或任何其他方式来检测这个? 例如……我目前能够通过捕获来检测Ctrl-C … # Trap ^C Signal.trap(“INT”) { # Do something exit } 或error handling…… def get_input input = ARGF.gets input.strip! rescue SystemExit, Interrupt => e # If we get here, Ctrl-C was encountered end 但是,我无法捕获或检测Ctrl-D。

Ruby的ARGV在Windows上可能是空的,这取决于运行脚本的方式

我的demo.rb: puts ARGV.size ARGV.each do |a| puts “Argument: #{a}” end 结果取决于我们如何运行脚本: > demo.rb foo bar 0 > ruby demo.rb foo bar 2 Argument: foo Argument: bar 为什么会这样? 这可以做一些事情吗? 编辑:感谢所有回复! 在这里我的设置: >assoc .rb .rb=rbFile >ftype rbFile rbFile=”c:\ruby-1.8.6\bin\ruby.exe” “%1” %* 所以它看起来正确。 但我发现了 >demo.rb foo bar 使用这样的命令行启动进程: “C:\ruby-1.8.7\bin\ruby.exe” “c:\demo.rb” 请注意,.rb与1.8.6相关联,但1.8.7已启动。 所以我猜其他一些东西搞砸了?

ARGV在Ruby中有什么意义?

ARGV在Ruby中有什么意义? first, second, third = ARGV puts “The script is called: #{$0}” puts “Your first variable is: #{first}” puts “Your second variable is: #{second}” puts “Your third variable is: #{third}” 运行我需要做的文件时,重点是什么: ruby ex1.rb 并输入我需要输入的第一,第二和第三个变量 ruby ex1.rb blah blah blah 这对所有运行该程序的人有何益处? 他们无论如何都做不到,因为我认为它是一个可执行文件: user = ARGV.first prompt = ‘> ‘ puts “Hi #{user}, I’m the #{$0} script.” […]