SmarterCSV和resque导致未定义的方法关闭

时间:2018-03-16 19:53:17

标签: ruby-on-rails csv resque smartercsv

我正在尝试使用ResqueSmarterCSV,但看到同样的错误:

  

undefined method 'close' for nil:NilClass

在我的resque日志中。我不确定为什么会这样。我已经完成了一些挖掘工作,看过这个问题的人发现它与文件位置错误有关,但我只是将文件作为参数传递,它不能保存在任何地方。< / p>

我的表格:

<%= form_tag check_upload_file_path, multipart: true do %>
    <%= file_field_tag :file %>
    <%= select_tag 'location', options_from_collection_for_select(Location.real, 'id', 'name'), include_blank: true %>
    <br>
    <%= submit_tag "Preview", class: "btn btn-awaken btn-sm approve-me", name: 'preview' %>
<% end %>

我的控制器:

def check_upload_file
    Resque.enqueue(AddClientsFromScale, params[:file], params[:location])
    redirect_to bulk_uploads_path
end

我的工作人员:

class AddClientsFromScale
    @queue = :validate_file

    puts "adding clients from scale..."

    def self.perform(file, location_id)
        p file, location_id
        WeighIn.check_file(file, location_id)
    end
end

我的模特:

class WeighIn < ActiveRecord::Base
    @hash_for_new_clients = {
        ' ID'                           => 'scale_id',
        'Full Name'                     => 'name',
    }

    def self.check_file(file, location_id)
        options = {:key_mapping => @hash_for_new_clients, :strings_as_keys => true, :keep_original_headers => true, :remove_unmapped_keys => true}

        # prints the file and contents properly
        p "file: ", file["tempfile"] 

        SmarterCSV.process(file, options) do |row|
            p row
        end
    end
end

任何人都知道发生了什么?

1 个答案:

答案 0 :(得分:0)

问题是file变量是一个包含更多数据的哈希,而不仅仅是文件本身。线索是您使用file["tempfile"]打印它的地方。这就是您插入SmarterCSV所需要的,因为这是您尝试处理的实际文件的参考。

SmarterCSV.process(file["tempfile"], options) do |row|

在我的情况下,我有一个额外的文件编码问题,我从SmarterCSV收到此错误:

  

警告:您正在尝试处理UTF-8输入,但未使用“b:utf-8”选项打开输入。请参阅自述文件“关于文件编码的说明”。

这最终是为我做的:

f = File.open(file["tempfile"], "r:bom|utf-8")
SmarterCSV.process(f, options) do |row|
    ...