Хорошо, я в недоумении здесь. Есть ли какая-либо причина, по которой час кажется произвольно добавленным к дате при преобразовании в метку времени, а затем обратном преобразовании из метки времени?
import datetime
dt = datetime.datetime(year=2020, month=3, day=8, hour=2)
print(dt)
dt2 = datetime.datetime.fromtimestamp(dt.timestamp())
print(dt2)
Результат:
2020-03-08 02:00:00
2020-03-08 03:00:00
ХМ? Проверено на 3.10.4 и 3.10.3
Наивное представление даты и времени в Python, представляющее местное время, может быть довольно запутанным — я думаю, это просто еще один пример. Попробуйте инициализировать dt с соответствующим часовым поясом и посмотрите, что произойдет... в общем, используйте осведомленную дату и время (набор tz), если можете, чтобы избежать такой путаницы.
Ваш код отлично работает на моем компьютере, который находится в Аделаиде (Австралия). Причина, по которой это не так, заключается в том, что переход на летнее время для часового пояса США по восточному поясному времени начался 8 марта 2020 года, поэтому часы в это время перешли вперед с 2:00 до 3:00, и, таким образом, метка времени, сгенерированная для 2:00, соответствует фактическому времени. 3 часа ночи (поскольку 2 часов ночи на самом деле не существует). Если вы попробуете свой код с помощью hour=1
или hour=3
, он будет работать нормально.
Вы можете решить эту проблему, работая исключительно со временем UTC.
Спасибо. Может я тупой, я бы не догадался.
@RyanMcconnell Я несколько раз сталкивался с этой проблемой в других средах, поэтому довольно быстро ее распознал. Просто вопрос опыта.
Если бы я переключил весь код на использование UTC вместо локализованного времени, проблема перехода на летнее время теоретически должна исчезнуть, верно?
@RyanMcconnell Правильно.
Кстати, это часовой пояс EST, я не уверен, что это имеет значение. С другими датами такого не происходит.