Как подсчитать количество дней между этими двумя датами?
start_date = Date.parse "2012-03-02 14:46:21 +0100"
end_date = Date.parse "2012-04-02 14:46:21 +0200"
Как подсчитать количество дней между этими двумя датами?
start_date = Date.parse "2012-03-02 14:46:21 +0100"
end_date = Date.parse "2012-04-02 14:46:21 +0200"
С помощью классов Date (и DateTime) вы можете сделать (end_date - start_date).to_i
, чтобы получить разницу в днях.
Предполагая, что end_date
и start_date
являются классами ActiveSupport::TimeWithZone
в Rails, вы можете использовать:
(end_date.to_date - start_date.to_date).to_i
Rails имеет встроенную функцию helpers, которая может решить эту проблему для вас. Следует иметь в виду, что это часть помощников Actionview, поэтому они не будут доступны непосредственно с консоли.
Попробуйте это
<% start_time = "2012-03-02 14:46:21 +0100" %>
<% end_time = "2012-04-02 14:46:21 +0200" %>
<%= distance_of_time_in_words(start_time, end_time) %>
"about 1 month"
Я продолжал получать результаты за секунды, так что это сработало для меня:
(Time.now - self.created_at) / 86400
Ни один из предыдущих ответов (до этой даты) не дает правильной разницы в днях между двумя датами.
Самый близкий к thatdankent. Полный ответ преобразует to_i
, а затем разделит:
(Time.now.to_i - 23.hours.ago.to_i) / 1.day
>> 0
(Time.now.to_i - 25.hours.ago.to_i) / 1.day
>> 1
(Time.now.to_i - 1.day.ago.to_i) / 1.day
>> 1
В конкретном примере вопроса не следует анализировать на Date
, если соответствующее время имеет значение. Вместо этого используйте Time.parse
.
чтобы получить количество дней во временном интервале (всего количество дней)
(start_date..end_date).count
(start_date..end_date).to_a.size
#=> 32
чтобы получить количество дней между двумя датами
(start_date...end_date).count
(start_date...end_date).to_a.size
#=> 31
def business_days_between(date1, date2)
business_days = 0
date = date2
while date > date1
business_days = business_days + 1 unless date.saturday? or date.sunday?
date = date - 1.day
end
business_days
end