У меня есть такой массив хэшей:
[{"testPARAM1"=>"testVAL1"}, {"testPARAM2"=>"testVAL2"}]
И я пытаюсь сопоставить это с одним хешем следующим образом:
{"testPARAM2"=>"testVAL2", "testPARAM1"=>"testVAL1"}
Я добился этого, используя
par={}
mitem["params"].each { |h| h.each {|k,v| par[k]=v} }
Но мне было интересно, можно ли сделать это более идиоматическим способом (желательно без использования локальной переменной).
Как я могу это сделать?
ruby-on-rails
ruby
arrays
hash
Барт Платак
источник
источник
input.reduce(:merge)
?merge!
вместоmerge
него, будет изменен первый хеш (который может вам не понадобиться), но не будет создаваться промежуточный хеш для каждого нового слияния.Как насчет:
h = [{"testPARAM1"=>"testVAL1"}, {"testPARAM2"=>"testVAL2"}] r = h.inject(:merge)
источник
Используйте #inject
hashes = [{"testPARAM1"=>"testVAL1"}, {"testPARAM2"=>"testVAL2"}] merged = hashes.inject({}) { |aggregate, hash| aggregate.merge hash } merged # => {"testPARAM1"=>"testVAL1", "testPARAM2"=>"testVAL2"}
источник
Здесь вы можете использовать либо inject, либо reduce из класса Enumerable, так как оба они являются псевдонимами друг друга, поэтому ни один из них не дает преимущества в производительности.
sample = [{"testPARAM1"=>"testVAL1"}, {"testPARAM2"=>"testVAL2"}] result1 = sample.reduce(:merge) # {"testPARAM1"=>"testVAL1", "testPARAM2"=>"testVAL2"} result2 = sample.inject(:merge) # {"testPARAM1"=>"testVAL1", "testPARAM2"=>"testVAL2"}
источник