aHash = {"a"=>100, "b"=>200, "c"=>300, "d"=>400} => {"a"=>100, "b"=>200, "c"=>300, "d"=>400}
Converting this to an array results in the following:
aArray = aHash.to_a => [["a", 100], ["b", 200], ["c", 300], ["d", 400]]
Now, going the other direction is a bit more complicated as there doesn't seem to be a "to_h" method to convert from an array to a hash. By using the "inject" method, this is what I've come up with:
aArray.inject({}) {|a,b| a[b[0]]=b[1]; a}
I pass an empty hash as an argument to the inject method, which is the initial value for "a." Since "b" is the array of arrays, the values can be accessed via the bracket [] method and used to assign a key/value pair for the hash. Ruby's dynamic nature means we don't have to worry about initializing the hash size up front as this is all handled by the Ruby interpreter at runtime. Finally, there's a bit of trickery after the semi-colon. Every expression in Ruby returns a value, so by having the last value of our code block be the hash "a," we're able to prime the next value for "a" by doing this, thereby allowing us to incrementally build our hash.
A more visual way of seeing this in action is as follows:
aHash.to_a.inject({}) {|a,b| a[b[0]]=b[1]; puts a.inspect; a} {"a"=>100} {"a"=>100, "b"=>200} {"a"=>100, "b"=>200, "c"=>300} {"a"=>100, "b"=>200, "c"=>300, "d"=>400} => {"a"=>100, "b"=>200, "c"=>300, "d"=>400}
I'm eager to hear feedback on this if anyone is willing to share.
~Mike