現在、スクショのようにファイルを選択し、ボタンを押すとcsvが出力できる機能を作っております。
調べながら、コードを完成させた(していないかも、、、)のですが、ボタンを押すと、
スクショのようなエラーが出てしまいます。
該当ファイルが選択されていない場合の処理をunlessで書くのかなと思ったのですが、
どのように書けば良いかがわかりません。(もしかしたら、全く見当違いかもです)
お忙しい中、お手数ではございますが、解決策を教えていただけると幸いです。
*user.rb*
rb
1def self.import(file) 2 CSV.foreach(file.path, headers: true) do |row| 3 user = find_by(id: row["id"]) || new 4 user.attributes = row.to_hash.slice(*updatable_attributes) 5 user.save! 6 end 7 end 8 9 10 def self.updatable_attributes 11 ["name","email","department","staff_id","card_id", "basic_work_time", 12 "designation_work_start_time", "designation_work_end_time","superior","admin","password"] 13 end
*users_controller*
rb
1def index 2 @users = User.all 3 end 4 5 def import 6 User.import(params[:file]) 7 end 8 9
*index.html.erb*
html
1<div class="csv"> 2 <%= form_tag import_users_path,multipart: true do%> 3 <%= file_field_tag :file %> 4 <%= submit_tag "CSV出力",class: "btn btn-primary"%> 5<% end %> 6</div> 7
*index.csv.ruby*
ruby
1require "csv" 2 3CSV.generate do |csv| 4 column_names = %w(name email department staff_id card_id 5 basic_work_time designation_work_start_time designation_work_end_time 6 superior admin password ) 7 csv << cilumn_names 8 @users.each do |user| 9 column_values = [ 10 user.name, 11 user.email, 12 user.department 13 user.staff_id 14 user.card_id 15 user.basic_work_time 16 user.designation_work_start_time 17 user.designation_work_end_time 18 user.superior 19 user.admin 20 user.password 21 ] 22 23 csv << column_values 24 end 25end
*routes.rb*
ruby
1resources :users do 2 collection { post :import } 3 member do 4 get 'edit_basic_info' 5 patch 'update_basic_info' 6 patch 'update_index' 7 get 'attendances/edit_one_month' 8 patch 'attendances/update_one_month' 9 end 10 collection do 11 get 'working' 12 end 13 resources :attendances, only: :update 14 15 end 16end 17
●gemfileにgem 'roo'を入れました。
●application.rbにrequire 'csv'は記入しました。
よろしくお願い致します。
あなたの回答
tips
プレビュー