关于python:将纪元时间用毫秒转换为datetime

converting epoch time with milliseconds to datetime

我使用ruby脚本将iso时间戳转换为epoch,我正在解析的文件具有以下时间戳结构:

1
2009-03-08T00:27:31.807

因为我想保持毫秒,我使用遵循ruby代码将其转换为纪元时间:

1
2
irb(main):010:0> DateTime.parse('2009-03-08T00:27:31.807').strftime("%Q")
=>"1236472051807"

但在python我试过以下:

1
2
import time
time.strftime('%Y-%m-%d %H:%M:%S', time.gmtime(1236472051807))

但我没有得到原来的时间日期时间,

1
2
3
>>> time.strftime('%Y-%m-%d %H:%M:%S', time.gmtime(1236472051807))
'41152-03-29 02:50:07'
>>>

我想知道它是如何格式化的?


使用datetime.datetime.fromtimestamp

1
2
3
4
>>> import datetime
>>> s = 1236472051807 / 1000.0
>>> datetime.datetime.fromtimestamp(s).strftime('%Y-%m-%d %H:%M:%S.%f')
'2009-03-08 09:27:31.807000'

%f指令仅由datetime.datetime.strftime支持,而不是由time.strftime支持。

使用%str.format更新替代方案:

1
2
3
4
5
6
>>> import time
>>> s, ms = divmod(1236472051807, 1000)  # (1236472051, 807)
>>> '%s.%03d' % (time.strftime('%Y-%m-%d %H:%M:%S', time.gmtime(s)), ms)
'2009-03-08 00:27:31.807'
>>> '{}.{:03d}'.format(time.strftime('%Y-%m-%d %H:%M:%S', time.gmtime(s)), ms)
'2009-03-08 00:27:31.807'


那些是毫秒,只需将它们除以1000,因为gmtime需要秒......

1
time.strftime('%Y-%m-%d %H:%M:%S', time.gmtime(1236472051807/1000.0))