Rails 3:从数据数组中创建有效的JSON对象

时间:2011-05-13 10:44:24

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

我从MongoDB数据库(@bs)获取信息。 @bs有大量我不感兴趣的信息,所以我需要的是循环所有信息并用我需要的信息创建一个新对象。

为此,我创建了一个新数组(@final),我正在获取信息并将其添加到@final。信息似乎到了那里,但是,当我将它转换为JSON时,它不是一个有效的JSON对象。我打算在@final.json中创建的是:

{ Something: [ {Email: "xxx@xxx.com", At: "date", ....}, {...}, ....] }

但是当我做to_json时,我得到[["At: date","Email: mail_test@tidgdfp.org","Message-id: .....

   @bs = coll.find("headers.from" => email, "date" => {"$gte" => initial_date, "$lte" => Time.now.utc})

@bs = @bs.to_a.map { |obj| obj.delete("completo"); obj.delete("_id"); obj.delete("date"); obj.delete("headers" => "content_type"); obj }

@final = Array.new

@bs.each do |a|
  elem = Array.new
  elem << "At: #{a["date"]}"
  elem << "Email: #{a["headers"]["to"]}"
  elem << "Message: #{a["headers"]["message_id"]}"
  elem << "Type: #{a["headers"]["status"]}"
  @final << elem
end

puts @final  
@final = @final.to_json
puts @final["Email"]     

请帮忙。

由于

1 个答案:

答案 0 :(得分:1)

在循环中,创建哈希而不是数组。 to_json应该将其设为JSON对象。

@bs.each do |a|
  @final << { :At => a['date'], :Email => a['headers']['to'], :Message => a['headers']['message_id'], :Type => a['headers']['status'] }
end