9

我正在使用一个非常简单的代码来为for语句中的每个循环计时。它看起来像这样:

import time

for item in list_of_files:

    # Start timing this loop.
    start = time.clock()

    # Do a bunch of stuff.

    # Get time elapsed in seconds.
    elapsed = time.clock() - start

    # Get minutes and seconds.
    m, s = divmod(elapsed, 60)

    # Print result.
    print 'End of analysis for %s in %dm %02ds.\n'% (item, m, s)

这在大多数情况下会导致正确的输出,9m 52s但有时会有大循环(需要一些时间),我会得到负面结果,例如-53m 17s.

我无法确定结果开始显示为负值的明确限制,但它显然只发生在经过时间 > 20 分钟的情况下,但不是针对每个花费 > 20 分钟的循环(即:它不一致)。

我的代码中有什么东西可以对导致这种情况的每个循环进行计时吗?

添加

我正在Spyder用作我的 IDE。我比较了time.clock()表现与time.time()这就是我所看到的:

>>> st1, st2 = time.clock(), time.time()
>>> st1,st2
(507.65, 1374502193.357196)
>>> print time.clock()-st1, time.time()-st2
0.14 15.1921429634
>>> print time.clock()-st1, time.time()-st2
0.34 35.0087578297
>>> print time.clock()-st1, time.time()-st2
0.67 69.8715758324
>>> print time.clock()-st1, time.time()-st2
0.77 80.0557789803
>>> print time.clock()-st1, time.time()-st2
1.25 130.559605837
>>> print time.clock()-st1, time.time()-st2
3.02 309.845729828
>>> print time.clock()-st1, time.time()-st2
8.9 899.936934948

不应该time.clock()以秒为单位返回经过的时间吗?该time.time()呼叫以秒为单位精确跟踪经过的时间(例如,最后一次呼叫是在 15 分钟后进行的,等于 900 秒),但我不知道time.clock()在做什么。

4

2 回答 2

4

我怀疑你有某种溢出。

http://linux.die.net/man/3/clock

时钟的linux手册页建议时钟周期的返回值,因此如果时钟恰好以高值开始并以低值停止,并且您的差是有符号的,您可能会得到一个经过时间的负值。

由于您正在对持续数秒的事件进行计时,因此 time.time() 函数可能更适合您正在做的事情。

于 2013-07-22T13:40:00.733 回答
1

time.clock()测量 Unix 系统上的 CPU 时间,而不是 wall 时间。有关底层系统调用的更多信息,请参见http://pubs.opengroup.org/onlinepubs/007908799/xsh/clock.html(注意它说它可以包装的部分)。

如果要测量 walltime,请使用time.time().

于 2013-07-22T14:56:51.737 回答