1

データベースに保存せずにテキスト ファイルをアップロードする必要があります。私の目標は、このファイルをアップロードし、自動的にコンテンツを取得してデータベースに保存することです。

私のファイル:data.txt

name age occupation
julio 19 student
ramon 20 student

私のデータベース:

class CreateStudents < ActiveRecord::Migration
   def change
     create_table: students do |t|
       t.string "name"
       t.integer "age"
       t.string "occupation"

       t.timestamps
     end
   end
end

これを行う方法を知っている人はいますか?インターネットで検索しましたが、私の場合の解決策は見つかりませんでした。私は助けが必要です。

4

1 に答える 1

2
= form_tag url, {multipart: true} do
  = file_field_tag :file
  ....

コントローラーで

if params[:file]
  lines = params[:file].tempfile.readlines.map(&:chomp) #readlines from file & removes newline symbol
  lines.shift #remove first line 
  lines.each do |l| 
    m = l.match(/(\S+)\s(\d+)\s(\S+)/) #parse line 
    Student.create {name: m[1],age: m[2], occupation: m[3]}
  end
end
于 2012-05-20T12:10:14.057 に答える