草庐IT

ruby - Ruby 通用定界输入的优缺点是什么? (百分比语法)

我不明白为什么有些人在ruby​​中大量使用百分比语法。例如,我正在阅读rubypluginguide它使用如下代码:%w{modelscontrollers}.eachdo|dir|path=File.join(File.dirname(__FILE__),'app',dir)$LOAD_PATH每次看到这样的东西,我都得去查找百分比语法引用,因为我不记得%w是什么意思。这种语法真的比["models","controllers"].each...更可取吗?我认为在后一种情况下,我定义了一个字符串数组更清楚,但在前一种情况下——尤其是对于学习ruby​​的人来说——似乎不太清楚,至少

ruby - 为什么是 RVM 全系统?

我已经设置了一个Rails生产环境:*名为deploy的用户下的Rails应用程序。*部署用户只是一个没有sudo权限的普通用户。*部署用户使用自己的沙盒rvm(没有系统范围),所以任何ruby​​都只在部署用户下。*运行apache的用户无权访问ruby​​环境,也不需要访问权限,因为apache不需要ruby​​。*deploy用户运行一个unicorn集群。这个rvm非系统范围的配置对我来说非常有用。我看到的优势是:*我不需要在每次安装gem时都使用sudo。*Ruby是沙盒化的,只对deploy用户可用,通过最小化提高了系统的安全性。Apache不关心ruby​​,所以它无法访

ruby - 切换 bool 变量的最佳方法是什么?

在true和false之间进行变量切换的最佳方法是什么?一个明显的方法是初始化一个变量foo:foo=false并做:foo=foo.!每次我想切换的时候。但是当变量名很长时,这会变得冗长。有没有更简单的方法来做到这一点(通过使用诸如语法糖、原始类之类的东西)?特别是,我想知道是否有一种方法可以通过只给它一个方法来切换:foo.some_method 最佳答案 您可以使用XOR运算符。foo^=truefoo=falsefoo^=true#=>truefoo^=true#=>false

ruby - 通过 Ruby 拆分字符串以获取所有子字符串的最佳方法是什么?

比如单词“stack”,我想得到一个像这样的数组:['s','st','sta',...'stack','t','ta',...,'c','ck','k']我是通过这样的代码做到的:defsplit_word(str)result=[]chas=str.split("")len=chas.size(0..len-1).eachdo|i|(i..len-1).eachdo|j|result.push(chas[i..j].join)endendresult.uniqend有没有更好、更干净的方法来做到这一点?谢谢。 最佳答案 defs

ruby - Ruby 的带编号的全局变量是什么

值$1、$2、$'、$`在Ruby中是什么意思? 最佳答案 它们是从最近的模式匹配中捕获的(就像在Perl中一样;Ruby最初从Perl中提取了很多语法,尽管现在已经基本克服了:)。$1,$2等引用正则表达式中带括号的捕获:给定/a(.)b(.)c/,$1将是a之间的字符和b和$2b之间的字符和c.$`和$'分别表示匹配整个正则表达式(它本身在$&中)的字符串之前和之后的字符串。这些实际上有一定的意义,即使只是在历史上;你可以在perldocperlvar中找到它,它通常可以很好地记录预期的助记符和Perl变量的历史,并且大部分仍然

ruby - $:<< "." do to Ruby's require path? 是什么意思

我不明白$:的意思在Ruby中。我将Ruby升级到1.9.1,但程序无法运行。我的同学告诉我,我应该添加$:什么是$:做? 最佳答案 $:是包含构成Ruby加载路径的路径数组的变量将一个项目追加到数组的末尾.引用当前目录123|||VVV$:所以你正在将当前目录添加到Ruby的加载路径引用资料:可以在ExecutionEnvironmentVariables中找到此页面的一部分来自ThePragmaticProgrammersGuideAnarrayofstrings,whereeachstringspecifiesadirecto

ruby-on-rails - 测试 'create' Controller 操作的正确方法是什么?

我正在使用RubyonRails3.2.2、Rspec2.9.0和RspecRails2.9.0。我想测试createController操作,但我不知道如何使其成为“正确”/“正确”的方式。我“搭建”了模型、Controller、View……文件,因此在这些文件中我拥有由RubyonRails生成器生成的通用代码;在我的规范文件中,我有:it"assigns@article"donew_article=FactoryGirl.build(:article)Article.should_receive(:new).and_return(new_article)post:createas

ruby-on-rails - Mongoid::Document 是 GlobalID::ActiveJobs 的标识吗?

根据ActiveJobsguide,第8节,它说:ThisworkswithanyclassthatmixesinGlobalID::Identification,whichbydefaulthasbeenmixedintoActiveModelclasses.Mongoid::Document混合ActiveModel::Model,但我找不到GlobalID::Identification在它的included_modules中。GlobalID::Identification在哪里定义?我可以有效地使用任何Mongoid::Document吗?为我的ActiveJobs?

ruby - 在 Ruby 中执行多个要求的最佳方法是什么?

我不确定我是否已经解决了这个问题,但我想知道在ruby​​脚本中执行多个要求的最佳方法是什么。我提出了几个基本示例,我将在下面概述这些示例,但我不确定是否有最佳实践——我的搜索结果一无所获。0)一堆包含和异常(我会把救援排除在外)require'rubygems'require'builder'1)字符串数组torequire=['rubygems','builder']begintorequire.eachdo|req|requirereqrescueLoadError=>e#Notsureifthisisgreateitherputs"Missingrequiredgem:"+e.

ruby - =~ 和/\在 Ruby 中是什么意思?

我一直在自学Ruby,对于我试图解决的某个问题,我注意到很多人在他们的代码中使用=~和/\代码。我不太确定它们是如何工作的,只是想得到一个解释。例如,我正在查看某人为这个PigLatin翻译器编写的代码,这是我第一次看到这些被使用。defpiglatin(word)ifword=~(/\A[aeiou]/i)word=word+'ay'elsifword=~(/\A[^aeiou]/i)match=/\A[^aeiou]/i.match(word)word=match.post_match+match.to_s+'ay'endwordend我只是对/\斜杠和=~感到困惑