0

我正在尝试上传和解析多个 CSV 文件。到目前为止我所拥有的:

我的观点

 <h3>Upload multiple files</h3>  
  <%= form_tag({:controller => "multi_uploader", :action => "import"}, :multipart => true) do %>
    <em>Upload a tab-separated .txt file to generate new rating sets.</em> <hr/>
    <%= file_field_tag :file_1 %>
     <hr/>
    <%= file_field_tag :file_2 %>
     <hr/>
    <%= file_field_tag :file_3 %>
     <hr/>
    <%= file_field_tag :file_4 %>
     <hr/>
    <%= file_field_tag :file_5 %>
     <hr/>
    <%= file_field_tag :file_6 %>
    <hr/>
    <%= submit_tag "Import Data", :class => "btn btn-link"%>
    <% end %>

我的控制器:

 def import
    unless params[:file_1].nil?
    file_1 = params[:file_1]
    RatingSet.multi_uploader(file_1)
  end
  unless params[:file_2].nil?
    file_2 = params[:file_2]
    RatingSet.multi_uploader(file_2)
  end
  unless params[:file_3].nil?
    file_3 = params[:file_3]
    RatingSet.multi_uploader(file_3)
  end
  unless params[:file_4].nil?
    file_4 = params[:file_4]
    RatingSet.multi_uploader(file_4)
  end
  unless params[:file_5].nil?
    file_5 = params[:file_5]
    RatingSet.multi_uploader(file_5)
  end
  unless params[:file_6].nil?
    file_6 = params[:file_6]
    RatingSet.multi_uploader(file_6)
  end
    redirect_to "/multi_uploader", :flash => { :notice => "Successfully Uploaded." }
  end

我的模型导入文件的方法:

 def self.multi_uploader(file)
    upload = File.open(file.path)  
    #Parse file and save data to db. 
  end

在我的multi_uploader方法中,我解析出文件应该上传到哪个类别的密钥(从文件中)。当我上传单个文件时,一切都按预期工作,但是如果我上传多个文件,所有文件的内容都会保存到一个类别,而不是多个类别。就好像所有文件都被视为一个文件,而不是 n 个单独的文件。我可以改变什么来单独上传每个文件?

4

1 回答 1

0

嗯,据我所知。这种行为实际上不应该发生。我会建议另一种执行此代码的方法,因为它看起来有点污染。

def import
    (1..x).each do |i| #with x being the max number of files uploaded at the same time
         RatingSet.multi_uploader(params["file_#{i}".to_sym])
    end
    redirect_to "/multi_uploader", :flash => { :notice => "Successfully Uploaded." }
end

无论哪种方式,这都不应该解决您的问题。老实说,我不知道为什么会发生这种情况。

更新:

您是否考虑过使用:<%= f.file_field :file, :multiple => true %>而不是多个 file_tags?

于 2013-09-11T06:29:53.230 回答