首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Rails日期范围JSON数据

Rails日期范围JSON数据
EN

Stack Overflow用户
提问于 2016-08-31 06:04:08
回答 1查看 436关注 0票数 0

我希望有一个日期范围从1.month.ago..Date.today,然后为每一天选择最高温度(所以应该得到30个个人数字),然后总结结果。

我以JSON格式获取数据,其结构如下

代码语言:javascript
复制
{"status": "ok", "data": [{"temperature": 22.4, "date": "20160815-0345"}}

我通过循环解析数据。

代码语言:javascript
复制
@data['data'].each do |d|
 maxTotal << [DateTime.parse(d['date']), d['temperature']]
end

但是,对于如何选择每天的最大值,然后对其进行总结,这还不够。

代码语言:javascript
复制
@total = maxTotal { |a| a[0].to_date == (1.month.ago.to_date) }.max { |a,b| a[1] <=> b[1] }.sum[1]
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-08-31 09:03:32

更新:测试和工作

代码语言:javascript
复制
json_data = @data['data']
sum_of_max_temperature_in_each_day = json_data.
  group_by{ |h| Date.parse(h[:date]) }.
  reject{ |k, v| !( ((30.days.ago.to_date)..(Date.today)) === k ) }.
  inject(0){ |sum, h| sum + h.second.max_by{ |h| h[:temperature] }[:temperature] }

解释(打破它)

代码语言:javascript
复制
# Example; let json_data be
json_data = [
  {"temperature": 22.4, "date": "20160815-0345"},
  {"temperature": 10.4, "date": "20160815-1435"},
  {"temperature": 15.8, "date": "20990101-0430"},
  {"temperature": 4, "date": "20160816-0101"}
]

# sum of max temperature each day within last 30 days
puts json_data.
  group_by{ |h| Date.parse(h[:date]) }.
  reject{ |k, v| !( ((30.days.ago.to_date)..(Date.today)) === k ) }.
  inject(0){ |sum, h| sum + h.second.max_by{ |h| h[:temperature] }[:temperature] }
=> 26.4

# 1) Group by day
puts json_data.
  group_by{|h| Date.parse( h[:date] )}
{
  Mon, 15 Aug 2016=>[
    {:temperature=>22.4, :date=>"20160815-0345"},
    {:temperature=>10.4, :date=>"20160815-1435"}
  ],
  Thu, 01 Jan 2099=>[
    {:temperature=>15.8, :date=>"20990101-0430"}
  ],
  Tue, 16 Aug 2016=>[
    {:temperature=>4, :date=>"20160816-0101"}
  ]
}

# 2) Remove those not within the last 30 days
puts json_data.
  group_by{ |h| Date.parse(h[:date]) }.
  reject{ |k, v| !( ((30.days.ago.to_date)..(Date.today)) === k ) }

{
  Mon, 15 Aug 2016=>[
   {:temperature=>22.4, :date=>"20160815-0345"},
   {:temperature=>10.4, :date=>"20160815-1435"}
  ],
  Tue, 16 Aug 2016=>[
    {:temperature=>4, :date=>"20160816-0101"}
  ]
}

# 3) Showing what's happening inside the inject() block.
puts json_data.
  group_by{ |h| Date.parse(h[:date]) }.
  reject{ |k, v| !( ((30.days.ago.to_date)..(Date.today)) === k ) }.
  inject(0){ |sum, h| 
    puts "h ==> #{h}";
    puts "h.second ==> #{h.second}";
    puts "h.second.max_by ==> #{h.second.max_by{ |h| h[:temperature] }[:temperature]}"
  }

h ==> [
  Mon, 15 Aug 2016,
  [
    {:temperature=>22.4, :date=>"20160815-0345"},
    {:temperature=>10.4, :date=>"20160815-1435"}
  ]
]
h.second ==> [
  {:temperature=>22.4, :date=>"20160815-0345"},
  {:temperature=>10.4, :date=>"20160815-1435"}
]
h.second.max_by ==> 22.4
h ==> [
  Tue, 16 Aug 2016, 
  [
    {:temperature=>4, :date=>"20160816-0101"}
  ]
]
h.second ==> [
  {:temperature=>4, :date=>"20160816-0101"}
]
h.second.max_by ==> 4
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39241852

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档