timeit模块用于测量小段代码执行时间,通过多次运行取最小耗时以减少误差。使用timeit.timeit()函数,传入代码字符串和运行次数number(默认100万次)即可测试性能差异。

Python的timeit模块用来测量小段代码的执行时间,特别适合对比不同实现方式的性能差异。它通过多次运行代码取最小耗时,减少系统波动带来的误差。
基本用法:直接调用timeit函数
使用timeit.timeit()可以快速测试一行代码的运行时间。
- 第一个参数是你要测量的代码,以字符串形式传入
- number参数指定运行次数,默认是100万次
例如,比较两种创建列表的方式:
import timeit# 使用列表推导式
time1 = timeit.timeit('[x*2 for x in range(10)]', number=100000)
# 使用循环append
time2 = timeit.timeit('list(map(lambda x: x*2, range(10)))', number=100000)
print(time1, time2)
使用Timer类自定义测试
当需要更灵活控制时,可以用timeit.Timer类。
立即学习“Python免费学习笔记(深入)”;
- 初始化时传入语句和设置代码
- 调用timeit()方法运行指定次数
- 支持setup参数导入模块或初始化变量
示例:测试字符串拼接性能
import timeitstmt = "'-'.join([str(n) for n in range(100)])"
setup = "pass" # 可在这里导入模块或定义变量
timer = timeit.Timer(stmt, setup)
print(timer.timeit(10000))
在命令行中使用timeit
可以直接在终端运行timeit,适合快速验证。
网站功能资讯模块资料模块会员模块产品展示模块产品订购模块购物车模块留言模块在线加盟模块多级后台管理系统网站环境本系统为 asp.net开发donet版本为1.1框架数据库为acdess2000授权方式为免费,本版本本地可直接运行(使用http://localhost或http://127.0.0.1访问)如需放到外网通过域名访问,则需通过qq联系我免费索取钥匙文件,将钥匙文件放到网站空间根目录即可
- 使用python -m timeit启动
- 后面跟上要测试的代码片段
- 自动选择最佳重复次数并输出结果
例如:
python -m timeit "'spam' * 10"会输出类似:1000000 loops, best of 5: 0.234 usec per loop
注意事项与技巧
使用timeit时注意以下几点才能得到准确结果:
- 避免在测试代码中包含输入输出操作,如print
- 复杂逻辑建议封装成函数再测
- 多次测量取最小值比平均值更可靠
- 确保测试环境一致,避免后台程序干扰
对于多行代码,可用分号或三引号包裹:
timeit.timeit('''a = []
for i in range(10):
a.append(i*2)
''', number=10000)
基本上就这些。掌握timeit能帮你写出更快的Python代码,关键是多试几种写法,用数据说话。









