在Rails中合并两个具有匹配ID的JSON

时间:2013-08-07 12:15:09

标签: ruby-on-rails ruby json ruby-on-rails-3

我有两个结构如下的JSON。第一个来自API:

[
  {
   "course_code":"Basic 101 - 0913",
   "name":"Basic 101",
   "start_at":"2013-09-16T00:00:00+02:00",
   "end_at":"2013-10-13T23:55:00+02:00",
   "workflow_state":"available"
  },
  {"course_code":"Medium 201 - 0913",
   "name":"Medium 201",
   "start_at":"2013-08-06T16:55:25+02:00",
   "end_at":null,
   "workflow_state":"available"
  }
]

第二个是我的数据库中的JSON导出:

[
  {
   "id":1,
   "course_id":"Basic 101",
   "name":"Basic Level",
   "description":"blablabla",
   "discipline_id":"1",
   "duration":"28",
   "created_at":null,
   "updated_at":null
  },
  {
   "id":2,
   "course_id":"Medium 201",
   "name":"Medium Level",
   "description":"blablabla",
   "discipline_id":"1",
   "duration":"28",
   "created_at":null,
   "updated_at":null
  }
]

我想将这两个JSON合并为一个,在第一个JSON中匹配:name,在第二个JSON中匹配:course_id

如果你知道在Rails中使用JSON的好教程,我真的很感兴趣。

2 个答案:

答案 0 :(得分:4)

这实际上不是JSON问题。

解析JSON数据时,它返回数组和哈希值。

情况下合并它的一种方法是循环访问数据并检查您想要/需要匹配的参数。找到匹配项后,您可以手动创建包含所需数据的新哈希值,也可以使用

hash1.merge(hash2)

http://www.ruby-doc.org/core-1.9.3/Hash.html#method-i-merge

将返回由两个Hashes组成的哈希 - 具有相同名称的属性将在第一个哈希中被覆盖。

答案 1 :(得分:3)

快速回答,让你知道去哪里。假设第一个json位于json1,第二个位于json2个变量中,此代码为:

require 'json'

arr1 = JSON.parse(json1)
arr2 = JSON.parse(json2)
mrg = []
arr1.each do |el1|
  arr2.each do |el2|
    if el2['course_id'] == el1['name']
      mrg.push(el1.merge(el2))
    end
  end
end

p mrg

将打印:

[
  {
   "course_code"=>"Basic 101 - 0913",
   "name"=>"Basic Level", 
   "start_at"=>"2013-09-16T00:00:00+02:00", 
   "end_at"=>"2013-10-13T23:55:00+02:00", 
   "workflow_state"=>"available", 
   "id"=>1, 
   "course_id"=>"Basic 101", 
   "description"=>"blablabla", 
   "discipline_id"=>"1", 
   "duration"=>"28", 
   "created_at"=>nil, 
   "updated_at"=>nil
  },
  {
   "course_code"=>"Medium 201 - 0913", 
   "name"=>"Medium Level", 
   "start_at"=>"2013-08-06T16:55:25+02:00", 
   "end_at"=>nil, 
   "workflow_state"=>"available", 
   "id"=>2, 
   "course_id"=>"Medium 201", 
   "description"=>"blablabla", 
   "discipline_id"=>"1", 
   "duration"=>"28", 
   "created_at"=>nil, 
   "updated_at"=>nil
  }
]