草庐IT

ruby-on-rails - "require File.expand_path(' ../../config/environment', __FILE__)"到底做什么?

我一直在尝试更深入地了解Ruby,解构样板式rails应用程序似乎是了解编写跨不同文件和目录的Ruby应用程序的一些细节和优雅的好方法。在我当前的应用程序中,文件之间对“requires”的依赖变得有点问题(我发现我需要做一些事情,比如requires'../../../lib/helper'它变得有点丑陋。我注意到Rails应用程序似乎不受此影响。我确实注意到了这条线:requireFile.expand_path('../../config/environment',__FILE__)当我用谷歌搜索时,我发现很多关于Rails启动例程等的解释,但没有关于该行到底做什么的明确描述。在

ruby-on-rails - Rails 控制台 : Run a Ruby file several times

Rails提供了一个非常有用的控制台('script/console')。我编写了一个ruby​​文件并使用requirefoo.rb在控制台中运行它。第一次工作正常,但第二次和下一次requirefoo.rb没有运行我的脚本(require没有重新加载它)。你有什么提示/技巧吗? 最佳答案 require用于加载扩展-因此代码将执行一次,以使扩展出现在您的环境中,但随后的require不会做任何事情,因为工作已经完成完成。load,另一方面,每次加载并执行代码。如前所述,如果你只是想运行你的脚本并且你需要Rails环境,那么可以考

ruby-on-rails - Rails 控制台 : in `require' : cannot load such file -- readline (LoadError)

我的Rails应用程序出现一些错误,我正在尝试通过发出以下命令来启动Rails控制台:railsconsole无论我尝试什么,我总是得到同样的错误:/usr/local/rvm/rubies/ruby-2.1.1/lib/ruby/2.1.0/irb/completion.rb:9:in`require':cannotloadsuchfile--readline(LoadError)from/usr/local/rvm/rubies/ruby-2.1.1/lib/ruby/2.1.0/irb/completion.rb:9:in`'from/opt/mammie/web/icosole

ruby - 如何逐行读取 gzip 文件?

我有一个gzip文件,目前我是这样阅读它的:infile=open("file.log.gz")gz=Zlib::GzipReader.new(infile)output=gz.readputsresult我认为这会将文件转换为字符串,但我想逐行读取它。我想要完成的是该文件有一些警告消息和一些垃圾,我想grep这些警告消息然后将它们写入另一个文件。但是,一些警告消息会重复出现,因此我必须确保只对它们进行grep一次。因此,逐行阅读会对我有所帮助。 最佳答案 您应该能够像处理常规流一样简单地遍历gzip阅读器(accordingtot

ruby - 什么是 Ruby 文件 I/O 中的 EOFError?

officialdocumentation没有指定。我知道EOFError的意思是“文件结束错误”,但这到底是什么意思?如果文件阅读器到达文件末尾,对我来说这听起来不像是错误。 最佳答案 EOFError在所有IO中都很方便,该类是ruby​​中所有输入/输出的基础。现在还要记住核心Unix概念:一切皆文件。这包括套接字。因此,如果您打开了某个套接字并正在从中读取数据,则遇到文件结尾可能是一种异常(exception)情况。那里的所有示例都显示了EOFError的琐碎用法(在读取一些文本文件时),这些用法并不是很有用。但是,开始深入

ruby-on-rails - Rails 生成错误 : No such file or directory - getcwd

在新的Rails4.2项目上运行railsgenerate时,我不断收到错误:~/.rbenv/versions/2.2.0/lib/ruby/gems/2.2.0/gems/spring-1.3.0/lib/spring/configuration.rb:37:in`pwd':Nosuchfileordirectory-getcwd(Errno::ENOENT)我该如何解决这个问题? 最佳答案 该错误是由在后台运行的现有RailsSpring进程引起的。您可以通过运行psax|轻松解决此问题grepspring查找进程ID,然后将

ruby - 如何打开一个文件并搜索一个词?

如何使用Ruby打开文件并在其中搜索单词? 最佳答案 所有提出的解决方案的时间复杂度都是O(n)。为简单起见,我使用String#include?来检查单词。这可以用string=~regex形式的正则表达式代替。阅读完整文件并在其中搜索。File.read(filename).include?(word)如果您的文件非常大,这不是最佳解决方案,因为您会将整个文件读入内存,然后再开始搜索。你的内存复杂度是O(n)逐行读取文件并在每一行中搜索File.open(filename)do|f|f.any?do|line|line.incl

ruby-on-rails - `require' : cannot load such file -- capybara/rspec (LoadError)

我尝试测试我的项目。它以前是工作的,我不知道每当我输入bundleexecrspecspec/时我做了什么,它说cannotloadsuchfile--capybara/rspec(LoadError).我需要一个建议,作为新手,我需要一个建议来测试我在ruby​​onrails中的MVC。Gemfile:------------group:testdo#Prettyprintedtestoutputgem'turn',:require=>falsegem'minitest'gem'capybara','1.1.2'gem'rb-inotify','0.8.8'gem'libnotif

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-on-rails - "require File.dirname(__FILE__)"-- 如何安全地解除文件系统依赖?

我正在使用的一些Ruby库使用这样的require语句:requireFile.dirname(__FILE__)+'/specification_helper.rb'lib_dir=File.expand_path(File.join(File.dirname(__FILE__),"lib"))requireFile.join(File.dirname(__FILE__),'lib/tools','version')requireFile.expand_path(File.join(File.dirname(__FILE__),'datautils','conn'))这种格式不会使您