1

我使用 Ruby 从 MongoDB 中的查询获得了以下输出:

irb(main):087:0>   data = col.find({}, :fields => ["result", "time"])
=> <Mongo::Cursor:0x14768b8 namespace='spark.light' @selector={} @cursor_id=>

irb(main):090:0> data.first
=> {"_id"=>BSON::ObjectId('537d961197c20960ad000001'), "result"=>2177, "time"=>2014-05-22 06:15:45 UTC}

现在我想将此数据提供给在 Ruby on Rails 上运行的 chartkick 以绘制折线图。输入应如下所示:

"2014-05-22 06:15:45 UTC" => "2177"

有什么干净的方法可以做到这一点吗?

4

2 回答 2

2

这会将记录转换为time => result

Hash[data.map do |item|
  [item['time'], item['result']]
end]

# => { 2014-05-22 06:15:45 UTC => 2177, 2014-05-22 06:20:00 UTC => 1000 }
于 2014-05-30T18:39:11.177 回答
0

Hash#values_at与方法一起使用Hash::[]

Hash[data.first.values_at('time', 'result')]
于 2014-05-30T18:50:39.170 回答