我的数组元素包含上周推文的unix时间
times = [1383285836, 1383285835, 1383285827, 1383285819, 1383285819, 1383285818, 1383285814, 1383285808, 1383285806, 1383285802, 1383285793, 1383285787, 1383285781, 1383285781, 1383285781, 1383285779, 1383285778, 1383285756, 1383285756, 1383285755, 1383285755, 1383285753, 1383285752, 1383285752, 1383285746, 1383285739, 1383285735, 1383285735, 1383285729, 1383285721, 1383285717, 1383285715, 1383285715, 1383285712, 1383285710, 1383285708, 1383285706, 1383285702, 1383285694, 1383285690, 1383285690, 1383285689, 1383285689, 1383285684, 1383285684, 1383285682, 1383285681, 1383285681, 1383285681, 1383285680, 1383285670, 1383285670, 1383285663, 1383285659, 1383285659, 1383285658, 1383285656, 1383285653, 1383285650, 1383285648, 1383285647, 1383285647, 1383285644, 1383285641, 1383285639, 1383285636, 1383285633, 1383285632, 1383285627, 1383285625, 1383285623, 1383285622, 1383285620, 1383285620, 1383285619, 1383285618, 1383285616, 1383285612, 1383285612, 1383285607, 1383285607, 1383285607, 1383285603, 1383285602, 1383285599, 1383285594, 1383285590, 1383285588, 1383285586, 1383285574, 1383285572, 1383285572, 1383285568, 1383285568, 1383285567, 1383285562, 1383285560, 1383285559, 1383285557, 1383285556]
我想按照范围及其数量对它们进行分组,以便每天获得多少推文
grouped = {date1: 3, date2: 1, date3: 5}
谢谢!
答案 0 :(得分:1)
您可以将unix时间转换为日期,然后使用each_with_object
进行分组和计数:
times.each_with_object(Hash.new(0)){|i,h| h[Time.at(i).to_date] += 1}
#=> {date1: 3, date2: 1, date3: 5}
你也可以这样做:
Hash[times.group_by{|i| Time.at(i).to_date }.map{|k,v| [k,v.size]}]
#=> {date1: 3, date2: 1, date3: 5}
答案 1 :(得分:0)
您也可以尝试使用
times.group_by{|x| x }.values.map{|y| y.count}