この配列があるとします
x=[{:shipping_id=>2, :fsn=>"ab", :price=>300, :quantity=>1},
{:shipping_id=>3, :fsn=>"abc",:price=>500, :quantity=>2},
{:shipping_id=>2, :fsn=>"abcd",:price=>300,:quantity=>3},
{:shipping_id=>4, :fsn=>"abx", :price=>600,:quantity=>1},
{:shipping_id=>3, :fsn=>"abb", :price=>400,:quantity=>1}]
一意の配送 ID でグループ化したいのですが、この場合は shipping_id=2 でグループ化します。
だから私はx.select! {|y| y[:shipping_id]==2}
私に与えることをします
[{:shipping_id=>2, :fsn=>"ab",:price=>300,:quantity=>1}, {:shipping_id=>2, :fsn=>"abcd",:price=>300,:quantity=>3}]
しかし問題は、この形式で結果が欲しいことです
x={:shipping_id=>[2,2],:fsn=>["ab","abcd"],:price=>[300,300],:quantity=>[1,3]}
私は何をすべきか?これを数行で実行できますが、最適化された方法はありますか?
更新 -: 最終的な作業ソリューション (私のソリューション)-
コントローラ
new_params={}
order_hash.each do |row|
new_params=row.convert_to_params(new_params)
end
params.merge!(new_params)
モデル
def convert_to_params(new_params)
item=self.instance_values.symbolize_keys
item.each do |k, v|
new_params[k].nil? ? new_params[k]=[v] : new_params[k].push(v)
end
return new_params
end
これにより、私の望ましい結果が得られました