想测试一行代码的运行时间,在python中比较方便,可以直接使用timeit:
看个例子吧
>>> import timeit
#执行命令
>>> t2 = timeit.Timer('x=range(1000)')
#显示时间
>>> t2.timeit()
10.620039563513103
#执行命令
>>> t1 = timeit.Timer('sum(x)', 'x = (i for i in range(1000))')
#显示时间
>>> t1.timeit()
0.1881566039438201
或者如下使用
In [1]: from timeit import timeit as timeit
In [2]: timeit('x=1')
Out[2]: 0.03820111778328037
In [3]: timeit('x=map(lambda x:x*10,range(32))')
Out[3]: 8.05639690328919
其实在ipython中可以直接使用
In [4]: timeit y=map(lambda x:x**10,range(32))
10000000 loops, best of 3: 16.2 ns per loop
在python中编程,最大的乐趣就是实际自己需要实现的东西很少.
大多时候,需要做的是"怎么用"!