草庐IT

ruby - Ruby NOT Rails 中是否有复数函数?

我正在编写一些Ruby代码,而不是Rails,我需要处理这样的事情:found1matchfound2matches我安装了Rails,所以也许我可以在脚本顶部添加一个require子句,但是有人知道RUBY的复数字符串方法吗?如果脚本不是Rails但我安装了Rails,是否有一个我可以要求的类可以处理这个问题?编辑:所有这些答案都很接近,但我勾选了使它对我有用的那个。在编写Ruby而不是Rails代码时尝试使用此方法作为帮助程序:defpluralize(number,text)returntext.pluralizeifnumber!=1textend

ruby - "require"默认查找的路径是什么?

在Ruby中,有人告诉我这样做require"some_file"Ruby会在某些地方寻找文件。我知道它会查找some_file.rb,但默认情况下它在哪里查找? 最佳答案 这取决于您的平台,以及Ruby的编译方式,因此没有“那个”答案。你可以通过运行找到:ruby-e'puts$:'不过,通常情况下,您拥有标准、站点和供应商Ruby库路径,包括每个路径下的架构、版本和通用目录。​​ 关于ruby-"require"默认查找的路径是什么?,我们在StackOverflow上找到一个类似的

ruby - 在 ruby​​ 的同一目录中是否有更短的方法来要求文件?

是否有更短的方法来要求位于同一目录(与正在执行的脚本)中的文件?requireFile.expand_path(File.dirname(__FILE__)+'/some_other_script')我读到require"my_script"和require"./my_script"实际上会加载脚本两次(ruby不会识别它实际上是同一个脚本),这就是为什么推荐File.expand_path的原因:如果每次需要脚本时都使用它,那么它只会被加载一次。我觉得很奇怪,像Ruby这样简洁的语言似乎没有更短的解决方案。例如,python简单地有这个:import.some_other_modul

ruby-on-rails - "$"字符在 Ruby 中是什么意思?

使用RubyonRails有一段时间了,并决定查看实际源代码。从GitHub上获取repo并开始四处寻找。遇到一些我不确定它做了什么或它引用了什么的代码。我在actionmailer/test/abstract_unit.rb中看到这段代码root=File.expand_path('../../..',__FILE__)beginrequire"#{root}/vendor/gems/environment"rescueLoadError$:.unshift("#{root}/activesupport/lib")$:.unshift("#{root}/actionpack/lib"

ruby - 何时在 Ruby 中使用 `require` 、 `load` 或 `autoload` ?

我理解Ruby中require、load和autoload之间的细微差别,但我的问题是,你怎么知道要加载哪一个利用?除了能够在匿名模块中“包装”load之外,require似乎是首选。但是autoload允许您延迟加载文件——这听起来很棒,但我不确定您实际上比require获得了什么一种方法优于另一种方法吗?是否存在一种方法脱颖而出的情况? 最佳答案 通常,您应该使用require。load每次都会重新加载代码,因此如果您从多个模块执行此操作,将会做很多额外的工作。autoload的惰性在理论上听起来不错,但许多Ruby模块会做一些

ruby - 我安装了一个 gem 但 require 'gemname' 不起作用。为什么?

我真正要问的问题是为什么require不采用gem的名称。另外,如果没有,找到需要该死的东西的密咒的最简单方法是什么!?例如,如果我安装了memcache-client,那么我必须使用它来要求它require'rubygems'require'memcache' 最佳答案 我的系统似乎也不知道RubyGems的存在——除非我告诉它。“require”命令被RubyGems覆盖,因此它可以加载gems,但除非您已经需要RubyGems,否则它不知道如何执行此操作。所以如果你自己写,你可以这样做:require'rubygems'req

ruby-on-rails - load 与 Ruby 中的 require 有何不同?

在RubyonRails应用程序中,load和require之间有什么主要区别吗?还是它们都具有相同的功能? 最佳答案 require在所有定义的搜索路径中搜索库并追加.rb或.so到您输入的文件名。它还确保图书馆只是包括一次。因此,如果您的应用程序需要库A和B,并且库B也需要库A,那么A将只加载一次。使用load,你需要添加库的全名,每次你加载它调用load-即使它已经在内存中。 关于ruby-on-rails-load与Ruby中的require有何不同?,我们在StackOverf

ruby-on-rails - 为 Rails 4 禁用 ActiveRecord

我想在Rails4中禁用ActiveRecord。我在config/application.rb中做了以下操作requireFile.expand_path('../boot',__FILE__)#require'rails/all'--commentedrequire"action_controller/railtie"require"action_mailer/railtie"#require"active_resource/railtie"noneed#require"rails/test_unit/railtie"noneed#require"sprockets/railtie

Ruby:require 与 require_relative - 在 Ruby <1.9.2 和 >=1.9.2 中运行的最佳实践

如果我想要,最佳实践是什么requireRuby中的一个相关文件and我希望它在1.8.x和>=1.9.2中工作?我看到几个选项:就做$LOAD_PATH忘记一切做$LOAD_PATHrequire'./path/to/file'检查是否RUBY_VERSIONrequire_relative作为require,使用require_relative事后需要的地方检查是否require_relative已经存在,如果存在,尝试像之前的情况一样继续使用奇怪的结构,例如requireFile.join(File.dirname(__FILE__),'path/to/file')-唉,它们似乎

ruby - 为什么 Ruby 1.9.2 从 LOAD_PATH 中删除 ".",还有什么替代方案?

Ruby1.9.2的最新变更集不再生成当前目录.你的一部分LOAD_PATH.我有很多Rakefile假设.是LOAD_PATH的一部分,所以这打破了他们(他们报告所有基于项目路径的require语句“没有这样的文件要加载”)。这样做有什么特别的理由吗?至于修复,添加$:无处不在,但似乎非常骇人听闻,我不想那样做。使我的Rakefiles1.9.2+兼容的首选方法是什么? 最佳答案 它被认为是“安全”风险。你可以使用绝对路径绕过它File.expand_path(__FILE__)etal或做require'./filename'(