Pythonで日付時刻オブジェクトをエポック(Unix時間)以降のミリ秒に変換するにはどうすればよいですか?


354

datetime1970エポック以降のUNIX時間または秒/ミリ秒に変換するPython オブジェクトがあります。

どうすればよいですか?



あなただけの望むここに上陸した場合、現在のミリ秒の精度でエポック秒を、試し$ python -c 'import time; print(time.time())':与えた1584487455.698623
MarkHu

回答:


473

これを行う最も簡単な方法は

import datetime

epoch = datetime.datetime.utcfromtimestamp(0)

def unix_time_millis(dt):
    return (dt - epoch).total_seconds() * 1000.0

32
これまでのところ、これが最良のソリューションです(Pythonバージョン> 2.7の場合)。の実装%sはOSに依存するためです。したがって、誰もがどのOSに関係なくコードが確実に機能することを望んでいます%s。2.3 <py ver <2.7の場合。一つは単純に構築することができtotal_seconds()、次のように:delta.days*86400+delta.seconds+delta.microseconds/1e6

14
注:dtUTC(ローカルではない)である必要があります。Python 2.6 / 3サポートで同様の答えを
jfs '28

7
ここでen.wikipedia.org/wiki/Unix_timeとして定義されている真のUNIXタイムスタンプのみが必要な場合(そして、この回答からのunix_time関数のみを使用する場合)は、delta.total_seconds()をintでラップする必要があることに言及する価値があります。フロートで終わるのを避ける
corford '30 / 12/30

1
を使用 して計算されたエポックはutcfromtimestamp(0)、「tz」が0でない場合にのみ「tz」オフセットを引き起こす可能性があります。これは、エポックがUTC時間である場合に「tz」が計算されるためです。エポックを計算する最良の方法は、タイムゾーンが考慮されるところです。dtdt- epochepoch = datetime.datetime(1970, 1, 1)
ahj

35
datetime.utcfromtimestamp(0)tzohなしでdatetimeを返すのはなぜですか。メソッド名のutc fromtimestampにあります。それをナイーブにしないために、私はのようなことをしなければなりませんdatetime.utcfromtimestamp(0).replace(tzinfo=pytz.UTC)。これは、dtタイムゾーンに対応しているか、取得できる場合に必要ですTypeError: can't subtract offset-naive and offset-aware datetimes
FGreg

170

Python 3.3では、新しいメソッドが追加されましたtimestamp

import datetime
seconds_since_epoch = datetime.datetime.now().timestamp()

あなたの質問はあなたがミリ秒を必要とすると述べました、あなたはこのように得ることができます:

milliseconds_since_epoch = datetime.datetime.now().timestamp() * 1000

timestamp単純な日時オブジェクトで使用する場合、ローカルタイムゾーンであると見なされます。これが意図したものでない場合は、タイムゾーン対応の日時オブジェクトを使用してください。


28
注:.timestamp()メソッドは、単純な入力日時がローカルタイムゾーンにあることを前提としています(ローカルタイムがあいまいな場合があります)。UTCの場合は、dt.replace(tzinfo=timezone.utc).timestamp()代わりに使用してください
jfs 2014

11
datetime.timestamp()は、エポック秒を浮動小数点数として返します。ミリ秒を取得するには:int(datetime.timestamp()* 1000)
Solar.gy 2017

9
この答えは、非人間に優しいドキュメントの精神で、コピー&pasteable例ではありませんdocs.python.org/3/library/...:ある-この datetime.datetime.timestamp(datetime.datetime.now())
MarkHu

3
(少なくとも)3.6では、datetime.timestamp()はタイムゾーンナイーブ(tzinfo = None)の日時がUTCであると想定しています。したがって、常にタイムゾーンを設定することをお勧めします。datetime.datetime.now(pytz.timezone('Europe/Paris')).timestamp() == datetime.datetime.now(pytz.utc).timestamp() == datetime.datetime.utcnow().timestamp()ただし、(常に)に等しくない(datetime.datetime.now().timestamp()ローカルtzがUTCの場合、最後の1つは残りにのみ等しい)
Bluu

