2014-02-14 4 views
48

Я использовал рубиновый скрипт для преобразования времени изо штампа в эпоху, файлов, которые я разбор имеет следующую структуру штампа времени:преобразование времени эпохального с миллисекундами DateTime

2009-03-08T00:27:31.807 

Так как я хочу, чтобы миллисекунды I используется следующий код рубина, чтобы преобразовать его в эпоху время:

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

Но в питоне я попробовал следующее:

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

Интересно, это связанно с тем, как я форматированием?

ответ

83

Использование 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 Alternative использованием %, 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

да, я собирался предложить это ... но meh хороший ответ (+1 для сохранения миллисекунды на дисплее :)) –

+0

Отличный ответ также @JoranBeasley ваш тоже замечательный :) Спасибо, ребята. –

+0

Обратите внимание, что первый ответ @falsetru делит на плавающую точку '1000.0', тем самым сохраняя миллисекунды в datetime. –

13

тех миллисекунды, просто разделить их на 1000, так как gmtime ожидает секунды ...

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

Я вижу, но я буду быть расторгнув миллисекунды правильно ..? –

+1

yes ... Я думаю, вы можете сохранить их, выполнив «timestamp/1000.0», который передаст их в виде десятичного числа ... (хотя Im не уверен, что вы можете их получить) –

+0

есть эквивалент gmtime, который принимает микро или миллисекунды в качестве входных данных? –

Смежные вопросы