簡體   English   中英

Ruby如何排序散列的哈希?

[英]Ruby how to sort hash of hashes?

我有那么深的哈希值哈希:

my_hash = { 
    :category_1 => {
        :solution_1 => { :order => 1 },
        :solution_2 => { :order => 2 }
    },
    :category_2 => {
        :solution_3 => { :order => 3 },
        :solution_4 => { :order => 4 }  
    }
}

我想通過鍵:order在:category_ *哈希下對:solution_ *哈希排序。 有什么建議么?

(固定)

假設您有以下年齡段的人:

people = {
  :fred => { :name => "Fred", :age => 23 },
  :joan => { :name => "Joan", :age => 18 },
  :pete => { :name => "Pete", :age => 54 }
}

使用sort_by獲取我們要去的地方:

people.sort_by { |k, v| v[:age] }
  # => [[:joan, {:name=>"Joan", :age=>18}], 
        [:fred, {:name=>"Fred", :age=>23}],
        [:pete, {:name=>"Pete", :age=>54}]]

好的,您沒有指定問題,所以我假設您要刪除一層。 我稍微更改了起始哈希值以實際查看排序是否有效:

my_hash = { 
    :category_1 => {
        :solution_1 => { :order => 2 },
        :solution_2 => { :order => 3 }
    },
    :category_2 => {
        :solution_3 => { :order => 4 },
        :solution_4 => { :order => 1 }  
    }
}

Hash[my_hash.inject({}) { |h, (k, v)| h.merge(v) }.sort_by { |k,v| v[:order] }]
#=> {:solution_4=>{:order=>1}, :solution_1=>{:order=>2}, :solution_2=>{:order=>3}, :solution_3=>{:order=>4}}

編輯:

考慮到您的澄清(並且仍然從我上面發布的修改后的未排序哈希開始):

sorted = my_hash.inject({}) do |h, (k, v)| 
  h[k] = Hash[v.sort_by { |k1, v1| v1[:order] }] 
  h 
end
#=> {:category_1=>{:solution_1=>{:order=>2}, :solution_2=>{:order=>3}}, :category_2=>{:solution_4=>{:order=>1}, :solution_3=>{:order=>4}}}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM