我有一个关于将Nokogiri应用到我的Rails应用程序中的问题。我正在尝试从网站收集棒球统计数据并将数据显示到视图中。我成功地解析了数据,但是,我不确定以 RESTful 方式将代码存储在何处。
目前,我正在收集统计数据,将它们放在一个数组中,然后将它们与另一个数组(按等级、球队、联赛等)进行匹配。然后将这两个数组放入哈希中。有没有更有效的方法可以做到这一点(例如解析数据,然后将数据分配为哈希值,而排名、球队、联赛等被分配为哈希键)?
最后,我将Nokogiri调用放入我的控制器中,但我相信有更好的方法。Ryan Bate的Railscasts建议将Nokogiri调用放入耙子任务(/lib/tasks/)中。既然我希望网站每天收到新的棒球统计数据,我是否必须定期运行耙子任务?其次,我如何最好地将数据实现到视图中。
在线搜索带来了将其放入配置/初始值设定项的想法,但我不确定这是否是更好的解决方案。
以下是Nokogiri的电话:
task :fetch_mets => :environment do
require 'nokogiri'
require 'open-uri'
url = "http..."
doc = Nokogiri::html(open(url))
x = Array.new
doc.css('tr:nth-child(14) td').each do |stat|
x << stat.content
end
a = %w[rank team league games_total games_won games_lost ratio streak]
o = Hash[a.zip x]
statistics = Hash[o.amp{|(y,z)| [y.to_sym, z]}]
@order_stat = statistics.each{|key, value| puts #{key} is #{value}."}
end
如果我必须澄清任何事情,请告诉我,非常感谢。
数据库中创建一个名为 Statistics 的表,并在哈希中包含所有键(加上 created_on 和 id)。要保存您的统计数据,请执行以下操作:
Statistic.new(statistics).save
然后在您看来,拉出created_on最高的那个。要按 cron 计划运行 rake 任务,请查看何时。
此外,这样做可能更干净:
keys = %w[rank team league games_total games_won games_lost ratio streak].map(&:to_sym)
values = doc.css('tr:nth-child(14) td').map(&:text)
statistics = Hash[keys.zip values]