практически не контролирует ошибки. Например, если подать ему на вход дату, в которой день недели установлен некорректно, то он несоответствия не обнаружит. Это всего лишь анализатор — со своей работой он справляется неплохо, а требовать от него большего было бы неправильно.
Следует особо отметить склонность этого кода к «американизмам». Когда американец пишет 3/4/2001, он обычно имеет в виду 4 марта 2001 года. В Европе и большинстве других мест это означает 3 апреля. Но если при записи всех дат применяется одно и то же соглашение, ничего страшного не произойдет. Ведь возвращается просто массив, и ничто не мешает вам мысленно
переставить первый и второй элементы. Кстати, имейте в виду, что вышеописанным образом интерпретируется даже такая дата, как 15/3/2000, хотя нам совершенно очевидно, что 15 — это день, а не месяц. Метод же
parsedate
«на голубом глазу» сообщит, что 15 — номер месяца!..
7.21. Форматирование и печать даты и времени
Для получения канонического представления даты и времени служит метод
asctime
; У него есть синоним
ctime
.
Аналогичный результат дает метод
to_s
. Точно такая же строка будет напечатана, если просто передать объект, представляющий дату и время, методу puts.
С помощью метода
strftime
класса
Time
можно отформатировать дату и время почти произвольным образом. В этой главе мы уже встречали спецификаторы
%a
,
%A
,
%U
,
%W
,
%H
,
%M
,
%S
,
%I
и
%p
, а ниже приведены оставшиеся:
%b
Сокращенное название месяца (
"Jan"
)
%B
Полное название месяца (
"January"
)
%c
Предпочтительное представление локальной даты и времени
%d
День месяца (
1..31
)
%j
Порядковый номер дня в году (
1..366
); так называемая «юлианская дата»
%m
Номер месяца (
1..12
)
%w
Номер дня недели (
0..6
)
%x
Предпочтительное представление даты без времени
%y
Год в двузначном формате (без указания века)
%Y
Год в четырехзначном формате
%Z
Название часового пояса
%%
Знак
%
(процент)
Дополнительную информацию вы найдете в справочном руководстве по языку Ruby.
7.22. Преобразование часовых поясов
Обычно приходится работать только с двумя часовыми поясами: GMT (или UTC) и тем, в котором вы находитесь.
Метод
gmtime
преобразует время к поясу GMT (модифицируя сам вызывающий объект). У него есть синоним
utc
.
Может быть, вы думаете, что можно просто преобразовать момент времени в массив, подменить часовой пояс и выполнить обратное преобразование? Проблема в том, что все методы класса, к примеру
local
и
gm
(а также их синонимы
mktime
и
utc
), готовы создавать объект
Time
только
в предположении, что указано либо местное время, либо время по Гринвичу.
Есть обходной путь для преобразования часового пояса. Но предполагается, что вы заранее знаете разницу во времени. Взгляните на следующий фрагмент:
mississippi = Time.local(2000,11,13,9,35) # 9:35 am CST
california = mississippi - 2*3600 # Минус два часа.
В текущей версии Ruby еще нет встроенной функции для этой цели. Но ее можно без труда написать самостоятельно:
require 'date'
def month_days(month,year=Date.today.year)
mdays = [nil,31,28,31,30,31,30,31,31,30,31.30,31]
mdays[2] = 29 if Date.leap?(year)
mdays[month]
end
days = month_days(5) # 31 (May)
days = month_days(2,2000) # 29 (February 2000)
days = month_days(2,2100) # 28 (February 2000)
7.24. Разбиение месяца на недели
Представьте, что нужно разбить месяц на недели, например чтобы напечатать календарь. Эту задачу решает приведенный ниже код. Возвращаемый массив состоит из подмассивов, по семь элементов в каждом. При этом первому элементу каждого внутреннего массива соответствует воскресенье. Начальные элементы для первой недели и конечные для второй могут быть равны