Ich folge Ryan Bates Railcast Tutorial zum Importieren von Excel-Datei über eine Bahn-Anwendung. Meine Ruby-Version ist 2.2.4 und Rails-Version ist 4.2.6 Ich habe "Roo" Gem bereits installiert.Importieren von Excel-Datei in Schienen-Anwendungen
Meine app \ models \ user.rb Datei ist:
class User < ActiveRecord::Base
require 'csv'
def self.import(file)
spreadsheet= open_spreadsheet(file)
header=spreadsheet.row(1)
(2..spreadsheet.last_row).each do |i|
row=Hash[[header,spreadsheet.row(i)].transpose]
user=find_by_id(row["id"])||new
user.attributes=row.to_hash.slice(*accessible_attributes)
user.save
end
end
def self.open_spreadsheet(file)
case File.extname(file.original_filename)
#when ".csv" then Roo::Csv.new (file.path nil, :ignore)
when ".xls" then Roo::Excel.new (file.path)
#when ".xlsx" then Excelx.new (file.path, nil, :ignore)
else raise "Unknown file type: #{file.original_filename}"
end
end
end
Meine app \ Controller \ users_controller.rb Datei ist:
class UsersController < ApplicationController
def index
@users=User.all
end
def import
User.import(params[:file])
redirect_to root_url, notice: "Activity data imported!"
end
end
Jetzt ist meine Anwendung Homepage richtig funktioniert. Aber nachdem die Datei von Dateiauswahl selectiong wenn ich auf das bin Klick auf „Import Excel“ -Taste (Ich habe getan, das alles in index.html.erb Datei) ,, dann wird die folgende Fehlermeldung zeigt:
RuntimeError in UsersController#import
could not locate a workbook, possibly an empty file passed
Kann dieses Problem noch nicht lösen. Die Methode open_spreadsheet ist dort bereits definiert. Was ist der Grund für den Fehler?
immer noch der gleiche Fehler ,,, wurde nichts passiert – Abhradip
Sie fehlen und "Ende" nach dem ersten jeder Schleife – ryudice
jetzt kommt es mit SyntaxError in UsersController # import – Abhradip