如何获得UTC时间,即自1970年1月1日的Unix纪元以来的毫秒?


当前回答

datetime。您已经可以使用方法strftime导出到时间戳。下面是函数示例:

import datetime
def UtcNow():
    now = datetime.datetime.utcnow()
    return int(now.strftime("%s"))

如果您想要微秒,您需要更改导出字符串并将其强制转换为浮点类型,例如:

其他回答

你可以使用datetime库获取UTC时间甚至是本地时间。

import datetime

utc_time = datetime.datetime.utcnow() 
print(utc_time.strftime('%Y%m%d %H%M%S'))
import datetime
import pytz

# datetime object with timezone awareness:
datetime.datetime.now(tz=pytz.utc)

# seconds from epoch:
datetime.datetime.now(tz=pytz.utc).timestamp() 

# ms from epoch:
int(datetime.datetime.now(tz=pytz.utc).timestamp() * 1000) 

时区感知的datetime对象,不像datetime.utcnow():

from datetime import datetime,timezone
now_utc = datetime.now(timezone.utc)

从Unix纪元开始的时间戳,单位为毫秒:

datetime.now(timezone.utc).timestamp() * 1000

为什么所有回复基于datetime而不是时间? 我认为这是简单的方法!

import time
nowgmt = time.strftime("%Y-%m-%d %H:%M:%S", time.gmtime())
print(nowgmt)

对于Python 2代码,使用datetime.utcnow():

from datetime import datetime
datetime.utcnow()

对于Python 3,使用datetime.now(timezone.utc)(2。X解决方案在技术上是可行的,但在3中有一个巨大的警告。x文档):

from datetime import datetime, timezone
datetime.now(timezone.utc)

当您需要计算两个日期之间所花费的时间时,您需要做的就是减去结束日期和开始日期。这种减法的结果是一个timedelta对象。

来自python文档:

class datetime.timedelta([days[, seconds[, microseconds[, milliseconds[, minutes[, hours[, weeks]]]]]]])

这意味着默认情况下,您可以获得它的定义中提到的任何字段- 天,秒,微秒,毫秒,分钟,小时,周。timedelta实例也有total_seconds()方法:

返回持续时间中包含的总秒数。 相当于(td。微秒+ (td。秒+ td。天* 24 * 3600)* 106) / 106计算时启用真除法。