我有一些返回错误的代码,我不明白为什么。我有点像一个新来的鲁比,但我觉得我已经到了:
line 27: NoMethodError "each" for NilClass
我使用的代码如下:
require 'rubygems'
require 'nokogiri'
require 'sqlite3'
FIELDS = [['cityselect', 'VARCHAR'],['match', 'VARCHAR'], ['num_phone', 'NUMERIC'], ['name', 'VARCHAR'],['address', 'VARCHAR'] ]
DIV_ID = "#dgrSearch"
FILE_O = File.open('hold-data/directory-tel.txt', 'w')
FILE_O.puts( FIELDS.map{|f| f[0]}.join("\t") )
DB_NAME = "hold-data/directory-tel.sqlite"
File.delete(DB_NAME) if File.exists?DB_NAME
DATAB = SQLite3:Database.new( DB_NAME )
TABLE = "records_telephone"
DB_INSERT_STATEMENT = "INSERT into #{TABLE} values
(#{FIELDS.map{'?'}.join(',')})"
DATAB.execute "CREATE TABLE #{TABLE}(#{FIELDS.map{|f| "`#{f[0]}` #{f[1]}"}.join(', ')});"
FIELDS.each do |fn|
DATAB.execute "CREATE INDEX #{fn[2]} ON #{TABLE}(#{fn[0]})" unless fn[2].nil?
end
Dir.glob("hold-data/pages/*.html").reject{|f| f =~ /All match/}.each do |fname|
meta_stuff = File.basename(fname, '.html').split('--')
page = Nokogiri::HTML(open(fname))
page.css("#{DIV_ID} tr")[1..-2].each do |tr| # this is line #27
data_tds = tr.css('td').map{ |td|
td.text.gsub(/[$,](?=\d)/, '').gsub(/\302\240|\s/, ' ').strip
}
row_data = meta_stuff + data_tds
FILE_O.puts( data_row.join("\t"))
DATAB.execute(DB_INSERT_STATEMENT, row_data)
end
end
FILE_O.close
有人知道我做错了什么吗?
最佳答案
如果你告诉我们错误发生在哪一行,下次会有用的。
从它的外观来看,这里只有一行,您调用的表达式可能返回nil:
page.css("#{DIV_ID} tr")[1..-2].each do
记住,如果
each
为空,the_array[1..-2]
将返回nil。因此
the_array
可能返回一个空数组,因此出现错误。如果这个行为没有被删除,我会考虑调查发生这种情况的原因,或者在调用
page.css("#{DIV_ID} tr")
之前检查数组是否为空(见下文)只是个建议。if page.css("#{DIV_ID} tr").empty?
#empty array
else
#not empty
end
关于ruby - Ruby Nomethoderror“每个”为零类,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/14603459/