1
あなたの興味のために、逆は] fromtimestampdocs.python.org/3/library/…
Flimm

98
>>> import datetime
>>> # replace datetime.datetime.now() with your datetime object
>>> int(datetime.datetime.now().strftime("%s")) * 1000 
1312908481000

または、時間モジュールのヘルプ(および日付のフォーマットなし):

>>> import datetime, time
>>> # replace datetime.datetime.now() with your datetime object
>>> time.mktime(datetime.datetime.now().timetuple()) * 1000
1312908681000.0

の助けを借りて答えました: http //pleac.sourceforge.net/pleac_python/datesandtimes.html

ドキュメンテーション:


6
ところで、strftime( "%s")は空の文字列を返します。2番目の方法は正常に動作します。
Pavel Vlasov

23
2番目の精度しかない
shuckc 2013年

6
'%s'はPythonではサポートされていません。たとえば、Windowsにはない場合があります。推測することを強制し.timetuple()ます。DST中に誤って推測する可能性があります(エラーの50%の確率+/-時間)。どちらも '%s'であり、過去の日付に対して誤ったutcオフセットを使用する可能性があります。ローカル時刻を確実にPOSIXタイムスタンプに変換するには、モジュールによって提供されるような履歴タイムゾーンデータベースが必要です(OSがすでにそのようなデータベースを提供している場合を除く)tm_isdst=-1mktime()mktime()pytz
jfs

1
time.mktime(ts.timetuple())ここで、tsはpythonのdatetimeオブジェクトです
suhailvs

1
@suhail:上記の私のコメントを読んでくださいmktime/timetuple。またtimetuple()、秒の端数を取り除き、質問のポイントは、ミリ秒の精度でタイムスタンプを取得することです。
jfs 14


13

これが私のやり方です:

from datetime import datetime
from time import mktime

dt = datetime.now()
sec_since_epoch = mktime(dt.timetuple()) + dt.microsecond/1000000.0

millis_since_epoch = sec_since_epoch * 1000


2
@JFSebastian頭を上げてくれてありがとう!実際、検討されているDSTはありません。サーバーがUTCではなくローカルタイムの場合、違いが生じます。(まだ)UTC以外のサーバーを設定する説得力のある理由は見つかりませんでした。私のモトは "UTCを書き、現地時間を読む"ので、どこに滞在しているのかが常にわかります...
estani

2
mktimeの代わりにいつでもcalendar.timegmを使用して、mktimeがタイムゾーンを推測しようとする問題を回避できます。
Decko

13

@ChristopherBullミリ秒数を1000で除算して秒数にする
ジョナス

5
あなたは誤解し、それを間違った方法で理解しました。秒はすべて上記の関数で利用可能です。ミリ秒に変換できますが、1秒の精度になります。
クリストファーブル

1
この答えはtimeモジュールを使用していますが、OPはdatetimeモジュールについて尋ねました。FWIW、最も単純な現在の時代はint(time.time())
MarkHu

7
from datetime import datetime
from calendar import timegm

# Note: if you pass in a naive dttm object it's assumed to already be in UTC
def unix_time(dttm=None):
    if dttm is None:
       dttm = datetime.utcnow()

    return timegm(dttm.utctimetuple())

print "Unix time now: %d" % unix_time()
print "Unix timestamp from an existing dttm: %d" % unix_time(datetime(2014, 12, 30, 12, 0))

timegm()utc時間でのみ機能します。それは使用しないtm_isdstので、のutcnow.timetuple()代わりに使用できますutcnow.utctimetuple()。注:使用naive_local_datetime.utctimetuple()はここでは間違っています。現地時間をUTCに変換しません。またtimetuple()、結果から1秒の端数をストリップします(重要かどうかはアプリケーションによって異なります)。また、質問では秒ではなく*ミリ*秒について質問します
jfs

私はutcnow()とutctimetuple()を使用して、UTCを処理していることをコードに明確に示しています(このようにして、コードを読んでいる人は、timegmがUTCのみであることを覚えておく必要はありません)。utctimetuple()は、単純なdttmオブジェクトの変換を意味しません(したがって、utcnow()でdttmを初期化します)。また、質問は秒またはミリ秒に言及しました。
corford 2014年

