我想测量以下代码的执行速度:
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
但我没有任何全局变量。
答案 0 :(得分:15)
试试这个:
t = timeit.Timer(stmt='pe1()', setup='from pe1m import pe1')
timeit.Timer
对象不知道您正在调用它的命名空间,因此它无法访问您导入的pe1m
模块。
setup
参数是在定时语句的上下文中执行的语句,它们共享相同的命名空间,因此无论您在那里定义什么,都可以在stmt
中访问。
答案 1 :(得分:4)
你也可以尝试这个
>>>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