ruby-on-rails – 按月分组计算
发布时间:2020-12-17 03:07:27 所属栏目:百科 来源:网络整理
导读:我有一个Albums表,其中有一个名为release_date的日期列. 我想获得所有月份组合的列表以及该月/年中发布的专辑数量. 所以,输出可能是这样的: 2016年11月 – 11 2016年10月 – 4 2016年7月 – 19日 2015年12月 – 2 Postgres 9.6上的Ruby 2.3.1 w / Rails 5,F
我有一个Albums表,其中有一个名为release_date的日期列.
我想获得所有月份组合的列表以及该月/年中发布的专辑数量. 所以,输出可能是这样的: > 2016年11月 – 11 Postgres 9.6上的Ruby 2.3.1 w / Rails 5,FWIW. 解决方法
我假设你的表是单一的Album per Rails惯例.如果没有,请考虑更改它.
Album.all.map { |album| [Date::MONTHNAMES[album.date.month],album.date.year].join(' ') } .each_with_object(Hash.new(0)) { |month_year,counts| counts[month_year] += 1 } 说明: .map方法遍历相册并返回由[“month year”,“month year”,…]组成的字符串数组. .each_with_object方法是一种标准计数算法,它返回一个带有每个唯一数组项的计数的哈希. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |