回答:
これを行う最も簡単な方法は
import datetime
epoch = datetime.datetime.utcfromtimestamp(0)
def unix_time_millis(dt):
return (dt - epoch).total_seconds() * 1000.0
%s
はOSに依存するためです。したがって、誰もがどのOSに関係なくコードが確実に機能することを望んでいます%s
。2.3 <py ver <2.7の場合。一つは単純に構築することができtotal_seconds()
、次のように:delta.days*86400+delta.seconds+delta.microseconds/1e6
dt
UTC(ローカルではない)である必要があります。Python 2.6 / 3サポートで同様の答えを
utcfromtimestamp(0)
、「tz」が0でない場合にのみ「tz」オフセットを引き起こす可能性があります。これは、エポックがUTC時間である場合に「tz」が計算されるためです。エポックを計算する最良の方法は、タイムゾーンが考慮されるところです。dt
dt- epoch
epoch = datetime.datetime(1970, 1, 1)
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
Python 3.3では、新しいメソッドが追加されましたtimestamp
:
import datetime
seconds_since_epoch = datetime.datetime.now().timestamp()
あなたの質問はあなたがミリ秒を必要とすると述べました、あなたはこのように得ることができます:
milliseconds_since_epoch = datetime.datetime.now().timestamp() * 1000
timestamp
単純な日時オブジェクトで使用する場合、ローカルタイムゾーンであると見なされます。これが意図したものでない場合は、タイムゾーン対応の日時オブジェクトを使用してください。
.timestamp()
メソッドは、単純な入力日時がローカルタイムゾーンにあることを前提としています(ローカルタイムがあいまいな場合があります)。UTCの場合は、dt.replace(tzinfo=timezone.utc).timestamp()
代わりに使用してください。
datetime.datetime.timestamp(datetime.datetime.now())
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つは残りにのみ等しい)
fromtimestamp
(docs.python.org/3/library/…)
>>> 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
ドキュメンテーション:
.timetuple()
ます。DST中に誤って推測する可能性があります(エラーの50%の確率+/-時間)。どちらも '%s'であり、過去の日付に対して誤ったutcオフセットを使用する可能性があります。ローカル時刻を確実にPOSIXタイムスタンプに変換するには、モジュールによって提供されるような履歴タイムゾーンデータベースが必要です(OSがすでにそのようなデータベースを提供している場合を除く)tm_isdst=-1
mktime()
mktime()
pytz
time.mktime(ts.timetuple())
ここで、tsはpythonのdatetimeオブジェクトです
mktime/timetuple
。またtimetuple()
、秒の端数を取り除き、質問のポイントは、ミリ秒の精度でタイムスタンプを取得することです。
デロリアンを使って時空を旅することができます!
import datetime
import delorean
dt = datetime.datetime.utcnow()
delorean.Delorean(dt, timezone="UTC").epoch
これが私のやり方です:
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
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秒の端数をストリップします(重要かどうかはアプリケーションによって異なります)。また、質問では秒ではなく*ミリ*秒について質問します
utctimetuple()
秒の端数を取り除きます。乗算して1000
も元に戻せません。
>>> 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
時間オブジェクトを正規化するソリューションの別の形式を次に示します。
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
import time
seconds_since_epoch = time.mktime(your_datetime.timetuple()) * 1000
* 1000
ただし、削除すると、取得されseconds_since_epoch
ます。今はミリ秒は気にしないので、この回答を賛成します。
これは私が上記の答えに基づいて作成した関数です
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なし)として使用するだけです
隠された日時から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;
}