Python - 日期时间未正确考虑闰秒



我正在解析一些具有闰秒时间戳日期时间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

谢谢

%S的文档说:

与时间模块

不同,日期时间模块不支持闰秒。

时间字符串"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

这样做:

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

相关内容

  • 没有找到相关文章

最新更新