jjzjj

scripting

全部标签

ruby - 我怎样才能可靠地发现 Ruby 可执行文件的完整路径?

我想写一个脚本,打包成一个gem,它将修改它的参数,然后用修改后的参数exec一个新的ruby进程。换句话说,类似于修改其参数然后执行exec$SHELL$*的shell脚本。为此,我需要一种可靠的方法来发现正在执行当前脚本的ruby​​可执行文件的路径。我还需要获取传递给当前进程的完整参数——Ruby参数和脚本参数。 最佳答案 Rake源代码是这样的:RUBY=File.join(Config::CONFIG['bindir'],Config::CONFIG['ruby_install_name']).sub(/.*\s.*/m,

ruby-on-rails - ruby sftp 错误

我正在尝试使用ruby​​将文件上传到我的sftp,我可以通过ssh登录,一切正常,但我的脚本失败了......这是我的小脚本require'rubygems'require'net/sftp'Net::SFTP.start('50.5.54.77','root',:password=>'PASSWORD')do|sftp|#uploadafileordirectorytotheremotehostsftp.upload!("/Users/tamer/sites/sandbox/move_me.txt","/home")end但我一直收到这个错误rubysftp.rb/Library/

ruby-on-rails - Ruby - 批量读取文件

我正在读取一个大小为10mb且包含一些ID的文件。我将它们读入ruby列表。我担心将来可能会导致内存问题,因为文件中的id数量可能会增加。有没有一种批量读取大文件的有效方法?谢谢 最佳答案 与LazyEnumerators和each_slice,您可以两全其美。中间切线不用担心,可以批量迭代多行。batch_size可以自由选择。header_lines=1batch_size=2000File.open("big_file")do|file|file.lazy.drop(header_lines).each_slice(batch

ruby - 如何在 crontab 中测试东西

这一直在我身上发生:1)我写了一个脚本(ruby,外壳等)。2)运行它,它有效。3)把它放在crontab中,让它在几分钟内运行,所以我知道它从那里运行。4)不行,无错误跟踪,返回步骤2或31000次。当我的ruby​​脚本在crontab中失败时,我真的不知道为什么它会失败,因为当我像这样通过管道输出时:rubyscript.rb>&/path/to/output我大概得到了脚本的输出,但我没有从中得到任何错误,也没有得到来自bash的错误(比如没有找到ruby​​或文件不存在)我不知道设置了什么环境变量,也不知道它是否有问题。事实证明,要从crontab运行ruby​​脚本,您必须

脚本底部的 Ruby 方法?

我使用的是ruby​​1.8.7。我可以发誓我之前已经在脚本底部编写了我的函数并且运行良好。我必须将它们放在顶部吗?这似乎是他们现在唯一的工作方式。没什么大不了的。我只是更喜欢将它们放在底部,所以我想我会问。 最佳答案 您可以在一个或多个BEGINblock中执行初始化代码(继承自Perl,后者继承自awk)。can_i_do_this?#=>yesBEGIN{defcan_i_do_this?puts"yes"end}为了完整起见,还有ENDblock:END{can_i_do_this?#=>yes}defcan_i_do_th

ruby - 在 OSX 上以编程方式使用 Dictionary.app 的词库功能(最好通过 Ruby)

我需要编写一个Ruby方法,它接受一个词,通过OS10.5的Dictionary.app的同义词库函数运行它,并返回备选词。如果Ruby方法最终调用命令行,那很好;我只需要能够从Ruby以编程方式完成它。查看RubyOSA后,我意识到可以通过某些词典服务访问词典[http://discussions.apple.com/thread.jspa?threadID=1561332],但我真的不明白。有人看到一个简单的解决方案吗?我也准备制作一个Automator工作流程并从命令行调用它,但由于某种原因我无法从shell中正确地为“获取定义”函数提供一个词(它一直说它不能'找到这个词,但是当

Ruby 需要 "no such file to load"错误但在路径中很明显

我一直在尝试让一个ruby​​文件要求另一个ruby​​文件,我觉得我快疯了。我的设置如下“/raid1/ruby-code/benchmark/”中的两个文件CommandRunnerBenchmarkerBenchmarker是此时的主要程序,它需要CommandRunner,我尝试了很多不同的东西,但都没有用。以下是我放在Benchmarker开头的所有内容的列表require'CommandRunner'require'./CommandRunner'$LOAD_PATH.unshiftFile.expand_path(File.dirname($PROGRAM_NAME))r

ruby - Ruby 能否访问出现的 shell 命令的输出?

我的Ruby脚本正在运行一个shell命令并解析它的输出。但是,似乎该命令首先执行并将输出保存在数组中。我希望能够在打印时实时访问输​​出行。我玩过线程,但还没有让它工作。有什么建议吗? 最佳答案 您正在寻找管道。这是一个例子:#Thisexamplerunsthenetstatcommandviaapipe#andprocessesthedatainRubyasitcomebackpipe=IO.popen("netstat3")while(line=pipe.gets)printlineprint"and"end

ruby-on-rails - "ruby script/plugin"是命令吗?

我按照在线教程在AppEngine上创建RubyonRails应用程序。有一个其他人可以运行的命令,但它没有在我的Ubuntu10.10上运行:rubyscript/plugininstallhttp://svn.avdi.org/nulldb/trunk/当我尝试运行它时,它会提示:ruby1.8:Nosuchfileordirectoryscript/plugin(LoadError)我的电脑出了什么问题?ruby-v==>1.8.7rails-v==>2.3.10gem-v==>1.3.7 最佳答案 如果使用rails3,cd

ruby-on-rails - Vagrant/VirtualBox VM 配置 : rbenv installs successfully but subsequent uses in script fail

我正在使用Vagrant+VirtualBox为我的Rails应用设置虚拟机。我正在清理Vagrantfile中引用的.sh配置脚本,如下所示:config.vm.provision"shell",path:"script/provision-script.sh"配置脚本做了很多事情,但最后它应该安装rbenvRuby版本控制,然后使用rbenv安装Ruby2.2.1。供应脚本的那部分看起来像这样:echo"settinguprbenv"#executetheremainingcommandsasvagrantuser,insteadofrootsudo-H-uvagrantbash-