将以毫秒为单位的纪元时间转换为日期时间



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

2009-03-08T00:27:31.807

由于我想保留毫秒,我使用以下 ruby 代码将其转换为纪元时间:

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

但是在python中,我尝试了以下内容:

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

但是我没有找回原来的时间日期时间,

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

我想知道这与我的格式有关吗?

使用 datetime.datetime.fromtimestamp

>>> 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

>>> 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 预计秒数......

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

我是钟摆迷...所以。。。

import pendulum
pendulum.from_timestamp(1236472051807/1000.0,tz='America/Toronto')

输出:

DateTime(2019, 12, 20, 10, 55, 10, tzinfo=Timezone('America/Toronto'))

对于所有寻找Gmail API internalDate的搜索...以上是对我有用的,比Date标题更准确。

最新更新