将数据对象数组转换为原始数据

时间:2012-09-06 20:22:28

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

这可能是我的一个巨大疏忽,但我一直在寻找一个小时的修复,没有运气!

我正在关注RailsCast tutorial on exporting data to .CSV

我用来填充CSV的数据来自Ransack查询(在参数中)

然而,正在吐出的数据是数据对象的集合,而不是原始数据本身 -

浏览器中的输出:

#<Order:0x007f820823c738>,#<Order:0x007f82082ad708>,#<Order:0x007f82082ace98>,
#<Order:0x007f82082ac718>

我只是想尝试获取相同的对象,但只是打印出来...就像在RailsCasts教程中那样(Screenshot

这是我的Orders_Controller

def index
  @search = Order.search(params[:q])
  @orders = @search.result

  @results = @orders

  respond_to do |format|
    format.html # index.html.erb
    format.csv { render text: @results.to_csv }
  end
end

那么有没有一种简单的方法可以将这些数据对象转换为原始字符串,如教程中那样?

修改

这是我模型中的to_csv方法

def self.to_csv(options = {})
  CSV.generate(options) do |csv|
    csv << column_names
    all.each do |order|
      csv << order.attributes.values_at(*column_names)
    end
  end
end

1 个答案:

答案 0 :(得分:2)

所以我认为这就是问题所在:@search.result是一个Orders数组,因此@results.to_csv正在调用Array#to_csv方法。由于您没有获得ActiveRecord::Relation,因此您可能需要以不同方式转换为csv。

ransack_helpers.rb中创建lib模块:

module RansackHelpers
  def self.to_csv(ransack_result, options = {})
    CSV.generate(options) do |csv|
      result_array = ransack_result.result
      column_names = result_array.first.class.column_names
      csv << column_names
      result_array.each do |item|
        csv << item.attributes.values_at(*column_names)
      end
    end
  end
end

orders_controller.rb

def index
  @search = Order.search(params[:q])
  @orders = @search.result

  respond_to do |format|
    format.html # index.html.erb
    format.csv { render text: RansackHelpers.to_csv(@search) }
  end
end

我没有测试过这段代码,因此可能存在一些问题,但我认为这就是您想要做的。