我喜欢使用内置的 csv rails 库将我的 rails 应用程序中的数据集导出为 csv 文件。通常一个 csv 文件是按行编写的,就像下面的示例一样,它来自我的 datasets_controller.rb:
require 'csv'
dataset = Dataset.find(6)
dataset_headers = dataset.datacolumns.collect { |dc| dc.columnheader }
csv_file = CSV.generate do |csv|
csv << dataset_headers
end
现在我的问题是我是否也可以像这样明智地编写我的 csv 文件列?
require 'csv'
dataset_columns = Datacolumn.all(:conditions => ["dataset_id = ?", 6], :order => "columnnr ASC").uniq
csv_file = CSV.generate do |csv|
csv << "here put one after another all my data columns"
end
编辑:
根据道格拉斯的建议,我想出了下面的colde。
data_columns=Datacolumn.all(:conditions => ["dataset_id = ?", dataset.id], :order => "columnnr ASC").uniq
CSV.generate do |csv|
value=Array.new
data_columns.each do |dc|
value << dc.columnheader
dc.sheetcells.each do |sc|
if sc.datatype && sc.datatype.is_category? && sc.category
value << sc.category.short
elsif sc.datatype && sc.datatype.name.match(/^date/) && sc.accepted_value
value << sc.accepted_value.to_date.to_s
elsif sc.accepted_value
value << sc.accepted_value
else
value << sc.import_value
end
end
csv << value
value = Array.new
end
end
对于这种情况,输出不会转置,如下所示:
height,10,2,<1,na
fullauthor,Fortune,(Siebold & Zucc.) Kuntze,Fortune,(Siebold & Zucc.) Kuntze
Year,1850,1891,1850,1891
fullname,Mahonia bealei,Toxicodendron sylvestre,Mahonia bealei,Toxicodendron sylvestre
但是当我将写入 csv 的行更改为
csv << value.transpose
我收到一个错误,告诉我它无法将字符串转换为数组来执行此操作。有人知道如何解决这个问题吗?
对此的任何帮助将不胜感激。
最好的克拉斯