Преобразование времени эпохи с миллисекундами в datetime
Я использовал ruby script для преобразования временной метки 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'
>>>
Интересно, связано ли это с тем, как я форматирую?
Ответы
Ответ 1
Используйте 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
.
UPDATE Альтернатива с использованием %
, 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'
Ответ 2
это miliseconds, просто разделите их на 1000, так как gmtime ожидает секунды...
time.strftime('%Y-%m-%d %H:%M:%S', time.gmtime(1236472051807/1000.0))