tags:

views:

42

answers:

3

Here's what I'm doing atm:

test = {
  'd' => 20,
  'b' => 40,
  'c' => 30,
  'a' => 50,
  'e' => 10
}

f = []
test.to_a.sort.each do |e|
  f << e[1]
end
puts f.join(' ')

Outputs:

50 40 30 20 10

Is there a more efficient/concise/better way to do this? And before someone says so, no, I can't use an array. :p

EDIT Sorry, posted the wrong code.

+2  A: 
test.values.sort.join(' ')
Chandra Patni
+3  A: 

In your title you mention that you want to get the values of the array sorted by their respective keys. But in your example, you actually just sort the values, regardless of the keys.

If that's what you want, simply use:

test.values.sort

But if you want to sort the values based on the keys, use this:

test.keys.sort.collect {|k| test[k]}
Mirko Froehlich
A: 
test.sort_by(&:first).map(&:last).join(' ')

Unfortunately, Ruby doesn't have a class for representing Hash entries (key-value pairs), but just uses a two-element array instead. If Ruby did have a dedicated class for key-value pairs, this would be much less opaque:

test.sort_by(&:key).map(&:value).join(' ')

And, of course, the fact that Enumerable#sort_by returns an Array, is also quite unfortunate. If it returned a SortedMap or something like that, it would be even nicer:

test.sort_by(&:key).values.join(' ')
Jörg W Mittag