所以我建立了一个自定义的用户数组,如:
[["user1",432],["user1",53],["user9",58],["user5",75],["user3",62]]
我想按每个数组中的2n'd值对它们进行排序,从最大到最小。我有一种感觉,使用sort或sort_by进行数组是这样做的方法,但我不确定如何实现它
答案 0 :(得分:42)
如果您对sort_by
感兴趣,可以解构内部数组
array.sort_by { |_, x| x }.reverse
或调用索引运算符
array.sort_by { |x| x[1] }.reverse
而不是反转你可以否定从块返回的值。
array.sort_by { |_, x| -x }
array.sort_by { |x| -x[1] }
另一种选择是使用ampersand和Array#last
。
array.sort_by(&:last).reverse
使用sort
的解决方案可能是
array.sort { |x, y| y[1] <=> x[1] }
答案 1 :(得分:2)
使用此:array.sort_by { |a| -a[1] }
答案 2 :(得分:0)
反向sort_by
的另一个解决方案(-
在所有情况下都不起作用,请考虑按字符串排序):
class Invertible
include Comparable
attr_reader :x
def initialize(x)
@x = x
end
def <=> (x)
x.x <=> @x
end
end
class Object
def invertible
Invertible.new(self)
end
end
[1, 2, 3].sort_by(&:invertible) #=> [3, 2, 1]
["a", "b", "c"].sort_by(&:invertible) #=> ["c", "b", "a"]
在简单的情况下,它比反向慢,但对于复杂的排序可能会更好:
objs.sort_by do |obj|
[obj.name, obj.date.invertible, obj.score, ...]
end