J'essaie de créer un hachage à partir d'un modèle.
C'est le type de hachage que je veux créer.
{"United Sates" => "us", "United Kingdom" => "uk" .....}
J'ai essayé tellement de façons maintenant que je tourne en rond.
Voici quelques-unes de mes mauvaises tentatives.
select = Array.new
countries.each do |country|
# select.Push({country.name => country.code })
# select[country.name][country.code]
end
h = {}
countries.each do |c|
# h[] = {c.name => c.code}
# h[] ||= {}
# h[][:name] = c.name
# h[][:code] = c.code
#h[r.grouping_id][:name] = r.name
# h[r.grouping_id][:description] = r.description
end
Veuillez quelques conseils.
Merci
Voici quelques alternatives à une ligne:
# Ruby 2.1+
name_to_code = countries.map{ |c| [c.name,c.code] }.to_h
# Ruby 1.8.7+
name_to_code = Hash[ countries.map{ |c| [c.name,c.code] } ]
# Ruby 1.8.6+
name_to_code = Hash[ *countries.map{ |c| [c.name,c.code] }.flatten ]
# Ruby 1.9+
name_to_code = {}.tap{ |h| countries.each{ |c| h[c.name] = c.code } }
# Ruby 1.9+
name_to_code = countries.to_a.each_with_object({}){ |c,h| h[c.name] = c.code }
Avec l'aimable autorisation du commentaire de @ Addicted ci-dessous:
# Ruby 1.8+
name_to_code = countries.inject({}){ |r,c| r.merge c.name=>c.code }
Avec Rails 4, vous pouvez simplement faire:
country_codes = Hash[Country.pluck(:name, :code)]
Je pense que c'est optimal parce que vous n'avez pas à charger un tas d'objets country et à les parcourir
La méthode pluck sur Rails 3 ne permet pas plus d'un attribut, mais vous pouvez faire quelque chose comme:
country_codes = Hash[Country.connection.select_rows(Country.select('name, code').to_sql)]
Définissez le hachage du pays, puis remplissez-le à partir de vos enregistrements.
countries_hash = {}
countries.each do |c|
countries_hash[c.name] = c.code
end
Ma réponse préférée de nos jours est d'utiliser pluck
et to_h
countries.pluck(:name, :code).to_h
# => {"United Sates" => "us", "United Kingdom" => "uk" .....}
pour les inverser et avoir le code en premier
countries.pluck(:code, :name).to_h
# => {"us" => "United Sates", "uk" => "United Kingdom" .....}