@cases => [{"name"=>"25 Cases per 60 day", "count"=>0},
{"name"=>"30 Cases for 60 days", "count"=>8},
{"name"=>"10 Cases per 60 days", "count"=>5}]
如果我有一个包含先前结果的对象,我如何按DESC顺序按count
排序?
要获取实例变量cases
,我做了
ClassName.all.collect{|e| {'name' => e.name, 'count' => e.contracts.count}}
答案 0 :(得分:15)
sorted = @cases.sort_by{ |hash| hash['count'] }.reverse
sorted = @cases.sort_by{ |hash| -hash['count'] }
sorted = @cases.sort_by{ |hash| -(hash['count'] || 0) }
第一个是最简单的。
第二个是我会做的。
如果某些哈希值缺少“计数”值,则可以执行第三步。