我使用ruby脚本将iso时间戳转换为epoch,我正在解析的文件具有以下时间戳结构:
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'
>>>
我想知道它是如何格式化的?
答案 0 :(得分:111)
使用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'
答案 1 :(得分:15)
那些是毫秒,只需将它们除以1000,因为gmtime需要秒......
time.strftime('%Y-%m-%d %H:%M:%S', time.gmtime(1236472051807/1000.0))
答案 2 :(得分: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
标头更准确。