2

我的代码的目标是处理目录中的所有 .xls 文件并将它们全部转换为 .csv。这在过去有效,但在更新 Ruby 和 Roo 后,它显示以下错误。我正在使用 Ruby 1.9.3-p362 和 Roo 1.11.2。

require 'rubygems'
require 'csv'
require 'iconv'
require 'mysql2'
require 'mysql'
require 'roo'

begin
    Dir["#{@work_path}/*.xls"].each do |file|  
        begin
          file_path = "#{file}"
          file_basename = File.basename(file, ".xls")
          xls = Excel.new(file_path)
          xls.to_csv("#{@kenshoo_work_path}#{file_basename}.csv")
          @log.info("Converted file #{file}")
          FileUtils.remove(file)
          @log.info("Deleted file #{file}")
        rescue Exception => e
          @log.warn("Unable to convert file: #{file_basename} into csv because #{e.message}")
        end
    end
end

对于每个文件,我都会收到以下错误消息:

Unable to convert file: #{file} into csv because uninitialized constant Excel

任何帮助表示赞赏。谢谢。

4

1 回答 1

4

roo在命名空间中有ExcelRoo::。您需要将所有实例替换ExcelRoo::Excel

版本没有命名空间下的类Roo::,因此这可以解释为什么您的代码在更新后中断。

新的存储库在这里:https ://github.com/Empact/roo

于 2013-05-02T17:25:33.170 回答