40
output.sort_by {|k, v| v}.reverse

和钥匙

h = {"a"=>1, "c"=>3, "b"=>2, "d"=>4}
=> {"a"=>1, "c"=>3, "b"=>2, "d"=>4}

Hash[h.sort]

现在我有这两个。但我正在尝试按值按降序对哈希进行排序,以便它返回

=> {"d"=>4, "c"=>3, "b"=>2, "a"=>1 }

提前致谢。

编辑:让我发布整个代码。

def count_words(str)
  output = Hash.new(0)
  sentence = str.gsub(/,/, "").gsub(/'/,"").gsub(/-/, "").downcase
  words = sentence.split()
  words.each do |item|
    output[item] += 1 
  end
  puts Hash[output.sort_by{ |_, v| -v }]
  return Hash[output.sort_by{|k, v| v}.reverse]
end
4

2 回答 2

93

尝试:

Hash[h.sort.reverse]

这应该返回你想要的。

编辑:

按价值做到这一点:

Hash[h.sort_by{|k, v| v}.reverse]
于 2012-11-04T04:32:13.140 回答
28

试试这个:

Hash[h.sort_by{ |_, v| -v }]
于 2012-11-04T04:56:33.427 回答