jjzjj

ruby-on-rails - 如何在 ruby​​ 中使用 next 和 inject

我正在编写如下代码:[1,2,3,4,5].inject([])do|res,a|res出现以下错误:NoMethodError:undefinedmethod`接下来它生成res变量为nil,如何解决这个问题?我尝试了各种方法,但无法使用ruby​​,我知道我提供的这个片段可以在没有next(a==4?res)的情况下完成,但在我的实际用例中,我有一些复杂的逻辑并且可以就这么简单。 最佳答案 替换res与nextres现在,它会起作用。例子:-#!/usr/bin/envrubyar=[1,2,3,4,5].inject([])d

ruby - 注入(inject)双符号运算符

我有一个注入(inject)电话[2,4,6].inject(true){|res,val|res&&val%2==0}并希望发送&&运算符以注入(inject)inject(0,:+)。我该怎么做? 最佳答案 你不能因为&&和||,与其他运算符不同,不是方法的语法糖(即没有称为&&或||的方法),因此您不能使用符号引用它们。但是您可以避免使用inject计算bool值数组的逻辑合取或析取,将其替换为all?或any?分别是因为对于任何数组都满足以下条件:ary.inject(true){|res,b|res&&b}==ary.al

Ruby 数组中最长的单词

我构建此方法是为了查找数组中最长的单词,但我想知道是否有更好的方法来完成此操作。我是Ruby的新手,只是将此作为学习inject方法的练习。它返回数组中最长的单词,或相等最长单词的数组。classArraydeflongest_word#Convertarrayelementstostringsintheeventthatthey'renot.test_array=self.collect{|e|e.to_s}test_array.inject()do|word,comparison|ifword.kind_of?(Array)thenifword[0].length==compari

ruby - 如何获取注入(inject)循环的每个值

我想获取inject的每个值。例如[1,2,3].inject(3){|sum,num|sum+num}返回9,我想获取循环的所有值。我尝试了[1,2,3].inject(3).map{|sum,num|sum+num},但没有成功。我写的代码是这样的,但是我觉得是多余的。a=[1,2,3]result=[]a.inject(3)do|sum,num|v=sum+numresult[4,6,9]有没有办法同时使用inject和map? 最佳答案 使用专用的Eumerator非常适合这里,但我会为此展示更通用的方法:[1,2,3].i

arrays - Ruby : Choosing between each, 映射、注入(inject)、each_with_index 和 each_with_object

当我多年前开始编写Ruby时,我花了一段时间才理解each之间的区别。和map.当我发现所有其他的时,情况只会变得更糟Enumerable和Array方法。借助官方文档和manyStackOverflowquestions,我慢慢开始明白那些方法做了什么。不过,这是我花了更长时间才理解的内容:我为什么要使用一种或另一种方法?有任何指导方针吗?我希望这个问题不会重复:我对“为什么?”更感兴趣。比“什么?”或“如何?”,我认为它可以帮助Ruby新手。 最佳答案 一个更tl;dr的答案:Howtochoosebetweeneach,map

ruby - 在 Ruby 中,为什么在使用 "do"和 "end"时不能将方法调用视为一个单元?

以下问题与问题“RubyPrintInjectDoSyntax”有关。我的问题是,我们能否坚持使用do和end并使其与puts或p一起使用?这个有效:a=[1,2,3,4]b=a.injectdo|sum,x|sum+xendputsb#printsout10所以,这样说对吗,inject是Array对象的一个​​实例方法,这个实例方法接受一段代码,然后返回一个数字。如果是这样,那么它应该与调用函数或方法并取回返回值没有区别:b=foo(3)putsb或b=circle.getRadius()putsb以上两种情况,我们可以直接说putsfoo(3)putscircle.getRadi

ruby-on-rails - SQL 注入(inject)和 ActiveRecord

这对SQL注入(inject)安全吗:Guest.where(:event_id=>params[:id])我在发送params[:id]时没有进行任何类型的清理。一般来说,所有这些activerecord方法都安全吗?(如where、joins等。)如果不是,安全的最佳做法是什么?另外,是否有任何我应该注意的警告/边缘情况?谢谢 最佳答案 ActiveRecord的所有查询构建方法,如where、group、order等等,都可以安全地防止SQL注入(inject)ASLONGAS您不向它们传递原始SQL字符串。这容易受到SQL注

arrays - Ruby:sum 与 inject(:+) 产生不同的结果

我注意到array.sum和array.inject(:+)产生不同的结果。这是什么原因?a=[10,1.1,6.16]a.inject(:+)#=>17.259999999999998a.sum#=>17.26 最佳答案 Array#sum的C实现委托(delegate)给Kahansummationalgorithm当它的一些输入是float时。这个算法......significantlyreducesthenumericalerrorinthetotalobtainedbyaddingasequenceoffinitepre

ruby - 使用#inject 连接数组中的字符串

我正在浏览anonlinelesson,通常有一个非常简单的单行解决方案。一个问题指出,给定以下数组:["emperor","joshua","abraham","norton"]我必须使用#inject获取所有名称的单个字符串,并用一个字符串连接在一起,每个名称的首字母都有上限,如下所示:"EmperorJoshuaAbrahamNorton"虽然这可以通过#map轻松完成和#join,此特定练习仅需要使用#inject。我想到了这样的事情:["emperor","joshua","abraham","norton"].inject("")do|memo,word|memo这会给我:

ruby - 在 Sinatra 应用程序中注入(inject)依赖项

我正在编写一个调用某些外部服务的Sinatra应用程序。我显然希望我的测试避免调用真正的服务所以假设现在我有这个classMyApp在我的测试中describe"myapp"doincludeRack::Test::Methodsdefapp()MyAppendit"shouldshowOKifcalltoexternalservicereturnedOK"do@external_service_handler=MiniTest::Mock.new@external_service_handler.expect:do_request,"OK"#Dotheinjectionget'/my