我有一个哈希,看起来像这样
{"1-5 lbs"=>107342.43999999999, "31+ lbs"=>39838.58000000001, "21-30 lbs"=>19036.41, "11-20 lbs"=>39350.95, "6-10 lbs"=>41401.880000000005}
我想对它进行排序,使其看起来像这样
{"1-5 lbs"=>107342.43999999999, "6-10 lbs"=>41401.880000000005, "11-20 lbs"=>39350.95, "21-30 lbs"=>19036.41, "31+ lbs"=>39838.58000000001 }
逻辑存储在实例变量@weight_ranges
中
发布于 2013-07-16 07:24:56
您需要进入正则表达式来获取每个范围的第一个数字的值。
Hash[(@weight_ranges.sort_by {|key, value| key.scan(/\d+/)[0].to_i})]
要进一步细分,请执行以下操作:
# Sort the weight ranges by the first series of digits found in the key
x = @weight_ranges.sort_by {|key, value| key.scan(/\d+/)[0].to_i}
# Convert each inner Array to a key, value pair in a Hash
x = Hash[x]
发布于 2013-07-16 07:30:10
您将数据描述为散列。对于一个序列,你需要一个配对数组。下面这样的代码就可以做到:
list_of_pairs = @weight_ranges.keys.sort_by(&:to_i).map {|k| [k, @weight_ranges[k]]}
这利用了一个令人高兴的巧合,即to_i
在它看到的第一个非数字处停止。
校正
我刚刚了解到,在1.9版本中,Ruby散列是有序的!因此它很容易适应:
Hash[@weight_ranges.sort_by{|k,v| k.to_i}]
我将这两个想法都留在这里,因为第一个想法仍然适用于Ruby < 1.9。
https://stackoverflow.com/questions/17665517
复制相似问题