1

我有一些看起来像这样的 JSON。我将它存储并读入一个对象@items。

[
 {
  {
    "id": "A",
    "description": "a_description"
  }, 
  {
    "id": "B",
    "description": "b_description"
  }
 }, 
 {
  {
    "id": "A",
    "description": "a_description"
  }, 
  {
    "id": "B",
    "description": "b_description"
  }
 }
] 

我的目标是显示一个包含两列的表,一列标记为 A,另一列标记为 B,其中每一行给出“a_description”和“b_description”。我不知道该怎么做。

4

2 回答 2

2

像这样的东西也许

<tr><th>A</th><th>B</th></tr>
<% @items.each do |item| %>
  <tr><td><%=item[0].description%></td><td><%=item[1].description%></td></tr>
<% end %>
于 2012-07-24T17:54:31.603 回答
2

啊,哈希数组和数组哈希问题。

要解决您的“乱序”问题,您首先必须转换

{
  "id": "A",
  "description": "foo"
},
{
  "id": "B",
  "description": "bar"
}

进入{"A" : "foo", "B" : "bar" }.

@new_items = @items.map do |item|
  output = {}
  item.each do |hash|
    output.merge!(hash["id"] => hash["description"])
  end
end

然后@new_items变成(故意乱序呈现,因为散列元素没有排序)

[
  { 
    "A": "a1_description",
    "B": "b1_description"
  },
  { 
    "B": "b2_description",
    "A": "a2_description"
  }
]

从那里开始,每一行只是一个哈希,因此您可以根据您所在的列取消引用您需要的值。

@new_items.each do |item|
  puts "#{item['A']} is paired with #{item['B']}"
end

如果您不想使用硬编码“A”和“B”,当然可以动态检索密钥.keys

于 2012-07-24T19:28:21.980 回答