質問

この拡張を列挙可能にすると考えてください。

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"}

この拡張機能が不要になった、またはそれに十分近い組み込み関数はありますか?

役に立ちましたか?

解決

Enumerable.to_h シーケンスを変換します [key, value]sにa Hash だからあなたはすることができます:

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

複数の値が同じキーにマッピングされている場合、これは最後の値を保持します。

他のヒント

[   {:name=>'fred', :age=>32},
    {:name=>'barney', :age=>42},
].group_by { |person| person[:name] }

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

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

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top