extraire de la valeur spécifique d'un hachage multidimensionnel ruby par nom de clé
-
19-09-2019 - |
Question
disons que j'ai un hachage multidimensionnel, et dans l'un des subhashes i une paire de clés valeur => que je dois récupérer par clé. Comment puis-je faire?
Exemple hash:
h={:x=>1,:y=>2,:z=>{:a=>{:k=>"needle"}}}
h={:k=>"needle"}
est toujours: k, et j'ai besoin d'obtenir "aiguille"
i remarqué qu'il n'y a pas « aplatir » fonction pour hash en Ruby 1.8, mais si ce serait là, j'imagine que je voudrais juste faire
h.flatten[:k]
J'imagine que je dois écrire une fonction récursive pour cela?
Merci
La solution
Vous pouvez toujours écrire votre propre extension spécifique à la mission Hash qui fait le sale boulot pour vous:
class Hash
def recursive_find_by_key(key)
# Create a stack of hashes to search through for the needle which
# is initially this hash
stack = [ self ]
# So long as there are more haystacks to search...
while (to_search = stack.pop)
# ...keep searching for this particular key...
to_search.each do |k, v|
# ...and return the corresponding value if it is found.
return v if (k == key)
# If this value can be recursively searched...
if (v.respond_to?(:recursive_find_by_key))
# ...push that on to the list of places to search.
stack << v
end
end
end
end
end
Vous pouvez utiliser ce tout simplement:
h={:x=>1,:y=>2,:z=>{:a=>{:k=>"needle"}}}
puts h.recursive_find_by_key(:k).inspect
# => "needle"
h={:k=>"needle"}
puts h.recursive_find_by_key(:k).inspect
# => "needle"
puts h.recursive_find_by_key(:foo).inspect
# => nil
Autres conseils
S'il vous suffit de chercher la valeur clé, mais ne savent pas comment la clé est profonde, utiliser cet extrait
def find_tag_val(hash, tag)
hash.map do |k, v|
return v if k.to_sym == tag
vr = find_tag_val(v, tag) if v.kind_of?(Hash)
return vr if vr
end
nil #othervice
end
h = {message: { key: 'val'}}
find_tag_val(h, :key) #=> 'val'