问题
How should I convert a series of nested hashes (nested to arbitrary depth) to a series of nested OpenStructs? I'm loading in a big YAML file and I'm not enjoying accessing['everything']['like']['this']
.
I have found a few partial solutions using Google, but I thought this would make a nice question here.
Here is one of the solutions I found from http://andreapavoni.com/blog/2013/4/create-recursive-openstruct-from-a-ruby-hash:
# deep_struct.rb
require 'ostruct'
class DeepStruct < OpenStruct
def initialize(hash=nil)
@table = {}
@hash_table = {}
if hash
hash.each do |k,v|
@table[k.to_sym] = (v.is_a?(Hash) ? self.class.new(v) : v)
@hash_table[k.to_sym] = v
new_ostruct_member(k)
end
end
end
def to_h
@hash_table
end
end
Problem with this solution is that it doesn't take arrays into account.
回答1:
There is the solution (https://github.com/jsuchal/hashugar) i often use.
opts = Hashugar.new({:a => 1, 'b' => {:c => 2, :d => [3, 4, {:e => 5}]}})
But you also need to do:
opts.b.d.last.e
I do not understand how do you want to name array's getters. As Arup Rakshit sayed: give us yaml example and expected output or behavior.
来源:https://stackoverflow.com/questions/16990834/how-can-i-convert-nested-yaml-to-nested-arrays-and-openstructs-in-ruby