注:最後のコメントで言ったはずですが、彼が秒またはミリ秒(おそらく私の間違い)を望んでいることを意味するものとして質問を読みました。ミリの場合は、1000を掛けるだけです(上位のスコアの回答が示唆するとおり)。
corford 2014年

utctimetuple()秒の端数を取り除きます。乗算して1000も元に戻せません。
jfs

1
OPがこの質問をする方法のために、彼/彼女が何を望んだのか正確には不明です(すなわち、真のUNIXタイムスタンプまたはミリ秒精度のタイムスタンプ)。いずれにしても、両方の質問はすでにどこかで行われ、回答されています。そうは言っても、ここでの回答は、人々が問題を解決し、さまざまな解決策を説明するための最も迅速でクリーンなものだと思います。
corford 2014

3
>>> import datetime
>>> import time
>>> import calendar

>>> #your datetime object
>>> now = datetime.datetime.now()
>>> now
datetime.datetime(2013, 3, 19, 13, 0, 9, 351812)

>>> #use datetime module's timetuple method to get a `time.struct_time` object.[1]
>>> tt = datetime.datetime.timetuple(now)
>>> tt
time.struct_time(tm_year=2013, tm_mon=3, tm_mday=19, tm_hour=13, tm_min=0, tm_sec=9,     tm_wday=1, tm_yday=78, tm_isdst=-1)

>>> #If your datetime object is in utc you do this way. [2](see the first table on docs)
>>> sec_epoch_utc = calendar.timegm(tt) * 1000
>>> sec_epoch_utc
1363698009

>>> #If your datetime object is in local timeformat you do this way
>>> sec_epoch_loc = time.mktime(tt) * 1000
>>> sec_epoch_loc
1363678209.0

[1] http://docs.python.org/2/library/datetime.html#datetime.date.timetuple

[2] http://docs.python.org/2/library/time.html


3

時間オブジェクトを正規化するソリューションの別の形式を次に示します。

def to_unix_time(timestamp):
    epoch = datetime.datetime.utcfromtimestamp(0) # start of epoch time
    my_time = datetime.datetime.strptime(timestamp, "%Y/%m/%d %H:%M:%S.%f") # plugin your time object
    delta = my_time - epoch
    return delta.total_seconds() * 1000.0

2

パンダコードのビット:

import pandas

def to_millis(dt):
    return int(pandas.to_datetime(dt).value / 1000000)

1
import time
seconds_since_epoch = time.mktime(your_datetime.timetuple()) * 1000

9
これは間違っています!タイムタプルにはミリ秒が含まれていないため、mktimeはミリ秒単位のエポックを返しません。この場合は無意味です。
Wang

@王-あなたは正しいサーです、これはミリ秒を返さず、秒のみを返します
MattoTodd


1
* 1000ただし、削除すると、取得されseconds_since_epochます。今はミリ秒は気にしないので、この回答を賛成します。
Michael Scheper 16

0

これは私が上記の答えに基づいて作成した関数です

def getDateToEpoch(myDateTime):
    res = (datetime.datetime(myDateTime.year,myDateTime.month,myDateTime.day,myDateTime.hour,myDateTime.minute,myDateTime.second) - datetime.datetime(1970,1,1)).total_seconds()
    return res

戻り値は次のようにラップできます。str(int(res))10進値なしでそれを返すには、文字列またはint(strなし)として使用するだけです


-14

隠された日時からunixtimestampmillisへのこの他のソリューション。

private static readonly DateTime UnixEpoch = new DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc);

    public static long GetCurrentUnixTimestampMillis()
    {
        DateTime localDateTime, univDateTime;
        localDateTime = DateTime.Now;          
        univDateTime = localDateTime.ToUniversalTime();
        return (long)(univDateTime - UnixEpoch).TotalMilliseconds;
    } 

2
質問は、Python言語についてです
ステファン・
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.