Rails 3.1 создавать записи, а не обновлять? - PullRequest
1 голос
/ 13 января 2012

В моем приложении Rails (3.1) есть следующее задание Nokogiri rake:

desc "Import incoming calls"
task :fetch_incomingcalls => :environment do

    # Logs into manage.dial9.co.uk and retrieved list of incoming calls.
    require 'rubygems'
    require 'mechanize'
    require 'logger'

    # Create a new mechanize object
    agent = Mechanize.new

    # Load the dial9 website
    page = agent.get("https://manage.dial9.co.uk/login")

    # Select the first form
    form = agent.page.forms.first
    form.username = 'username
    form.password = 'password'

    # Submit the form
    page = form.submit form.buttons.first

    # Click on link called Call Logs
    page = agent.page.link_with(:text => "Call Logs").click

    # Click on link called Incoming Calls
    page = agent.page.link_with(:text => "Incoming Calls").click

    # Output results to file
    # output = File.open("output.html", "w") { |file|  file << page.search("tbody td").text.strip }

    # Add each row to a new call record
    page = agent.page.search("table tbody tr").each do |row|
      next if (!row.at('td'))
      time, source, destination, duration = row.search('td').map{ |td| td.text.strip }
      Call.create!(:time => time, :source => source, :destination => destination, :duration => duration)
    end
end

Значение времени является первой строкой таблицы и уникально для каждого вызова (так как мы можем получить только один вызовза один раз).

То, что я хотел бы сделать, это использовать значение времени в качестве уникального идентификатора для моих журналов вызовов.

Таким образом, при очистке экрана он "обновит" существующийзвонки (это не изменится, но я могу думать только об импорте только новых звонков).

Если я установлю его на:

Call.find_all_by_time(nil).each do |call|

, а затем:

call.update_attribute(:time, time)

Затем он обновит существующие записи, но я хочу импортировать записи, которых еще нет в нашей базе данных, - на основе значения времени.

Любая помощь приветствуется!

1 Ответ

1 голос
/ 13 января 2012

Ты имеешь в виду это?

# Add each row to a new call record
page = agent.page.search("table tbody tr").each do |row|
  next if (!row.at('td'))
  time, source, destination, duration = row.search('td').map{ |td| td.text.strip }
  call = Call.find_or_create_by_time(time)
  call.update_attributes({:time => time, :source => source, :destination => destination, :duration => duration})
end
...