这可能是我的一个巨大疏忽,但我一直在寻找一个小时的修复,没有运气!
我正在关注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
答案 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
我没有测试过这段代码,因此可能存在一些问题,但我认为这就是您想要做的。