2

我有一个哈希数组:

[{number: 1},{number: 2}, {number: 3}, {number: 4}]

我需要根据自定义顺序对它们进行排序:

[3,4,1,2]

因此,结果应该是:

[{number: 3},{number: 4}, {number: 1}, {number: 2}]

我知道sort_by存在,但我只将它用于升序和降序。

我可能会发疯而不必担心性能,但是有没有一种有效的方法可以通过数组根据自定义顺序对这个哈希数组进行排序?

4

3 回答 3

5

根据人们对问题的解释方式,潜在的解决方案可能是:

input  = [{number: 6},{number: 10}, {number: 2}, {number: 8}]
hash   = Hash[input.map { |h| [h[:number], h] }]
order  = [8,10,6,2]
output = hash.values_at(*order)
# => [{:number=>8}, {:number=>10}, {:number=>6}, {:number=>2}]
于 2013-07-08T20:40:59.433 回答
1
input  = [{number: 6},{number: 10}, {number: 2}, {number: 8}] 
order  = [8,10,6,2]
order.map{|i| input.find{|h| h[:number] == i }}
# => [{:number=>8}, {:number=>10}, {:number=>6}, {:number=>2}]

更新了更短的代码:

input  = [{number: 6},{number: 10}, {number: 2}, {number: 8}] 
order  = [8,10,6,2]
input.group_by{|h| h[:number]}
# => {6=>[{:number=>6}],
#     10=>[{:number=>10}],
#     2=>[{:number=>2}],
#     8=>[{:number=>8}]}
input.group_by{|h| h[:number]}.values_at(*order)
# => [[{:number=>8}], [{:number=>10}], [{:number=>6}], [{:number=>2}]]
于 2013-07-08T20:35:48.730 回答
1

只需对中值的索引进行排序a

h = [{number: 1},{number: 2}, {number: 3}, {number: 4}]
a = [3,4,1,2]

p h.sort_by{|el| a.index(el[:number])}
# => [{:number=>3}, {:number=>4}, {:number=>1}, {:number=>2}]
于 2013-07-08T20:53:03.043 回答