无法使用rake db seed加载文件以使用roo库填充数据库

时间:2013-05-01 13:41:21

标签: ruby-on-rails ruby ruby-on-rails-3

我正在使用roo库解析一个.xls文件并填充我的模型。我正在使用seeds.rb文件和using rake db:seed命令。我收到一条错误,指出我尝试打开的文件不存在,但它位于seed.rb的同一文件夹中。这是我到目前为止所得到的。

require 'rubygems'
require 'roo'
require 'active_record'

co = Roo::Excel.new("excel.xls")

co.default_sheet = co.sheets.first

2.upto(42700) do |line|
  #Category
  category_xls = co.cell(line, 'A')
  category_id = category_xls[0,2].to_i
  category_name = category_xls[4, category_xls.length]

  #Subcategory
  subcategory_xls = co.cell(line, 'B')

  #Item
  item_xls = co.cell(line, 'C')
  partno_xls = co.cell(line, 'D')
  description_xls = co.cell(line, 'E')
  explanation_xls = co.cell(line, 'H')
  information_xls = co.cell(line, 'J')

  #Uom
  uom_xls = co.cell(line, 'F')

  #MTML
  mtml_xls = co.cell(line, 'G')

  #Picture
  #picture = co.cell(line, 'I')

  # cria uma categoria e a insere no banco, caso ela nao exista
  category = Category.find_or_create_by_category_name(category_number: category_id, category_name: category_name)

  # cria uma subcategoria e a insere no banco, caso ela nao exista
  subcategory = Subcategory.find_or_create_by_subcategory_name(subcategory_name: subcategory_xls, category: category)

  # cria um item
  item = Item.create(item_name: item_xls, explanation: explanation_xls, information: information_xls, description: description_xls, subcategory: subcategory)

  # cria um uom
  uom = Uom.find_or_create_by_uom_name(uom_name: uom_xls, item: item)

  # cria um mtml
  mtml = Mtml.find_or_create_by_mtml_name(mtml_name: mtml_xls, item: item)

end

1 个答案:

答案 0 :(得分:0)

我认为你仍然需要告诉它文件与应用程序根目录的关系。

co = Roo :: Excel.new(Rails.root.join('db','excel.xls'))

相关问题