活动记录和文件:如何使用我的数据编写Json文件?

时间:2013-03-07 11:53:55

标签: ruby-on-rails postgresql activerecord

如何将表事件中的数据写入json文件? 请参阅此代码:

在模型event.rb

 class Event < ActiveRecord::Base
  attr_accessible :name, :event_description, :start_at, :end_at, :status, :eventable_id
  has_event_calendar
  belongs_to :eventable, polymorphic: true
  after_save :write_json


end
def write_json
    Event.all.each do |event|
            @eventJson = {
            "id" => event.id,
            "start" => event.start_at,
            "end" => event.end_at,
            "title" => event.name,
            "body" => event.event_description,
            "status" => event.status
            } 

    end
    File.open("public/event.json","w") do |f|
      f.write(@eventJson.to_json)
    end 

 end

在文件Json中有一条记录,但在表event中有许多记录。保存记录后,如何将表event中的所有记录写入event.json文件?

公共/ event.json

{"id":35,"start":"2013-03-28T00:00:00Z","end":"2013-03-28T00:00:00Z","title":"1345edrewrewr","body":"123124","status":"Confirm"}

3 个答案:

答案 0 :(得分:12)

问题是您在循环中为@eventJson分配值,以便先前的值丢失。你应该使用一个数组:

def write_json
  events_json = []
  Event.all.each do |event|
    event_json = {
      "id" => event.id,
      "start" => event.start_at,
      "end" => event.end_at,
      "title" => event.name,
      "body" => event.event_description,
      "status" => event.status
    } 
    events_json << event_json
  end
  File.open("public/event.json","w") do |f|
    f.write(events_json.to_json)
  end 
end

答案 1 :(得分:2)

在这种情况下,您可能希望使用map代替each - 它更清洁。 鉴于您说方法在模型中,这就是它的外观。

class Event < ActiveRecord::Base
    ...

    def self.write_json
      record_json = self.all.map{ |record| { self.name => record.attributes } }.to_json
      File.open("#{Rails.root}/#{(self.name.underscore)}.json", "w") do |f|
        f.write record_json
      end 
    end
end

答案 2 :(得分:0)

您可以通过以下方式进行操作:

  def write_json
    File.open('public/event.json', 'w') { |f| f.write(Event.all.to_json) }
  end

如果你想保存特定的字段,你可以这样做:

  def write_json
    File.open('public/event.json', 'w') do |f|
      f.write(Event.select(:id, :start, :end, :title, :body, :status).to_json)
    end
  end