从Mongoid创建CSV文档时,Ruby会按顺序列出列

时间:2014-09-17 00:09:14

标签: ruby arrays csv hash mongoid

我需要从数据库创建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])

不起作用

1 个答案:

答案 0 :(得分:0)

当你调用mymodel.attributes时,你会得到一个Hash back,它将属性名称(作为字符串)映射到它们的值。如果您的属性名称为header1header5,那么mymodel.attributes将是这样的:

{
  'header1' => 'value1',
  'header2' => 'value2',
  'header3' => 'value3',
  'header4' => 'value4',
  'header5' => 'value5'
}

当然,顺序取决于MongoDB的输出方式。以指定顺序从哈希中提取一堆值的最简单方法是使用values_at

mymodel.attributes.values_at(*header)