我正在解析一些具有闰秒时间戳 datetime 2012-06-30T23:59:60.209215
的数据。我使用以下代码解析该字符串并转换为日期时间对象:
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
谢谢
最佳答案
The documentation for %S
says :
Unlike the time module, the datetime module does not support leap seconds.
时间字符串"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
关于Python - 日期时间没有正确计算闰秒?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21027639/