如何将日期时间对象转换为自epoch(unix时间)以来的毫秒数?


Answers:


471

在我看来,最简单的方法是

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上都可以可靠运行,永远不要使用%s。对于2.3 <py ver <2.7。可以这样简单地构建一个total_seconds()delta.days*86400+delta.seconds+delta.microseconds/1e6
Wang

14
注意:dt必须使用UTC(非本地)。看到对Python 2.6 / 3支持的类似答案
jfs 2012年

7
值得一提的是,如果您想要的只是一个真正的unix时间戳,如此处en.wikipedia.org/wiki/Unix_time所定义(因此将仅使用此答案中的unix_time函数),则应将int包裹delta.total_seconds()到避免以浮标结尾
corford 2014年

1
utcfromtimestamp(0)仅当'tz'不为0时,使用计算的历元才可能导致'tz'偏移。这是因为dt in中dt- epoch已经计算了'tz',其中epoch是UTC时间。计算纪元的最佳方法epoch = datetime.datetime(1970, 1, 1)是考虑时区。
ahj

35
为什么哦为什么不datetime.utcfromtimestamp(0)带tzinfo返回日期时间?就在方法名称utc fromtimestamp中。为了使其天真,我必须做类似的事情datetime.utcfromtimestamp(0).replace(tzinfo=pytz.UTC)。如果dt知道时区,则这是必要的,否则您会得到TypeError: can't subtract offset-naive and offset-aware datetimes
FGreg

168

在Python 3.3中,添加了新方法timestamp

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

您的问题表明您需要毫秒,您可以这样获得:

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

如果您使用 timestamp在朴素的datetime对象上使用,则假定它在本地时区中。如果这不是您打算发生的事情,请使用可识别时区的日期时间对象。


28
注意:.timestamp()方法假定原始输入日期时间在本地时区中(本地时间可能不明确)。如果使用UTC,请dt.replace(tzinfo=timezone.utc).timestamp()改用
jfs

11
datetime.timestamp()以浮点数返回纪元秒。要获取毫秒数:int(datetime.timestamp()* 1000)
Solar.gy

9
按照 docs.python.org/3/library/…上不友好的文档的精神,此答案不是可复制粘贴的示例datetime.datetime.timestamp(datetime.datetime.now())

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,则最后一个等于其他时间...)
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”)为我返回一个空字符串。第二种方法工作正常。
Pavel Vlasov'4

23
只有第二个精度
shuckc

6
Python不支持'%s',例如Windows上可能不存在。.timetuple()返回tm_isdst=-1它迫使mktime()猜测。在DST期间可能会猜错(发生错误的50%+/-小时)。'%s'和都mktime()可能为过去的日期使用错误的utc偏移量。您需要一个历史时区数据库(例如由pytz模块提供的数据库)才能可靠地将本地时间转换为POSIX时间戳(除非OS已经提供了此类数据库)
jfs 2014年

1
time.mktime(ts.timetuple())ts是python的datetime对象
suhailvs 2014-09-22

1
@suhail:请阅读上面关于的评论mktime/timetuple。还timetuple()剥夺了几分之一秒,问题的重点是获得毫秒精度的时间戳。
2014年


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感谢您的注意!的确没有考虑。如果您的服务器是本地时间而不是UTC,则有所不同。我还没有发现(但是)任何其他有说服力的理由将服务器设置为UTC以外的任何其他方式。我的摩托车是“写UTC,阅读当地时间”,所以您始终知道自己要住的地方...
estani

2
您始终可以使用calendar.timegm而不是mktime来避免mktime尝试猜测时区的问题。
Decko 2017年


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()从结果中调用小数秒(无论是否重要取决于应用程序)。这个问题还问的是* milli *秒,而不是秒
jfs 2014年

我更喜欢使用utcnow()和utctimetuple()使代码完全清楚地表明您正在处理UTC(这样,任何阅读它的人都不必记住timegm仅是UTC)。utctimetuple()并不意味着在朴素的dttm对象上进行翻译(因此使用utcnow()初始化dttm)。另外,问题提到的是秒或毫秒。
科福德2014年

注意:应该在最后一条评论中说过,我读这个问题意味着他想要几秒钟或几毫秒(可能是我的错误)。对于千分之一,只需乘以1000(如最高得分答案所示)。
科尔福德

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
错了!timetuple不包含毫秒,因此mktime将不会以毫秒分辨率返回纪元。在这种情况下是没有用的。
Wang

@Wang-您是正确的先生,这不会返回毫秒,只有几秒钟
MattoTodd


1
* 1000但是,如果删除,您会得到seconds_since_epoch。支持这个答案,因为我现在不在乎毫秒。
Michael Scheper

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))要返回它而没有用作字符串的十进制值或仅用作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语言
斯特凡
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.