如何在哈希数组中分组
how to group by in a array of hashes
我有一个哈希数组
我需要能够按用户对它们进行分组。
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,
...
} }
我在数组中创建分组时遇到一些问题。
我试过了shipments = order.shipments.group_by { |shipment| shipment[:user_id] }.count
但是当我知道这里有 2 个用户时,这总是 returns1
感谢大家的帮助
您可以简单地按照以下步骤操作:
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)} }
我有一个哈希数组
我需要能够按用户对它们进行分组。
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,
...
} }
我在数组中创建分组时遇到一些问题。
我试过了shipments = order.shipments.group_by { |shipment| shipment[:user_id] }.count
但是当我知道这里有 2 个用户时,这总是 returns1 感谢大家的帮助
您可以简单地按照以下步骤操作:
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)} }