转自:

http://blog.sina.com.cn/s/blog_6163bdeb0101806e.html
http://www.sharejs.com/codes/python/6199
http://blog.csdn.net/rumswell/article/details/7349915

想测试一行代码的运行时间,在python中比较方便,可以直接使用timeit:

看个例子吧

[python]  view plain copy
  1. >>> import timeit
  2. #执行命令
  3. >>> t2 = timeit.Timer('x=range(1000)')
  4. #显示时间
  5. >>> t2.timeit()
  6. 10.620039563513103
  7. #执行命令
  8. >>> t1 = timeit.Timer('sum(x)', 'x = (i for i in range(1000))')
  9. #显示时间
  10. >>> t1.timeit()
  11. 0.1881566039438201

或者如下使用

[python]  view plain copy
  1. In [1]: from timeit import timeit as timeit
  2. In [2]: timeit('x=1')
  3. Out[2]: 0.03820111778328037
  4. In [3]: timeit('x=map(lambda x:x*10,range(32))')
  5. Out[3]: 8.05639690328919

其实在ipython中可以直接使用

[python]  view plain copy
  1. In [4]: timeit  y=map(lambda x:x**10,range(32))
  2. 10000000 loops, best of 3: 16.2 ns per loop

在python中编程,最大的乐趣就是实际自己需要实现的东西很少.

Python 社区有句俗语: “python自己带着电池” ,别自己写计时框架。 Python 2.3 具备一个叫做 timeit的完美计时工具可以测量python代码的运行时间。

timeit 模块

  • timeit 模块定义了接受两个参数的 Timer 类。两个参数都是字符串。 第一个参数是你要计时的语句或者函数。 传递给 Timer 的第二个参数是为第一个参数语句构建环境的导入语句。 从内部讲, timeit 构建起一个独立的虚拟环境, 手工地执行建立语句,然后手工地编译和执行被计时语句。
  • 一旦有了 Timer 对象,最简单的事就是调用 timeit(),它接受一个参数为每个测试中调用被计时语句的次数,默认为一百万次;返回所耗费的秒数。
  • Timer 对象的另一个主要方法是 repeat(), 它接受两个可选参数。 第一个参数是重复整个测试的次数,第二个参数是每个测试中调用被计时语句的次数。 两个参数都是可选的,它们的默认值分别是 3 和1000000。 repeat() 方法返回以秒记录的每个测试循环的耗时列表。Python 有一个方便的 min 函数可以把输入的列表返回成最小值,如: min(t.repeat(3, 1000000))
  • 你可以在命令行使用 timeit 模块来测试一个已存在的 Python 程序,而不需要修改代码。
  • 具体可参见文档: http://docs.python.org/library/timeit.html

# -*- coding: utf-8 -*-
#!/bin/env python

def test1():
    n=0
    for i in range(101):
        n+=i
    return n

def test2():
    return sum(range(101))

def test3():
    return sum(x for x in range(101))

if __name__=='__main__':
    from timeit import Timer
    t1=Timer("test1()","from __main__ import test1")
    t2=Timer("test2()","from __main__ import test2")
    t3=Timer("test3()","from __main__ import test3")
    print t1.timeit(10000)
    print t2.timeit(10000)
    print t3.timeit(10000)
    print t1.repeat(3,10000)
    print t2.repeat(3,10000)
    print t3.repeat(3,10000)

结果如下

3.21831489756
0.109082858296
4.83077821343
[3.2328774327463403, 3.200496361967792, 3.219513164382626]
[0.11024445844373787, 0.10911708052280389, 0.10891761383080834]
[4.817947811802895, 4.892466221265554, 5.003930946530911]

利用time模块

利用time模块(仅作练习之用,不推荐)。 time.localtime(),  time.time(),  time.clock() 对比:

  • time.localtime(),localtime返回的是struct_time,包含年月日,显然没有必要,更重要的是localtime()的精度依赖于time()
  • time.time(),time返回的是UTC时间(seconds since the 00:00:00 UTC on January 1)。在很多系统,包括windows下精度很差,win32下的精度只有1/18.2秒。不过在Unix/Linux系统下,time()的精度还是很高的。
  • Python的标准库手册推荐在任何系统下都尽量使用time.clock()。不过要注意是在win32系统下,这个函数返回的是真实时间(wall time),而在Unix/Linux下返回的是CPU时间。在win32下,这个函数的时间分辨率好于1微秒。

# -*- coding: utf-8 -*-
#!/bin/env python

def test():
    L=[]
    for i in range(100):
        L.append(i)

if __name__=='__main__':
    from time import clock
    start=clock()
    for i in range(10000):
        test()
    finish=clock()
    print (finish-start)/10000

执行结果为

0.00032365431221

其他方法

遇到复杂的程序,有很多性能分析工具可用。比如python的标准库里的profile可以统计程序里每一个函数的运行时间,并且提供了多样化的报表。

