- python中测试代码运行时间,可以使用
time库
和timeit库
,使用timeit
来计算相对精确一些,主要用于计算小代码运行时间。- 引用原话:
Class for timing execution speed of small code snippets
- 引用原话:
timeit测试方法
-
使用timeit中的Timer类,
timeit.Timer()
-
Timer(stmt="pass", setup="pass") # 这边只介绍两个参数
- stmt:statement的缩写,就是要测试的语句,要执行的对象
- setup:导入被执行的对象(就和run代码前,需要导入包一个道理)
- 注:两个参数都是字符串类型,当第一个参数直接是具体的语句时,第二个参数就不用设置了
使用time.Timer测试往list加入元素
- list.append
- list = list + [ ]
- list = [i for i in range()]
- list = list(range())
from timeit import Timer
def way1():
li = []
for i in range(10000):
li.append(i)
def way2():
li = []
for i in range(10000):
li = li + [i]
def way2_1():
li = []
for i in range(10000):
li += [i]
def way3():
li = [i for i in range(10000)]
def way4():
li = list(range(10000))
time1 = Timer("way1()", "from __main__ import way1")
print("append:{} s.".format(time1.timeit(1000)))
time2 = Timer("way2()", "from __main__ import way2")
print("+:{} s.".format(time2.timeit(1000)))
time2_1 = Timer("way2_1()", "from __main__ import way2_1")
print("+=:{} s.".format(time2_1.timeit(10000)))
time3 = Timer("way3()", "from __main__ import way3")
print("[i for i in range()]:{} s.".format(time3.timeit(1000)))
time4 = Timer("way4()", "from __main__ import way4")
print("[list(range):{} s.".format(time4.timeit(1000)))
运行结果:
append :0.6885555000000001 s.
+ :106.6892358 s.
+= :7.144745299999997 s.
i for i in range() :0.36833659999999213 s.
list(range) :0.23655779999999993 s.