0

我有一个页面,用户可以在其中将数据导入站点。可以从 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,而不是让用户按下“处理”按钮。

4

1 回答 1

2

在上面的第 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)

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

于 2009-10-31T15:35:00.947 回答