如果你拿哈希:
{
:element => {
:to_find => 'found me'
},
:element_2 => {
:inner_element => {
:n_elements => {
:to_find => 'found me'
}
:do_not_touch => 'still here'
}
}
}
我怎样才能找到并替换:to_find并更改'?
我试过了
(hash).update(hash){|k,v| (([:to_find].include? k) ? 'changed' : v}
然而,这只是一个深度。
我可以创建一个递归函数,例如:
def change_keys(hash, keys, new_value)
(hash).update(hash) do |k,v|
if (keys.include? k)
new_value
else
if v.class == Hash
find_key(v)
else
v
end
end
end
end
我已经测试过运行它,有效:
change_keys(my_hash, [:to_find], 'changed')
但是,有更清洁的方式吗?
答案 0 :(得分:3)
递归方法是可行的方法,但你可以让它变得更干净......
def change_keys(hash, keys, new_value)
keys.each { |k| hash[k] = new_value if hash.has_key?(k) }
hash.values.each { |v| change_keys(v, keys, new_value) if v.class == Hash }
end
答案 1 :(得分:0)
我认为你可以尝试这样的事情
eval({
:x => 'y',
:q =>
{
:x => 'y',
:s =>
{
:x => 'y'
}
}
}.to_s.gsub(/:x=>"."/, ':x=> "new_value"')
)