我需要从数据库创建CSV文档。所以我想按特定顺序组织列,我有这个顺序的模板,这个模板存储为标题数组
header = ["header1", "header2", "header3", "header4", "header5"]
record = [{"header4" =>"value4"}, {"header3" =>"value3"}, {"header5"=>"value5"}, {"header1"=>"value1"}, {"header2"=>"value2"}]
I need to get array like tis
record = [{"header1" =>"value1"}, {"header2" =>"value2"}, {"header3"=>"value3"}, {"header4"=>"value4"}, {"header5"=>"value5"}]
但是当我这样做的时候
csv<< mymodel.attributes.values.sort_by! { |h| header.index(h.keys[0])
这是行不通的
当你调用mymodel.attributes
时,你会得到一个Hash back,它将属性名称(作为字符串)映射到它们的值。如果您的属性名称是通过header1
的header5
,那么mymodel.attributes
将是这样的:
{
'header1' => 'value1',
'header2' => 'value2',
'header3' => 'value3',
'header4' => 'value4',
'header5' => 'value5'
}
当然,顺序取决于MongoDB的输出方式。以指定顺序从哈希中提取一堆值的最简单方法是使用values_at
:
mymodel.attributes.values_at(*header)