Мне кажется, что самый простой способ сделать это -
import datetime
epoch = datetime.datetime.utcfromtimestamp(0)
def unix_time_millis(dt):
return (dt - epoch).total_seconds() * 1000.0
Вот еще одна форма решения с нормализацией вашего объекта времени:
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
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()
вызывает полоски секунды из результата (независимо от того, зависит ли это от приложения). Также задается вопрос о * миллисекундах, а не секундах
– jfs
15 May 2014 в 19:52
utctimetuple()
разделяет доли секунды. Умножение на 1000
не вернет их.
– jfs
29 December 2014 в 02:14
В Python 3.3 добавьте новый метод.
datetime.timestamp()
https://docs.python.org/3.3/library/datetime.html#datetime.datetime.timestamp
.timestamp()
метод предполагает, что наивное входное время и время находится в локальном часовом поясе (и местное время может быть неоднозначным). Если он находится в формате UTC, используйте dt.replace(tzinfo=timezone.utc).timestamp()
вместо .
– jfs
29 December 2014 в 02:12
datetime.datetime.timestamp(datetime.datetime.now())
– MarkHu
1 February 2018 в 21:01
datetime.datetime.now(pytz.timezone('Europe/Paris')).timestamp() == datetime.datetime.now(pytz.utc).timestamp() == datetime.datetime.utcnow().timestamp()
, но не (всегда), равный datetime.datetime.now().timestamp()
(этот последний равен только остальным, если локальный tz - UTC ...)
– Bluu
12 July 2018 в 14:28
Вот как я это делаю:
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
Вы можете использовать Delorean для перемещения в пространстве и времени!
import datetime
import delorean
dt = datetime.datetime.utcnow()
delorean.Delorean(dt, timezone="UTC").epoch
http://delorean.readthedocs.org/ru/latest/quickstart.html & nbsp;
>>> 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
Рекомендации из документов Python 2.7 для модуля time
time
, но OP спросил о модуле datetime
. FWIW, самая простая текущая эпоха - int(time.time())
– MarkHu
1 February 2018 в 20:38
import time
seconds_since_epoch = time.mktime(your_datetime.timetuple()) * 1000
* 1000
, вы получите seconds_since_epoch
. Активировать этот ответ, потому что сейчас меня не волнует миллисекунды.
– Michael Scheper
27 April 2016 в 21:35
>>> 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/ dateandtimes.html
Документация:
.timetuple()
возвращает tm_isdst=-1
, заставляет mktime()
угадать. Он может ошибиться во время DST (вероятность ошибки +/- час 50%). И «% s», и mktime()
могут использовать неправильное смещение utc для дат из прошлого. Вам нужен исторический временной пояс db, такой как предоставленный модулем pytz
для надежного преобразования локального времени в метку времени POSIX (если ОС уже не предоставляет такой db)
– jfs
15 May 2014 в 20:01
mktime/timetuple
. Также timetuple()
разделяет доли секунды, и точка вопроса заключается в том, чтобы получить метку времени с точностью до миллисекунды.
– jfs
29 December 2014 в 02:18
Это другое решение для преобразования даты и времени в unix timestamp millis.
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;
}
Немного кода панды:
import pandas
def to_millis(dt):
return int(pandas.to_datetime(dt).value / 1000000)
%s
зависит от ОС! Таким образом, каждый хочет, чтобы код работал надежно, независимо от того, какая ОС, НИКОГДА не использовать%s
. Для 2,3 & lt; py ver & lt; 2.7. Можно просто построитьtotal_seconds()
следующим образом:delta.days*86400+delta.seconds+delta.microseconds/1e6
– Wang 24 July 2012 в 11:32dt
должно быть в формате UTC (не локально). См. аналогичный ответ с поддержкой Python 2.6 / 3 – jfs 28 October 2012 в 21:50datetime.utcfromtimestamp(0)
возвращает дату и время без tzinfo? Именно там, в имени метода, utc fromtimestamp. Чтобы сделать его не наивным, я должен сделать что-то вродеdatetime.utcfromtimestamp(0).replace(tzinfo=pytz.UTC)
. Это необходимо, еслиdt
осведомлен о часовом поясе, или вы получитеTypeError: can't subtract offset-naive and offset-aware datetimes
– FGreg 1 September 2016 в 18:03