时间戳超出平台localtime()/ gmtime()函数的范围

use*_*172 7 python datetime timestamp

我尝试:

ts = -216345600000
datetime.datetime.fromtimestamp(ts/1000)
Run Code Online (Sandbox Code Playgroud)

ValueError:平台localtime()/ gmtime()函数的时间戳超出范围

我检查epochconverter值:-216345600返回GMT:周六,1963年2月23日00:00:00 GMT

如何获得正确的结果?

Ret*_*i43 6

对于许多价值观,比如过去或将来的过多,只是提供时间戳fromtimestamp()会抱怨超出范围的错误.但是,您可以使用timedelta()相对于纪元来计算日期.

>>> from datetime import datetime, timedelta
>>> date = datetime(1970, 1, 1) + timedelta(seconds=-216345600)
>>> date
datetime.datetime(1963, 2, 23, 0, 0)
>>> date.strftime('%a, %d %b %Y %H:%M:%S GMT')
'Sat, 23 Feb 1963 00:00:00 GMT'
Run Code Online (Sandbox Code Playgroud)

但是,请注意你不能用它来回到恐龙时代,因为它datetime()仍然具有它可以支持的最小值和最大值.

>>> datetime(1970, 1, 1) + timedelta(seconds=-62135596800)
datetime.datetime(1, 1, 1, 0, 0)
>>> datetime(1970, 1, 1) + timedelta(seconds=253402300799)
datetime.datetime(9999, 12, 31, 23, 59, 59)
>>> datetime(1970, 1, 1) + timedelta(seconds=253402300800)

Traceback (most recent call last):
  File "<pyshell#157>", line 1, in <module>
    datetime(1970, 1, 1) + timedelta(seconds=253402300800)
OverflowError: date value out of range
Run Code Online (Sandbox Code Playgroud)

timedelta() 它也有其局限性,但以时代为参考点,我们甚至还没有达到它们.

>>> timedelta(microseconds=1000000000*86400*10000-1)
datetime.timedelta(9999999, 86399, 999999)
Run Code Online (Sandbox Code Playgroud)