MZaragoza
MZaragoza

Reputation: 10111

how to group by in a array of hashes

I have a array of hashes

and I need to be able to group them by users.

      order = Order.find(options[:order_id])
      shipments = order.shipments.select {|shipment| shipment["roundtrip_shipment"] == nil }.collect {|o| {
        id: o.id,
        user_id: o.user_id,
        ...
      } }

I am having some problems in making a group by in the array.

I have tried to do shipments = order.shipments.group_by { |shipment| shipment[:user_id] }.count

but this always returns 1 when I know that have 2 users here Thanks for all the help

Upvotes: 0

Views: 232

Answers (1)

Sathish Subramanian
Sathish Subramanian

Reputation: 111

You can simply do as follow:

order = Order.find(options[:order_id])
shipments = order.shipments.where.not(roundtrip_shipment: nil).group_by(&:user_id).collect {|x,y| {x => y.map(&:id)} }

Upvotes: 3

Related Questions