Answers:
在我看来,最简单的方法是
import datetime
epoch = datetime.datetime.utcfromtimestamp(0)
def unix_time_millis(dt):
return (dt - epoch).total_seconds() * 1000.0
%s
取决于操作系统!因此,任何人都希望代码无论在哪个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'偏移。这是因为dt
in中dt- epoch
已经计算了'tz',其中epoch是UTC时间。计算纪元的最佳方法epoch = datetime.datetime(1970, 1, 1)
是考虑时区。
datetime.utcfromtimestamp(0)
带tzinfo返回日期时间?就在方法名称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
在朴素的datetime对象上使用,则假定它在本地时区中。如果这不是您打算发生的事情,请使用可识别时区的日期时间对象。
.timestamp()
方法假定原始输入日期时间在本地时区中(本地时间可能不明确)。如果使用UTC,请dt.replace(tzinfo=timezone.utc).timestamp()
改用。
datetime.datetime.now(pytz.timezone('Europe/Paris')).timestamp() == datetime.datetime.now(pytz.utc).timestamp() == datetime.datetime.utcnow().timestamp()
但是(总是)不等于datetime.datetime.now().timestamp()
(如果本地tz是UTC,则最后一个等于其他时间...)
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()
返回tm_isdst=-1
它迫使mktime()
猜测。在DST期间可能会猜错(发生错误的50%+/-小时)。'%s'和都mktime()
可能为过去的日期使用错误的utc偏移量。您需要一个历史时区数据库(例如由pytz
模块提供的数据库)才能可靠地将本地时间转换为POSIX时间戳(除非OS已经提供了此类数据库)
time.mktime(ts.timetuple())
ts是python的datetime对象
mktime/timetuple
。还timetuple()
剥夺了几分之一秒,问题的重点是获得毫秒精度的时间戳。
您可以使用Delorean来时空旅行!
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
从Recommendedations 的Python 2.7文档的time
模块
time
模块,但是OP询问了有关datetime
模块的信息。FWIW,最简单的当前纪元是int(time.time())
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()
从结果中调用小数秒(无论是否重要取决于应用程序)。这个问题还问的是* milli *秒,而不是秒
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
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))要返回它而没有用作字符串的十进制值或仅用作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;
}