文件系统爬虫 - 迭代错误

时间:2012-12-26 18:07:00

标签: ruby regex spreadsheet web-crawler

我目前正在使用以下代码构建文件系统搜寻器:

require 'find'
require 'spreadsheet'
Spreadsheet.client_encoding = 'UTF-8'

count = 0

Find.find('/Users/Anconia/crawler/') do |file|           
  if file =~ /\b.xls$/                                            # check if filename ends in desired format
    contents =  Spreadsheet.open(file).worksheets
    contents.each do |row|
      if row =~ /regex/
        puts file
        count += 1
      end
    end
  end
end

puts "#{count} files were found"

我收到以下输出: 0 files were found

正则表达式经过测试和更正 - 我目前在另一台可行的爬虫中使用它。

row.inspect的输出是

#<Spreadsheet::Excel::Worksheet:0x003ffa5d418538 @row_addresses= @default_format= @selected= @dimensions= @name=Sheet1 @workbook=#<Spreadsheet::Excel::Workbook:0x007ff4bb147140> @rows=[] @columns=[] @links={} @merged_cells=[] @protected=false @password_hash=0 @changes={} @offsets={} @reader=#<Spreadsheet::Excel::Reader:0x007ff4bb1f3b98> @ole=#<Ole::Storage::RangesIOMigrateable:0x007ff4bb126fa8> @offset=15341 @guts={} @rows[3]> - 当然没有什么可以迭代的。

2 个答案:

答案 0 :(得分:0)

试试这个:

content = Spreadsheet.open(file)
sheet = content.worksheet 0 
sheet.each do |row|
...

答案 1 :(得分:0)

正如迭戈所提到的,我应该一直在迭代内容 - 非常感谢澄清!还应注意,在进行任何迭代之前,必须将row转换为字符串。