Количество рубинов по дате - PullRequest
1 голос
/ 28 января 2011

У меня есть массив дат, например,

Fri Jan 28 10:13:19 UTC 2011
Thu Jan 27 16:57:59 UTC 2011
Thu Jan 27 16:41:21 UTC 2011
Wed Jan 26 09:20:48 UTC 2011
Mon Jan 24 16:19:48 UTC 2011
Fri Jan 21 11:45:34 UTC 2011
Fri Jan 21 11:42:19 UTC 2011

Как я могу сгруппировать их так, чтобы вывод был в виде хэша с количеством элементов каждый день:

Friday 28 => 1
Thursday 27 => 2
Wednesday 26 => 1
Monday 24 => 1
Friday 21 => 2

Ответы [ 3 ]

1 голос
/ 28 января 2011
s=a.inject(Hash.new(0)) do |h,y|
    z=y.split
    h[ z[0]+z[2] ]+=1
    h
end
1 голос
/ 28 января 2011

Или, чтобы выразить решение Куруми более подробно и используя strftime Джимми:

histogram = dates.inject(Hash.new(0)) do |hist, date|
  hist[date.strftime('%A %d')] += 1
  hist 
end.sort_by{|date, count| date.split(' ').last}.reverse

Дайте нам:

Friday 28: 1
Thursday 27: 2
Wednesday 26: 1
Monday 24: 1
Friday 21: 2

OK

1 голос
/ 28 января 2011
@things.group_by {|thing| thing.strftime "%A %d" }.each do |key, group|
  puts "#{key} => #{group.size}"
end

%A - полное название дня недели, а %d - день месяца

.

Я не могу проверить это в настоящее время, но я думаю это будет работать.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...