10

我想测量以下代码的执行速度:

def pe1():
    l = []
    for i in range(1000):
        if i%3 == 0 or i%5 == 0:
            l.append(i)
    print sum(l)

我将此代码存储在 pe1m.py 下。现在我想用 python 解释器测试文件的速度。我做了:

import timeit
import pe1m

t = timeit.Timer(stmt = 'pe1m.pe1()')
t.timeit()

但我得到:

File "<stdin>", line 1, in <module>
  File "/usr/lib/python2.7/timeit.py", line 195, in timeit
    timing = self.inner(it, self.timer)
  File "<timeit-src>", line 6, in inner
NameError: global name 'pe1m' is not defined

但我没有任何全局变量。

4

2 回答 2

17

尝试这个:

t = timeit.Timer(stmt='pe1()', setup='from pe1m import pe1')

timeit.Timerobject 不知道您在其中调用它的名称空间,因此它无法访问pe1m您导入的模块。

setup参数是在定时语句的上下文中执行的语句,它们共享相同的命名空间,因此无论您在那里定义什么,都可以在stmt.

于 2012-04-12T22:22:45.493 回答
7

你也可以试试这个

>>>def pe1():
>>>    l = []
>>>    for i in range(1000):
>>>        if i%3 == 0 or i%5 == 0:
>>>            l.append(i)
>>>    print(sum(l))
>>>
>>>from  timeit import time it
>>>timeit('pe1()',setup="from __main__ import pe1",number=100) # Run 100 times
>>>timeit('pe1()',setup="from __main__ import pe1")  # run default times of 1000000 
于 2015-02-17T08:11:13.193 回答