大多时候,需要做的是"怎么用"!

python内置了timeit模块,通过它可以很简单的计算出代码执行时间,可以通过number参数控制代码的执行次数,非常好用。
更详细的实用方法可以参考:http://docs.python.org/2/library/timeit.html

Python
>>> import timeit
>>> timeit.timeit('"-".join(str(n) for n in range(100))', number=10000)
0.8187260627746582
>>> timeit.timeit('"-".join([str(n) for n in range(100)])', number=10000)
0.7288308143615723
>>> timeit.timeit('"-".join(map(str, range(100)))', number=10000)
0.5858950614929199
#该代码片段来自于: http://www.sharejs.com/codes/python/6199

python中timeit模块用法相关推荐

  1. python中MySQLdb模块用法实例

    篇文章主要介绍了python中MySQLdb模块用法,以实例形式详细讲述了MySQLdb模块针对MySQL数据库的各种常见操作方法,非常具有实用价值,需要的朋友可以参考下 本文实例讲述了python中 ...

  2. python中random模块用法_Python中random模块用法实例分析

    本文实例讲述了Python中random模块用法.分享给大家供大家参考.具体如下: import random x = random.randint(1,4); y = random.choice([ ...

  3. python中os模块用法

    一.os模块概述 Python os模块包含普遍的操作系统功能.如果你希望你的程序能够与平台无关的话,这个模块是尤为重要的.(一语中的) 二.常用方法 1.os.name 输出字符串指示正在使用的平台 ...

  4. python中elasticsearch_dsl模块用法详解

    elasticsearch-dsl是基于elasticsearch-py封装实现的,提供了更简便的操作elasticsearch的方法. 安装: pip install elasticsearch_d ...

  5. python中inspect模块用法详解

    获取函数签名对象.函数签名包含了一个函数的信息,包括函数名.它的参数类型.它所在的类和名称空间及其他信息). inspect模块主要提供了四种用处: 对是否是模块.框架.函数进行类型检查 获取源码 获 ...

  6. python argparse模块详解_python中argparse模块用法实例详解

    本文实例讲述了python中argparse模块用法.分享给大家供大家参考.具体分析如下: 平常在写命令行工具的时候,经常会带参数,所以用python中的argparse来实现. # -*- codi ...

  7. python中mysqldb模块_python中MySQLdb模块用法实例

    本文实例讲述了python中MySQLdb模块用法.分享给大家供大家参考.具体用法分析如下: MySQLdb其实有点像php或asp中连接数据库的一个模式了,只是MySQLdb是针对mysql连接了接 ...

  8. python pygame模块_python中pygame模块用法实例

    本文实例讲述了python中pygame模块用法,分享给大家供大家参考.具体方法如下: import pygame, sys from pygame.locals import * #set up p ...

  9. python bisect_python中bisect模块用法实例

    本文实例讲述了python中bisect模块用法,分享给大家供大家参考. 具体方法分析如下: 这个模块只有几个函数,一旦决定使用二分搜索时,立马要想到使用这个模块. 示例代码如下: import bi ...

最新文章

  1. linux下vsftp
  2. 自作的WM文件浏览器
  3. 使用jq.lazyload.js,解决设置loading图片的问题
  4. oracle插入数据语句实例,oracle Insert 用法总结
  5. 20190226work
  6. java webservice
  7. 红旗linux mysql_请问红旗Linux下,安装Mysql时,应该下载mysql 的哪一种rpm包?谢谢
  8. android react混合开发框架,7个混合式移动开发框架
  9. 第四章_思科ASDM网管系统搭建(java环境,jdk环境)
  10. html中增加一个播放器,从零实现一个自定义 HTML5 播放器
  11. 解决post提交时参数的中文乱码问题
  12. 一年月份大小月口诀_农历大小月卦口诀详解(最新版).doc
  13. 面试题目之:为什么选择veu?与其他框架对比的优势和劣势?
  14. 解决异常 more than one ‘primary‘ bean found among candidates: [jacksonObjectMapper, objectMapper]
  15. Visual C++编译错误:error C2220: 警告被视为错误 - 没有生成“object”文件
  16. 阿里云 mysql参数_阿里云MYSQL数据库怎么修改参数值?
  17. 关于欧盟人工智能法案我们需要了解什么?
  18. matlab 图像输入/显示等
  19. 爽啊,这么多有趣好玩强大的 Python 库
  20. FTP主动和被动模式区别?

热门文章

  1. 日语假名的罗马字表示法 注意事项:
  2. 如何避免网站改版造成的排名影响
  3. 前十四大好用的漏扫工具(偏web版)
  4. windows内存清理工具
  5. 全国电子矢量地图交流
  6. SpaceBuilder 1.0RC源代码提供下载
  7. 汇编语言是php吗,汇编程序属于应用软件吗
  8. ActivePerl 安装
  9. Linux grep命令使用介绍
  10. HP小型机的信息的命令集