转载一篇文章, url:http://blog.csdn.net/xiemanR/article/details/72763234
平时对于代码的测试基本上都是在测试功能。如果自己想开发开源代码的话编写测试用例,测试性能还是很有必要的。
timeit
timeit.timeit()只输出一个时间,单位秒
timeit.repeat()返回一个list, 每次的时间
2.profile
profile:纯Python实现的性能测试模块,接口和cProfile一样。
>>> import profile >>> def fun(): for i in range(100000): a = i * i >>> profile.run('fun()') 5 function calls in 0.031 seconds Ordered by: standard name ncalls tottime percall cumtime percall filename:lineno(function) 1 0.000 0.000 0.016 0.016 :0(exec) 1 0.016 0.016 0.016 0.016 :0(setprofile) 1 0.016 0.016 0.016 0.016 <pyshell#13>:1(fun) 1 0.000 0.000 0.016 0.016 <string>:1(<module>) 1 0.000 0.000 0.031 0.031 profile:0(fun()) 0 0.000 0.000 profile:0(profiler) >>>
ncall:函数运行次数
tottime: 函数的总的运行时间,减去函数中调用子函数的运行时间
第一个percall:percall = tottime / nclall
cumtime:函数及其所有子函数调整的运行时间,也就是函数开始调用到结束的时间。
第二个percall:percall = cumtime / nclall
3.cProfile
profile:c语言实现的性能测试模块,接口和profile一样。
>>> import cProfile >>> def fun(): for i in range(100000): a = i * i >>> cProfile.run('fun()') 4 function calls in 0.024 seconds Ordered by: standard name ncalls tottime percall cumtime percall filename:lineno(function) 1 0.024 0.024 0.024 0.024 <pyshell#17>:1(fun) 1 0.000 0.000 0.024 0.024 <string>:1(<module>) 1 0.000 0.000 0.024 0.024 {built-in method exec} 1 0.000 0.000 0.000 0.000 {method 'disable' of '_lsprof.Profiler' objects} >>>
ncalls、tottime、percall、cumtime含义同profile。
4.line_profiler
安装:
pip install line_profiler
安装之后kernprof.py会加到环境变量中。
line_profiler可以统计每行代码的执行次数和执行时间等,时间单位为微妙。
测试代码:
C:\Python34\test.py
import time @profile def fun(): a = 0 b = 0 for i in range(100000): a = a + i * i for i in range(3): b += 1 time.sleep(0.1) return a + b fun()
使用:
1.在需要测试的函数加上@profile装饰,这里我们把测试代码写在C:\Python34\test.py文件上.
2.运行命令行:kernprof -l -v C:\Python34\test.py
输出结果如下:
Total Time:测试代码的总运行时间
Hits:表示每行代码运行的次数
Time:每行代码运行的总时间
Per Hits:每行代码运行一次的时间
% Time:每行代码运行时间的百分比
5.memory_profiler:
memory_profiler工具可以统计每行代码占用的内存大小。
安装:
pip install memory_profiler
pip install psutil
测试代码:
同line_profiler。
使用:
1.在需要测试的函数加上@profile装饰
2.执行命令: python -m memory_profiler C:\Python34\test.py
输出如下:
6.PyCharm图形化性能测试工具:
PyCharm提供了图像化的性能分析工具,使用方法见利用PyCharm的Profile工具进行Python性能分析。
7.objgraph:
objgraph是一个实用模块,可以列出当前内存中存在的对象,可用于定位内存泄露。
objgraph需要安装:
pip install objgraph
使用方法这里不做描述,自行百度。
-------------------------------------------我是分割线-----------------------------------------
pycharm的图形化工具看起来不错,可以生成调用关系图, 但是该功能在社区版上没有看到。用doxygen+graphviz尝试生成过, 但是只有类的继承图,跟文档api一样,并且会少于代码中真实的继承关系。
在tornado的demo中存在用ab测试网站性能的基准测试代码,需要先安装: sudo apt-get install apache2-utils。
相关推荐
本文将详细介绍如何在Python中进行性能测试,包括常用的性能测试工具、测试策略、脚本编写、测试执行以及结果分析。 性能测试是确保软件应用能够在高负载条件下稳定运行的重要步骤。Python提供了多种工具和库来支持...
Python-profilng是一个强大的交互式Python性能分析工具,它允许开发者深入理解代码的运行时性能,从而找到程序的瓶颈并优化代码。在Python开发过程中,调试工具是必不可少的,特别是对于那些性能敏感的应用,理解...
3. **Python性能测试工具**: - **timeit模块**:内置工具,用于测量代码片段的执行时间,适合简单的性能比较。 - **pytest-benchmark插件**:全面的性能测试工具,支持基准测试和负载测试,生成详细报告。 - **...
3、Python性能优化工具 Python内置了丰富的性能优化工具来帮助我们定位性能瓶颈,如:profile、cProfile和hotshot。它们易于使用,而且有完备的支持文档可供参考。使用这些工具可以快速找到瓶颈代码段和最佳优化...
# Python性能优化:掌握性能分析工具的实战指南 Python 是一种高级编程语言,因其简洁的语法和可读性被广泛采用。Python 的设计哲学强调代码的简洁与清晰,使其成为初学者的理想选择,并且同样受到专业开发者的青睐...
在实际应用中,Python造数据工具可以帮助我们快速构造大规模的测试数据,这对于数据库性能测试、软件功能验证以及数据分析模型的训练都非常有帮助。此外,它还能在教育场景下作为教学辅助工具,让学生通过实际操作...
一个开源性能测试工具。 define user behaviour with python code, and swarm your system with millions of simultaneous users. 使用Python代码来定义用户行为。用它可以模拟百万计的并发用户访问你的系统。 官方...
#### 二、Python性能瓶颈定位与优化 - **理解Python底层架构:** 本书首先介绍了Python是如何抽象计算机硬件架构的,这对于理解程序运行机制至关重要。 - **性能瓶颈检测:** 通过使用性能分析工具(如profiler)来...
本文将深入探讨自动化测试工具、自动化测试框架、性能测试工具、测试用例管理和测试报告工具,以及与之相关的面试问题,特别是与Java和Python编程语言相关的面试题。 首先,自动化测试工具如Selenium、Appium和...
对于简单的性能测试,可以使用`time`命令进行粗粒度的计算。例如,在终端中运行`$ time python yourprogram.py`,会显示程序的`real`、`user`和`sys`时间,分别表示总耗时、用户CPU时间(不包括内核操作)和系统CPU...
在Python-云计算产品性能测试指南中,我们主要探讨如何利用Python技术进行云计算产品的性能评估,特别是在Debian系统环境下,针对云服务器、云数据库和对象存储这三种基础云服务。作为root用户,我们可以全面控制和...
11. **代码性能分析**:工具类可能包含性能计时器,帮助开发者定位代码中的瓶颈。 12. **加密解密**:提供简单的加密和解密功能,如MD5、SHA系列、AES等。 13. **图形用户界面**:如果涉及到GUI,可能有Tkinter、...
Python性能测试不仅关注计算速度,还关注内存使用和算法的复杂性。通过这个工具,开发者或爱好者可以比较不同Python版本、不同硬件配置下的π计算性能,或者测试优化代码的效果。此外,它也为教学和学习提供了实践...
WinPcap不仅用于抓包,还可以用于网络监控、数据分析、安全检测等,是许多网络分析工具的基础,包括Wireshark。 接下来,`dpkt-1.7.win32.exe` 是dpkt的Windows兼容版本。dpkt是一个用Python编写的快速、简单、不...
性能测试工具流程图:jmeter、loadrunner、python
为了验证工具的有效性,进行了实际部署和测试,分别在Windows和Linux环境下运行调试工具和Python测试程序。测试结果证实了该工具在连接通用性、调试功能性等方面达到了预期设计目标。 总的来说,Python远程调试工具...
标题中的“Python-python工具合集用来快速复用极致执行”暗示了这个压缩包可能包含了一系列用于提高Python编程效率和执行性能的工具。这些工具可能是库、框架或者脚本,旨在帮助开发者快速重用代码,优化程序,从而...
Locust是一个由Python编写的开源性能测试工具,它以用户友好、分布式和基于脚本的方式进行负载测试。本教程将深入探讨如何利用Python和Locust进行性能测试,以下是一些关键知识点: 1. **Python基础知识**:Python...
Python 机器学习工具包 SKlearn 是基于 Python 语言的机器学习工具包,主要用 Python 编写,建立在 Numpy、Scipy、Pandas 和 Matplotlib 的基础上,也用 Cython 编写了一些核心算法来提高性能。Sklearn 包括六大功能...
该项目是一款基于Java、Shell和Python语言的TPCC性能测试工具源码,版本5.1。该工具支持75个文件,包括19个SQL脚本、13个Shell脚本、11个Java源文件、10个JAR包文件、8个R脚本文件、2个Git忽略文件以及其他类型的...