我有一个页面,用户可以将数据导入网站。或者以复制的形式,从excel粘贴到文本区域,或者上传.csv文件。

控制器检查是否已上传csv - 如果是,则处理此问题,否则它将处理粘贴的内容。 (假设用户现在只选择一个选项)。

复制和粘贴部分工作正常,但是,当我尝试处理上传的csv文件时出现问题:

我收到错误:

  

无法转换   ActionController的:: UploadedTempfile   到字符串

#events_controller
  def invite_save
    @event = Event.find(params[:id])

    if params[:guest_list_csv]
      lines = parse_csv_file(params[:guest_list_csv])
    else
      #csv file uploaded
      lines = params[:guest_list_paste]
    end

    if lines.size > 0
      lines.each do |line|
          new_user(line.split)
      end 
      flash[:notice] = "List processing was successful."
    else
      flash[:error] = "List data processing failed."
    end

  end
private

  def parse_csv_file(path_to_csv)
    lines = []

    require 'fastercsv' 

    FasterCSV.foreach(path_to_csv) do |row|
      lines << row
    end
    lines
  end

  def new_user(line)
     #code to create new user would go here
  end

我基本上试图在一个平滑的动作中上传和处理csv,而不是让用户按下“进程”。按钮。

有帮助吗?

解决方案

在上面的第6行

if params[:guest_list_csv]
  lines = parse_csv_file(params[:guest_list_csv])
else
  #csv file uploaded
  lines = params[:guest_list_paste]
end

问题是 params [:guest_list_csv] 不是实际字符串,路径也不是,因为它是文件对象。您需要的是显式调用 #path

# line 6
  lines = parse_csv_file(params[:guest_list_csv].path)

请尝试一下,看看它是否解决了您的问题。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top