В моем приложении 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)
Затем он обновит существующие записи, но я хочу импортировать записи, которых еще нет в нашей базе данных, - на основе значения времени.
Любая помощь приветствуется!