web-dev-qa-db-ja.com

ミリ秒のエポック時間を日時に変換する

Rubyスクリプトを使用して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'
>>> 

それは私がどのようにフォーマットしているかに関連しているのだろうか?

61
add-semi-colons

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

これらはミリ秒です。gmtimeは秒を想定しているため、単に1000で除算します...

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