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

你可能感兴趣的文章
php判断ip黑名单程序代码
查看>>
php判断复选框是否被选中的方法
查看>>
PHP判断指定目录下是否存在文件
查看>>
php判断数组是否为空
查看>>
PHP判断数组是否有重复值、获取重复值
查看>>
springboot基于Web的社区留守儿童管理系统源码毕设+论文
查看>>
Springboot基于Redisson实现Redis分布式可重入锁【案例到源码分析】
查看>>
PHP利用正则表达式实现手机号码中间4位用星号(*)替换显示
查看>>
PHP加密与安全的最佳实践
查看>>
PHP加速器eaccelerator导致php-fpm进程卡死原因分析
查看>>
PHP区分 企业微信浏览器 | 普通微信浏览器 | 其他浏览器
查看>>
php原生代码怎么连表查询,PHP tp5中使用原生sql查询代码实例
查看>>
PHP去掉转义符
查看>>
php去除字符串开头或末尾的字符(例如逗号)
查看>>
php反射api
查看>>
PHP反射ReflectionClass、ReflectionMethod 入门教程
查看>>
PHP反射机制
查看>>
php取当天的最后一秒_Docker快速搭建PHP开发环境详细教程
查看>>
php取绝对值
查看>>
PHP变量内容的获取
查看>>