博客
关于我
timeit 模块详解(准确测量小段代码的执行时间)
阅读量:220 次
发布时间:2019-02-28

本文共 3062 字,大约阅读时间需要 10 分钟。

timeit ??????????????????

timeit ??? Python ????????????????????????????????????????????????????????????????????????????????????????????

??? timeit ??????????????

?????????

????????timeit ??????????????????????????????????

python -m timeit '"-".join(str(n) for n in range(100))' 10000 loops, best of 3: 40.3 usec per looppython -m timeit '"-".join([str(n) for n in range(100)])' 10000 loops, best of 3: 33.4 usec per looppython -m timeit '"-".join(map(str, range(100)))' 10000 loops, best of 3: 25.2 usec per loop

IDLE ????????

? IDLE IDE ??? timeit ??????????

import timeit# ??????????????print(timeit.timeit('"-".join(str(n) for n in range(100))', number=10000))  # ???? 0.8187 ?print(timeit.timeit('"-".join([str(n) for n in range(100)])', number=10000))  # ???? 0.7288 ?print(timeit.timeit('"-".join(map(str, range(100)))', number=10000))  # ???? 0.5859 ?

timeit ???????

timeit ???????????

1. timeit() ??

timeit.timeit(stmt='pass', setup='pass', timer=
, number=1000000)
  • ?????
    • stmt?????????????? pass?
    • setup??????????????? pass?
    • timer????????? time.perf_counter()?
    • number???????????? 1,000,000?

???timeit() ?????????? Python ???????????????????? GC???? setup ??? gc.enable()?

2. repeat() ??

timeit.repeat(stmt='pass', setup='pass', timer=
, repeat=3, number=1000000)
  • ?????
    • stmt?????????????? pass?
    • setup??????????????? pass?
    • timer????????? time.perf_counter()?
    • repeat???????????? 3?
    • number????????????????? 1,000,000?

repeat() ?????????????????????????????????????

3. print_exc() ??

timeit.print_exc(file=None)
  • ???????????????????
  • ???
t = Timer('for i in range(10): oct(i)')try:    t.timeit()except Exception:    t.print_exc()

?????????

???????? timeit ????????????

python -m timeit [-n N] [-r R] [-s S] [-t] [-c] [-v] [-h] [statement ...]
  • -n N ? --number=N?????????????? 1,000,000?
  • -r R ? --repeat=R?????????????? 3?
  • -s S ? --setup=S????????????????? pass?
  • -t ? --time??? time.time() ????????????
  • -c ? --clock??? time.clock() ????????????
  • -v ? --verbose?????????????

??????

???????????

python -m timeit -s 'text = "I love FishC.com!"; char = "o"' 'char in text' 10000000 loops, best of 3: 0.0877 usec per looppython -m timeit -s 'text = "I love FishC.com!"; char = "o"' 'text.find(char)' 1000000 loops, best of 3: 0.342 usec per loop

???????

python -m timeit 'try: str.__bool__ except AttributeError: pass' 100000 loops, best of 3: 15.7 usec per looppython -m timeit 'if hasattr(str, "__bool__"): pass' 100000 loops, best of 3: 4.26 usec per loop

??????

???????

def test():    """Stupid test function"""    L = [i for i in range(100)]if __name__ == '__main__':    import timeit    print(timeit.timeit("test()", setup="from __main__ import test"))

??????

?? ; ???????????

python -m timeit 'try: str.__bool__; except AttributeError: pass' 100000 loops, best of 3: 15.7 usec per loop

?????????????

import sysimport timeimport timeitfrom timeit import _isadora_tty, _isadora_winfrom timeit import _get_timerdef timeit(stmt, setup, timer, number=1000000):    # ... (????????????

timeit ?????????? Python ??????????????????????????????????????

转载地址:http://ouqi.baihongyu.com/

你可能感兴趣的文章
Nginx的使用总结(三)
查看>>
Nginx的使用总结(二)
查看>>
Nginx的可视化神器nginx-gui的下载配置和使用
查看>>
Nginx的是什么?干什么用的?
查看>>
Nginx访问控制_登陆权限的控制(http_auth_basic_module)
查看>>
nginx负载均衡和反相代理的配置
查看>>
nginx负载均衡器处理session共享的几种方法(转)
查看>>
nginx负载均衡的5种策略(转载)
查看>>
nginx负载均衡的五种算法
查看>>
nginx转发端口时与导致websocket不生效
查看>>
Nginx运维与实战(二)-Https配置
查看>>
Nginx配置Https证书
查看>>
Nginx配置ssl实现https
查看>>
Nginx配置TCP代理指南
查看>>
Nginx配置——不记录指定文件类型日志
查看>>
nginx配置一、二级域名、多域名对应(api接口、前端网站、后台管理网站)
查看>>
Nginx配置代理解决本地html进行ajax请求接口跨域问题
查看>>
nginx配置全解
查看>>
Nginx配置参数中文说明
查看>>
nginx配置域名和ip同时访问、开放多端口
查看>>