我有一个页面,用户可以将数据导入网站。或者以复制的形式,从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,而不是让用户按下“进程”按钮。
答案 0 :(得分: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)
请尝试一下,看看它是否解决了您的问题。