我写了一个在config/中查找配置文件的gem。这工作正常,但如果用户更改任何配置,他们必须停止程序并在我的gem加载新配置之前重新启动它。这将要求他们在每次更改时重新启动整个Rails应用程序,这并不理想。有没有办法“重新要求”一个文件,以便它重新加载它而不是使用缓存的版本。 最佳答案 您可以使用load代替require。这将加载文件,而不管它之前是否已经加载过。请注意,对于load,您需要指定.rb扩展名,它对于require是可选的。所以require"path/to/myconfig"变成了load"path/to/my
我只是想了解自己。我正在使用nokogirigem(用于解析HTML)。如果我能正确打开URL,我需要使用gem“open-uri”中的方法。但是当我将它包含在我的Gemfile中时(在Windows开发人员的机器上):gem'open-uri'-捆绑安装时出现找不到gem的错误。因此,如果我使用require'open-uri'-它可以正常工作。那么有人能解释一下这是怎么回事吗? 最佳答案 您正在使用bundler对于您的gem依赖项,您做对了,但是OpenUri是Ruby标准库的一部分。这就是为什么如果您想在代码中使用它,您仅需
我正在尝试请求一个我在另一个文件中创建的rake文件。这两个文件位于两个不同的目录中。我在第一个文件的顶部有require,在require之后的引号内有第二个文件的名称。它告诉我它无法加载这样的文件。这是否意味着因为它在不同的目录中找不到它?我尝试坚持第二个文件的完整路径,但它仍然无法加载文件。有谁知道如何将第二个文件加载到第一个文件中?提前致谢 最佳答案 require将仅在一组称为“加载路径”的位置中搜索文件。您可以在脚本或irbsession中使用全局变量$LOAD_PATH查看加载路径。如果它不在加载路径中,则不会找到它。
我在用Ruby导入文件时遇到了一个非常菜鸟的问题。我正在WindowsXP中制作一个Ruby应用程序。该应用程序的所有类文件都在"C:/Documents/Prgm/Surveyor_Ruby/lib"中。但是当我在另一个文件中require一个文件时,ruby和irb都找不到所需的文件。当前目录的内容:C:\Documents\Prgm\Surveyor_Ruby\lib>dirVolumeindriveChasnolabel.VolumeSerialNumberisAAAA-BBBBDirectoryofC:\Documents\Prgm\Surveyor_Ruby\lib10/0
我正在尝试将我的Rails应用程序部署到Heroku以按照以下说明进行测试:http://devcenter.heroku.com/articles/rails3#prerequisites这是我要运行的命令:herokucreate--stackcedar我收到此错误消息:/home/sergio/.rvm/rubies/ruby-1.9.3-p125/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.rb:36:in`require':cannotloadsuchfile--readline(LoadError)from/home/s
我试图让Capybara在一个简单的Ruby脚本中运行——即没有/在Rails之外。这是脚本:require'rubygems'require'capybara'require'capybara/dsl'includeCapybaraCapybara.current_driver=:seleniumCapybara.app_host='http://www.google.com'visit('/')问题是,当我运行它时,我得到了这个错误:NameError:uninitializedconstantCapybara::Sessionattoplevelindsl.rbatline52m
我见过许多包含这一行的Ruby代码示例(例如,http://www.sinatrarb.com/)。这个要求的目的是什么?#require'rubygems'require'sinatra'get'/hi'do"Helloworld!"end在所有情况下,代码都可以在没有此行的情况下工作。 最佳答案 require'rubygems'将调整Rubyloadpath允许您成功地require通过rubygems安装的gem,而不会出现LoadError:nosuchfileto加载--sinatra。来自rubygems-1.
如何在Ruby中发出带参数的HTTPGET请求?POSTing时很容易做到:require'net/http'require'uri'HTTP.post_formURI.parse('http://www.example.com/search.cgi'),{"q"=>"ruby","max"=>"50"}但我看不到使用'net/http'将GET参数作为散列传递的方法。 最佳答案 从版本1.9.2(我认为)开始,您实际上可以将参数作为散列传递给URI::encode_www_form像这样的方法:require'uri'uri=UR
我正在尝试从“require”中解救出来:没有这样的文件可以按顺序加载到ruby中提示用户指定-I标志,以防他忘记这样做。基本上代码如下所示:beginrequire'someFile.rb'rescueputs"someFile.rbwasnotfound,haveyou"puts"forgottentospecifythe-Iflag?"exitend我原以为rescue部分会在找不到someFile.rb的情况下接管执行,但我的假设是错误的。 最佳答案 没有参数的rescue只拯救StandardErrors。LoadEr
在Ruby中使用类文件时,您是将“requires”语句放在文件的顶部,还是放在类定义中? 最佳答案 从技术上讲,这并不重要。require只是一个普通的方法调用,它被调用的范围不会影响它的工作方式。放置的唯一区别在于它会在计算放置它的任何代码时执行。实际上,您应该将它们放在顶部,以便人们一眼就能看到文件的依赖项。这是它的传统位置。 关于ruby-Ruby'require'语句是在类定义内部还是外部?,我们在StackOverflow上找到一个类似的问题: h