0

先週のツイートの 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] 

それらを範囲とその数でグループ化したいので、1日あたりのツイート数を取得します

grouped = {date1: 3, date2: 1, date3: 5}

ありがとう!

4

2 に答える 2

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}
于 2013-11-01T06:14:03.843 に答える
0

これでも試すことができます

times.group_by{|x| x }.values.map{|y| y.count}
于 2013-11-01T06:29:09.943 に答える