我需要一个自纪元以来毫秒(ms)的单个时间戳。这应该不难,我确信我只是缺少datetime
或类似的方法。
实际上,微秒(μs)粒度也很好。我只需要1/10秒的时间。
实施例。我有一个事件发生在每750毫秒,让我们说它检查灯是打开还是关闭。我需要记录每个检查和结果并稍后查看,以便我的日志需要如下所示:
...00250 Light is on
...01000 Light is off
...01750 Light is on
...02500 Light is on
如果我只有完整的第二粒度,我的日志将如下所示:
...00 Light is on
...01 Light is off
...01 Light is on
...02 Light is on
不够准确。
答案 0 :(得分:36)
import time
time.time() * 1000
其中1000是每秒毫秒。如果您想要的是自纪元以来的百分之一秒,则乘以100。
答案 1 :(得分:8)
在Python中,datetime.now()
可能会生成一个精度高于time.time()
的值:
from datetime import datetime, timezone, timedelta
now = datetime.now(timezone.utc)
epoch = datetime(1970, 1, 1, tzinfo=timezone.utc) # use POSIX epoch
posix_timestamp_micros = (now - epoch) // timedelta(microseconds=1)
posix_timestamp_millis = posix_timestamp_micros // 1000 # or `/ 1e3` for float
理论上,time.gmtime(0)
(time.time()
使用的纪元)可能与1970
不同。