Python - Datetime не учитывает високосную секунду правильно?
Я анализирую некоторые данные, которые имеют время скачка timestampe datetime 2012-06-30T23:59:60.209215
, Я использовал следующий код для анализа этой строки и преобразования в объект datetime:
nofrag, frag = t.split('.')
nofrag_dt = datetime.datetime.strptime(nofrag, "%Y-%m-%dT%H:%M:%S")
dt = nofrag_dt.replace(microsecond=int(frag))
Документация Python утверждает, что это не должно быть проблемой, так как %S
принимает [0, 61]
, Но я получаю эту ошибку с указанным временем
nofrag_dt = datetime.datetime.strptime(nofrag, "%Y-%m-%dT%H:%M:%S")
ValueError: second must be in 0..59
Спасибо
2 ответа
Решение
Сделай это:
import time
import datetime
t = '2012-06-30T23:59:60.209215'
nofrag, frag = t.split('.')
nofrag_dt = time.strptime(nofrag, "%Y-%m-%dT%H:%M:%S")
ts = datetime.datetime.fromtimestamp(time.mktime(nofrag_dt))
dt = ts.replace(microsecond=int(frag))
print(dt)
Выход:
2012-07-01 00:00:00.209215
В отличие от модуля времени, модуль даты и времени не поддерживает високосные секунды.
Строка времени "2012-06-30T23:59:60.209215"
подразумевает, что время указано в UTC (это последняя секунда прыжка в данный момент):
import time
from calendar import timegm
from datetime import datetime, timedelta
time_string = '2012-06-30T23:59:60.209215'
time_string, dot, us = time_string.partition('.')
utc_time_tuple = time.strptime(time_string, "%Y-%m-%dT%H:%M:%S")
dt = datetime(1970, 1, 1) + timedelta(seconds=timegm(utc_time_tuple))
if dot:
dt = dt.replace(microsecond=datetime.strptime(us, '%f').microsecond)
print(dt)
# -> 2012-07-01 00:00:00.209215