Согласно правилам британского летнего времени / перехода на летнее время (https://www.gov.uk/when-do-the-clocks-change) часы:
- вперед на 1 час в 1:00 в последнее воскресенье марта,
- вернуться на 1 час в 2 часа ночи в последнее воскресенье октября.
В 2019 году это гражданское изменение местного времени происходит 31 марта и 27 октября, но дни слегка меняются каждый год. Есть ли чистый способ узнать эти даты для каждого входного года?
Мне нужно проверить эти даты «меняющегося времени» автоматически, есть ли способ избежать цикла for для проверкидетали каждой даты, чтобы увидеть, является ли она датой «меняющегося времени»?
В настоящий момент я изучаю эти даты на 2019 год, просто чтобы попытаться выяснить воспроизводимую / автоматическую процедуру, и я нашел это:
# using datetime from the standard library
march_utc_30 = datetime.datetime(2019, 3, 30, 0, 0, 0, 0, tzinfo=datetime.timezone.utc)
march_utc_31 = datetime.datetime(2019, 3, 31, 0, 0, 0, 0, tzinfo=datetime.timezone.utc)
april_utc_1 = datetime.datetime(2019, 4, 1, 0, 0, 0, 0, tzinfo=datetime.timezone.utc)
# using pandas timestamps
pd_march_utc_30 = pd.Timestamp(march_utc_30) #, tz='UTC')
pd_march_utc_31 = pd.Timestamp(march_utc_31) #, tz='UTC')
pd_april_utc_1 = pd.Timestamp(april_utc_1) #, tz='UTC')
# using pandas wrappers
pd_local_march_utc_30 = pd_march_utc_30.tz_convert('Europe/London')
pd_local_march_utc_31 = pd_march_utc_31.tz_convert('Europe/London')
pd_local_april_utc_1 = pd_april_utc_1.tz_convert('Europe/London')
# then printing all these dates
print("march_utc_30 {} pd_march_utc_30 {} pd_local_march_utc_30 {}".format(march_utc_30, pd_march_utc_30, pd_local_march_utc_30))
print("march_utc_31 {} pd_march_utc_31 {} pd_local_march_utc_31 {}".format(march_utc_31, pd_march_utc_31, pd_local_march_utc_31))
print("april_utc_1 {} pd_april_utc_1 {} pd_local_april_utc_1 {}".format(april_utc_1, pd_april_utc_1, pd_local_april_utc_1))
Вывод этих операторов print
:
march_utc_30 2019-03-30 00:00:00+00:00 pd_march_utc_30 2019-03-30 00:00:00+00:00 pd_local_march_utc_30 2019-03-30 00:00:00+00:00
march_utc_31 2019-03-31 00:00:00+00:00 pd_march_utc_31 2019-03-31 00:00:00+00:00 pd_local_march_utc_31 2019-03-31 00:00:00+00:00
april_utc_1 2019-04-01 00:00:00+00:00 pd_april_utc_1 2019-04-01 00:00:00+00:00 pd_local_april_utc_1 2019-04-01 01:00:00+01:00
Я мог бы использовать цикл for
, чтобы выяснить, является ли текущая дата последним воскресеньеммесяц , или сравните «дельта часа» междутекущая дата и дата послезавтра, чтобы увидеть, есть ли +1, но мне интересно, есть ли более чистый способ сделать это?
Есть ли что-то привязанное к году, например, зная вводный год2019
тогда мы точно знаем, что "дата изменения" в марте будет 31-го числа?