[英]Sort array of arrays by array value into hash in ruby
我有一个数组数组
[ [1,23,true], [2,33,false],[3,44,true] ]
我正在尝试根据每个内部数组的[2]值对数组进行排序,因此结果将是
true_values: [ [1,23,true],[3,44,true] ]
false_values: [ [2,33,false] ]
我可以选择数组对象,但是正在寻找一种简洁的排序和输出哈希的方法。
x = [ [1,23,true], [2,33,false],[3,44,true] ]
由于group_by
保持顺序,因此您可以在分组之前先进行排序:
p x.sort_by{|x|x[1]}.group_by(&:last) #=> {true=>[[1, 23, true], [3, 44, true]], false=>[[2, 33, false]]}
并且如果您不需要在哈希中保留true
/ false
值:
p x.sort_by{|x|x[1]}.group_by(&:pop) #=> {true=>[[1, 23], [3, 44]], false=>[[2, 33]]}
在这里,我首先使用Enumerable#group_by
将其按真或假分组,然后按v中找到的数组的第二个元素的内容对该散列进行排序。最后,我们调用.to_h
或进行散列以获得您概述的格式以上。
[10] pry(main)> arr
=> [[1, 23, true], [2, 33, false], [3, 44, true]]
[11] pry(main)> arr.group_by { |x| x[2] }.sort_by { |_, v| v.map { |i| i[1] } }.to_h
=> {true=>[[1, 23, true], [3, 44, true]], false=>[[2, 33, false]]}
这是一种方法:
arr = [[1, 44, true], [2, 33, false], [3, 23, true]]
arr.sort_by { |*_,tf| (tf && 0) || 1 }.chunk { |*_,tf| tf }.to_h
#=> {true=>[[1, 44, true], [3, 23, true]], false=>[[2, 33, false]]}
如果您希望通过arr[i][1]
打破联系,则:
arr.sort_by { |_,e,tf| [(tf && 0) || 1, e] }.chunk { |*_,tf| tf }.to_h
#=> {true=>[[3, 23, true], [1, 44, true]], false=>[[2, 33, false]]}
请注意,我已经更改了问题中给出的arr
来说明第二点。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.