在Ruby-递归group_by中从排序数组创建嵌套哈希
发布时间:2020-12-16 21:47:56 所属栏目:百科 来源:网络整理
导读:我有一个对象数组,已根据这些对象的几个属性进行排序.按优先顺序,这些属性是foo,bar和baz.这意味着对象首先按foo排序;那么具有相同foo值的子序列按bar排序;那些具有相同foo和bar值的那些由baz排序. 我想将其转换为反映此分组的嵌套哈希.基本上我正在寻找一个
我有一个对象数组,已根据这些对象的几个属性进行排序.按优先顺序,这些属性是foo,bar和baz.这意味着对象首先按foo排序;那么具有相同foo值的子序列按bar排序;那些具有相同foo和bar值的那些由baz排序.
我想将其转换为反映此分组的嵌套哈希.基本上我正在寻找一个递归的Enumerable#group_by.键是foo,bar和baz的值;值可以是子哈希值,也可以是对象的数组.这是一个例子: [obj1,obj2,... objn].group_by_recursive(:foo,:bar,:baz) #=> { foo_val_1 => { bar_val_1 => { baz_val_1 => [ obj1,obj3 ],baz_val_2 => [ obj4,obj5 ] },bar_val_2 => { baz_val_1 => [ obj6,obj7 ],baz_val_2 => [ obj8 ] },},foo_val_2 => { ... },... } 解决方法
想出了一个很好的解决方案. Monkey-patch可以像这样:
module Enumerable def group_by_recursive(*props) groups = group_by(&props.first) if props.count == 1 groups else groups.merge(groups) do |group,elements| elements.group_by_recursive(*props.drop(1)) end end end end 您传递的属性可以是Procs或Symbols (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |