5

Enumerable へのこの拡張を検討してください。

module Enumerable

  def hash_on
    h = {}
    each do |e|
      h[yield(e)] = e
    end
    h
  end

end

次のように使用されます。

people = [
  {:name=>'fred', :age=>32},
  {:name=>'barney', :age=>42},
]
people_hash = people.hash_on { |person| person[:name] }
p people_hash['fred']      # => {:age=>32, :name=>"fred"}
p people_hash['barney']    # => {:age=>42, :name=>"barney"}

すでにこれを行う組み込み関数がありますか、またはこの拡張が必要な​​いほど十分に近いですか?

4

2 に答える 2

7

Enumerable.to_hは一連の[key, value]s を に変換するHashので、次のことができます。

people.map {|p| [p[:name], p]}.to_h

複数の値が同じキーにマップされている場合、最後の値が保持されます。

于 2015-07-02T15:21:02.183 に答える
5
[   {:name=>'fred', :age=>32},
    {:name=>'barney', :age=>42},
].group_by { |person| person[:name] }

=> {"fred"=>[{:name=>"fred", :age=>32}],
   "barney"=>[{:name=>"barney", :age=>42}]}

キーは配列の形式であり、複数のフレッドまたはバーニーズを持つ可能性がありますが、.map本当に必要な場合は再構築に使用できます。

于 2011-01-26T17:31:14.957 に答える