博客
关于我
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/

你可能感兴趣的文章
Node提示:error code Z_BUF_ERROR,error error -5,error zlib:unexpected end of file
查看>>
Node提示:npm does not support Node.js v12.16.3
查看>>
Node搭建静态资源服务器时后缀名与响应头映射关系的Json文件
查看>>
Node服务在断开SSH后停止运行解决方案(创建守护进程)
查看>>
node模块化
查看>>
node模块的本质
查看>>
node环境下使用import引入外部文件出错
查看>>
Node的Web应用框架Express的简介与搭建HelloWorld
查看>>
Node第一天
查看>>
node编译程序内存溢出
查看>>
Node读取并输出txt文件内容
查看>>
node防xss攻击插件
查看>>
noi 1996 登山
查看>>
noi 7827 质数的和与积
查看>>
NOI-1.3-11-计算浮点数相除的余数
查看>>
NOI2010 海拔(平面图最大流)
查看>>
NOIp2005 过河
查看>>
NOIP2011T1 数字反转
查看>>
NOIP2014 提高组 Day2——寻找道路
查看>>
noip借教室 题解
查看>>