在datetime中丢失的微秒数

时间:2016-08-09 02:38:36

标签: python datetime

我试图获得微秒但最后三位数总是0,所以我想我只能得到毫秒。 这是操作系统问题吗?我使用的是Python 2.7.10的Win7x64。 难道我做错了什么?我怎么能得到微秒?

>>> import datetime
>>> datetime.datetime.now()
datetime.datetime(2016, 8, 9, 4, 33, 28, 504000)

这不是

的副本

Using %f with strftime() in Python to get microseconds

因为这种方法最终给了我相同的零。

1 个答案:

答案 0 :(得分:3)

我认为这是Windows下Python 2.7实现的一个已知限制:

>>> import datetime
>>> datetime.datetime.now()
datetime.datetime(2016, 8, 9, 10, 50, 59, 657000)
>>> datetime.datetime.now()
datetime.datetime(2016, 8, 9, 10, 51, 1, 561000)
>>> datetime.datetime.now()
datetime.datetime(2016, 8, 9, 10, 51, 2, 314000)
>>> datetime.datetime.now()
datetime.datetime(2016, 8, 9, 10, 51, 2, 906000)
>>> datetime.datetime.now()
datetime.datetime(2016, 8, 9, 10, 51, 9, 277000)

例如,请参阅herehere

在Python 2.7源代码中,函数Modules/datetimemodule.c/datetime_now()最终调用Modules/timemodule.c/floattime(),其中有以下注释:

/* There are three ways to get the time:
  (1) gettimeofday() -- resolution in microseconds
  (2) ftime() -- resolution in milliseconds
  (3) time() -- resolution in seconds
  In all cases the return value is a float in seconds.
  Since on some systems (e.g. SCO ODT 3.0) gettimeofday() may
  fail, so we fall back on ftime() or time().
  Note: clock resolution does not imply clock accuracy! */

因此,Windows平台显然正在使用ftime()来获取当前时间,并且根据the MSDN page for _ftime()(毫无疑问最终结果),没有微秒可用。因此,Python 2.7只给你毫秒,并将微秒保留为零:

return (double)t.time + (double)t.millitm * (double)0.001;

Python 3.5似乎具有完整的微秒分辨率,因此您可能需要考虑切换到那个(就好像大量的其他改进还不够)。