time模块可以使用从epoch开始的秒数初始化:

>>> import time
>>> t1=time.gmtime(1284286794)
>>> t1
time.struct_time(tm_year=2010, tm_mon=9, tm_mday=12, tm_hour=10, tm_min=19, 
                 tm_sec=54, tm_wday=6, tm_yday=255, tm_isdst=0)

是否有一种优雅的方法来初始化datetime。Datetime对象?


Datetime.datetime.fromtimestamp就可以了,如果您知道时区,那么您可以生成与time.gmtime相同的输出

>>> datetime.datetime.fromtimestamp(1284286794)
datetime.datetime(2010, 9, 12, 11, 19, 54)

or

>>> datetime.datetime.utcfromtimestamp(1284286794)
datetime.datetime(2010, 9, 12, 10, 19, 54)

从epoch到datetime到strftime的秒数:

>>> ts_epoch = 1362301382
>>> ts = datetime.datetime.fromtimestamp(ts_epoch).strftime('%Y-%m-%d %H:%M:%S')
>>> ts
'2013-03-03 01:03:02'

注意,对于1970年1月1日之前的日期,datetime.datetime.fromtimestamp(timestamp)和.utcfromtimestamp(timestamp)在windows上失败,而负的unix时间戳似乎在基于unix的平台上有效。医生说:

,这可能引发ValueError,如果时间戳超出的范围 平台C gmtime()函数支持的值。这很常见 这将限制在1970年到2038年之间。”

参见Issue1646728


从文档中,从seconds since epoch获取一个时区感知datetime对象的推荐方法是:

Python 3:

from datetime import datetime, timezone
datetime.fromtimestamp(timestamp, timezone.utc)

Python 2,使用pytz:

from datetime import datetime
import pytz
datetime.fromtimestamp(timestamp, pytz.utc)

对于那些希望它符合ISO 8601的人来说,因为其他解决方案没有T分隔符也没有时间偏移(除了Meistro的答案):

from datetime import datetime, timezone
result = datetime.fromtimestamp(1463288494, timezone.utc).isoformat('T', 'microseconds')
print(result) # 2016-05-15T05:01:34.000000+00:00

注意,我使用fromtimestamp是因为如果我使用utcfromtimestamp,我将需要链上.astimezone(…)来获得偏移量。

如果你不想一直到微秒,你可以选择一个不同的单位 isoformat()方法。