Превратить вложенный хеш в один хеш - PullRequest
0 голосов
/ 29 мая 2018

Я хочу превратить этот пример данных:

{"2018-05-16"=>{
  "ABCD"=>{929119=>0.14174555, 338296=>0.13858019, 332058=>0.13680765, 449614=>0.13679536}}}

в один массив хэшей:

[
  {"target_date"=>"2018-05-16", "location"=>"ABCD", "id"=>929119, "value"=>0.14174555},
  {"target_date"=>"2018-05-16", "location"=>"ABCD", "id"=>338296, "value"=>0.13858019},
  {"target_date"=>"2018-05-16", "location"=>"ABCD", "id"=>332058, "value"=>0.13680765},
  {"target_date"=>"2018-05-16", "location"=>"ABCD", "id"=>449614, "value"=>0.13679536}
]

1 Ответ

0 голосов
/ 29 мая 2018
h = { "2018-05-16"=>{
        "ABCD"=>{
          929119=>0.14174555,
          338296=>0.13858019,
          332058=>0.13680765,
          449614=>0.13679536
        }
      }
    }

dat, v = h.first
  #=> ["2018-05-16", {"ABCD"=>{929119=>0.14174555, 338296=>0.13858019,
                               332058=>0.13680765, 449614=>0.13679536}}]
loc, f = v.first
  #=> ["ABCD", {929119=>0.14174555, 338296=>0.13858019, 332058=>0.13680765,
  #             449614=>0.13679536}]
g = {"target_date"=>dat, "location"=>loc }
  #=> {"target_date"=>"2018-05-16", "location"=>"ABCD"}
f.map { |k,v| g.merge("id"=>k, "value"=>v) }
  #=> [{"target_date"=>"2018-05-16", "location"=>"ABCD", "id"=>929119,
  #     "value"=>0.14174555},
  #    {"target_date"=>"2018-05-16", "location"=>"ABCD", "id"=>338296,
  #     "value"=>0.13858019},
  #    {"target_date"=>"2018-05-16", "location"=>"ABCD", "id"=>332058,
  #     "value"=>0.13680765},
  #    {"target_date"=>"2018-05-16", "location"=>"ABCD", "id"=>449614,
  #     "value"=>0.13679536}]

Далее следует другой способ, который можно обобщить.

h.each_with_object([]) do |(k0,v0),arr|
  v0.each do |k1,v1|
    v1.each.map do |k2,v2| 
      arr << { "target_date"=>k0, "location"=>k1, "id"=>k2, "value"=>v2 }
    end
  end
end
  #=> <same as for first method>

Обратите внимание, что это работает с хэшами, имеющими несколько дат и / или местоположений, например, следующим:

{ "2018-05-16"=>{ "ABCD"=>{ 92=>0.14, 44=>0.13 }, "EFGH"=>{ 12=>0.24, 34=>0.23 } },
  "2018-05-17"=>{ "ABCD"=>{ 52=>0.34, 34=>0.33 }, "EFGH"=>{ 42=>0.44, 74=>0.43 } } }

Для этого хеша будет возвращен следующий массив.

[{"target_date"=>"2018-05-16", "location"=>"ABCD", "id"=>92, "value"=>0.14},
 {"target_date"=>"2018-05-16", "location"=>"ABCD", "id"=>44, "value"=>0.13},
 {"target_date"=>"2018-05-16", "location"=>"EFGH", "id"=>12, "value"=>0.24},
 {"target_date"=>"2018-05-16", "location"=>"EFGH", "id"=>34, "value"=>0.23},
 {"target_date"=>"2018-05-17", "location"=>"ABCD", "id"=>52, "value"=>0.34},
 {"target_date"=>"2018-05-17", "location"=>"ABCD", "id"=>34, "value"=>0.33},
 {"target_date"=>"2018-05-17", "location"=>"EFGH", "id"=>42, "value"=>0.44},
 {"target_date"=>"2018-05-17", "location"=>"EFGH", "id"=>74, "value"=>0.43}]
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...