jjzjj

group_enumerator

全部标签

ruby-on-rails - Enumerator.new 如何处理已通过的 block ?

我在理解Enumerator.new方法的工作原理时遇到了一些困难。假设文档中的示例:fib=Enumerator.newdo|y|a=b=1loopdoy[1,1,2,3,5,8,13,21,34,55]循环中断条件在哪里,它如何知道循环应该迭代多少次(因为它没有任何明确的中断条件并且看起来像无限循环)? 最佳答案 Enumerator使用Fibers在内部。您的示例等效于:require'fiber'fiber=Fiber.newdoa=b=1loopdoFiber.yieldaa,b=b,a+bendend10.times.m

arrays - Ruby:尝试在哈希数组上获取 Enumerator 时,nil:NilClass 的未定义方法 `[]'

我正在尝试循环哈希数组。当我到达获取枚举器开始循环的位置时,出现以下错误:undefinedmethod`[]'fornil:NilClass我的代码如下所示:defextraireAttributs(attributsParam)classeTrouvee=falsescanTrouve=falseownerOSTrouve=falseownerAppTrouve=falseresultat=Hash.new(0)attributs=Array(attributsParam)attributs.eachdo|attribut|#CRASHESHERE!!!typeAttribut=a

ruby-on-rails - rails group by 和 order by column

在我的Controller中,我得到了按类别分组的所有Extras:defindex@categories=Extra.all.group_by(&:category)end结果类似于哈希数组:{#=>[#,#=>[#,#]}我想按类别“排序”列而不是id排序,它应该如下所示:{#=>[#,#=>[#,#]}当我尝试时:defindex@categories=Extra.all.group_by(&:category).sort_by{|s|s[:sort]}end我得到“没有将符号隐式转换为整数”。那是因为我在“sort_by”中使用了一个符号吗? 最佳答

ruby - 了解 Ruby Enumerable#map(具有更复杂的 block )

假设我有一个函数defodd_or_evennifn%2==0return:evenelsereturn:oddendend我有一个简单的可枚举数组simple=[1,2,3,4,5]然后我用我的函数在map中运行它,使用一个do-endblock:simple.mapdo|n|odd_or_even(n)end#=>[:odd,:even,:odd,:even,:odd]如果不首先定义函数,我怎么能做到这一点?例如,#doesnotworksimple.mapdo|n|ifn%2==0return:evenelsereturn:oddendend#Desiredresult:#=>[

ruby - 如何将 Thor::Group 注册为带参数的子命令

这道题开始于here.但随着我对雷神的了解越来越多,情况发生了很大变化。我正在尝试创建一个带参数的Thor::Group子命令。奇怪的是,如果没有参数,它就可以工作。我可以使用Thor::Group作为子命令吗?这在我输入时有效:foocounterfoo/bin/foomoduleFooclassCLI但是当我输入时这不起作用:foocounter5moduleFooclassCLI','Countupfromtheinput.')endclassCounter:numeric,:desc=>"Thenumbertostartcounting"desc"Prints2numbersb

ruby - 如何简化此 Enumerator 代码?

为了简洁起见,我想优化以下代码。x1.each{|x|x2.each{|y|....xN.each{|z|yield{}.merge(x).merge(y)......merge(z)}}}假设x1,x2,...,xN是Enumerator对象。以上内容不够简洁它与x1、x2作为Array一起工作,但不是作为Enumerators因为应该为内部循环重置枚举器迭代器我试过了,但没有成功:[x1,x2,...,xN].reduce(:product).map{|x|x.reduce:merge}有什么建议吗?更新目前解决了:[x1,x2,...,xN].map(:to_a).reduce(

ruby - Ruby 中 Enumerator 类的用途是什么

如果我像这样创建一个枚举器:enum=[1,2,3].each=>#enum是枚举器。这个对象的目的是什么?我不能这样说:enum{|i|putsi}但我可以这样说:enum.each{|i|putsi}这似乎是多余的,因为Enumerator是用.each创建的。它似乎正在存储一些关于each方法的数据。我不明白这是怎么回事。我确信我们有这个Enumerator类是有一些合乎逻辑的原因的,但是它能做什么而Array不能呢?我想也许它是Array和其他Enumerable的祖先,但它似乎不是。Enumerator类存在的确切原因是什么?它会在什么情况下使用?

ruby - 为什么 Enumerable 在 Ruby 中没有长度属性?

至少在Ruby1.9.3中,Enumerable对象没有length属性。这是为什么? 最佳答案 Enumerable具有count方法,通常是枚举的直观“长度”。但为什么不叫它“长度”呢?好吧,因为它的运作方式非常不同。在Ruby的内置数据结构中,如Array和Hash,length只是检索数据结构的预先计算的大小。它应该总是立即返回。然而,对于Enumerable#count,它无法知道它在哪种结构上运行,因此没有快速、巧妙的方法来获取枚举的大小(这是因为Enumerable是一个模块,可以包含在任何类中)。它获得枚举大小的唯一

ruby - 从 Ruby 中的排序数组创建嵌套哈希——递归 group_by

我有一个对象数组,这些对象已根据这些对象的几个属性进行了排序。按照优先顺序,这些属性是foo、bar和baz。这意味着对象首先按foo排序;然后具有相同foo值的子序列按bar排序;然后具有相同foo和bar值的那些按baz排序。我想将其转换为反射(reflect)该分组的嵌套哈希。基本上我正在寻找递归Enumerable#group_by。键是foo、bar和baz的值;这些值将是对象的子哈希或数组。这是一个例子:[obj1,obj2,...objn].group_by_recursive(:foo,:bar,:baz)#=>{foo_val_1=>{bar_val_1=>{baz_

ruby - 如何在 Ruby 中获取 Enumerable 的第 n 个元素

例如,要返回我可以写的第10,000个质数:require'prime'Prime.first(10000).last#=>104729但是创建一个巨大的中间数组,只是为了检索它的最后一个元素感觉有点麻烦。鉴于Ruby是一种如此优雅的语言,我本以为会是这样的:Prime.at(9999)#=>104729但是没有Enumerable#at。上面的解决方法是有意的还是有更直接的方法来获取Enumerable的第n个元素? 最佳答案 我能想到的与假设的at方法最接近的是drop,它会跳过指定数量的元素。它试图返回一个实际的数组,所以如果