ruby-on-rails - Rails 4 CSV 上传到多个模型

标签 ruby-on-rails ruby-on-rails-4.1

我正在尝试上传一个 csv 文件,该文件包含属于两个不同模型的数据:ProjectPurchaseOrder。我在模型之间使用 has_many, :through 关系。

我在上传时遇到问题。我已将两个 Controller 中的共享属性列入白名单,并在两个模型中都包含了 accepts_nested_attributes

这是我在 csv 中读取的代码。

  def self.import(file)
    CSV.foreach(file.path, headers: true) do |row|
      project_hash = row.to_hash
      project = Project.where(project_name: project_hash["project_number"]).first
      if project.present?
        project.first.update_attributes(project_hash)
      else
        Project.create! (project_hash)
      end
      purchase_order = PurchaseOrder.where(po_number: project_hash["po_number"]).first
      if purchase_order.present?
        PurchaseOrder.create!
      end

我有两个问题。

  1. 我无法读取 po_number 属性。我收到此错误项目的未知属性“po_number”

  2. 我不知道如何将创建的采购订单推送到项目哈希中,以便它更新嵌套属性值。

提前感谢任何能够提供帮助的人!

**** 更新 通过这种方法,数据可以保存到正确的表中。但是,PurchaseOrder 和 Project 之间的关联不会保存。有什么想法吗?

  def self.import(file)
    CSV.foreach(file.path, headers: true) do |row|
      project_hash = row.to_hash
      po_hash = {}
      po = PurchaseOrder.new
      project_hash.each { |k, v| po_hash[k] = project_hash.delete(k) if po.respond_to?(k) }    

      project = Project.where(project_name: project_hash["project_number"]).first
      if project.present?
        project.first.update_attributes(project_hash)
      else
        Project.create! (project_hash)
      end

      po = PurchaseOrder.where(po_number: po_hash["po_number"]).first
      if po.present?
        po.first.update_attributes(po_hash)
      else
        PurchaseOrder.create! (po_hash)
      end
    end
  end

最佳答案

这些行正在尝试使用哈希中的所有值更新/创建项目...

project.first.update_attributes(project_hash)
...
Project.create! (project_hash)

但显然某些哈希元素(例如“po_number”)在项目表中没有列。

您需要根据哪些元素属于哪个模型来拆分 csv 哈希元素...

例如

po_hash = {}
po = PurchaseOrder.new
project_hash.each { |k, v| po_hash[k] = project_hash.delete(k) if po.respond_to?(k) }

这将从 project_hash 中删除采购订单字段并将其添加到 po_hash 中,以便您可以使用正确的哈希来更新正确的表。

建立协会...

改变

Project.create!(project_hash)

进入

project = Project.create!(project_hash)

这样无论项目是否存在或者是新创建的,它都存储在变量“project”中。同样,做

po = PurchaseOrder.create!(po_hash) 

然后,在创建或更新采购订单后,您可以简单地将采购订单分配给项目...

project.purchase_orders << po

关于ruby-on-rails - Rails 4 CSV 上传到多个模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31328041/

相关文章:

ruby-on-rails - 如何更改从其中一颗 gem 中加载 gem 的顺序

ruby-on-rails - Ruby on Rails 和 Tab

ruby-on-rails-4.1 - Rails破 Spring 发电机

javascript - 在 comfy 中使用特定于布局的 javascript 会导致 InvalidCrossOriginRequest

ruby-on-rails - 鲁博警察。如果散列文字的元素跨越多行,则对齐它们

ruby-on-rails - 如何在rails 3.0中将原型(prototype)替换为jquery?

ruby-on-rails - Excon::Errors::Timeout:达到连接超时

ruby-on-rails - cancancan 自定义操作不起作用

mysql - Rails 依赖破坏所有

mysql - 添加索引 Ruby on Rails 4.1.4 迁移