`
chenyinghg
  • 浏览: 33745 次
  • 性别: Icon_minigender_2
  • 来自: 惠州
社区版块
存档分类
最新评论

Python性能测试工具

阅读更多

转载一篇文章, 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提供了多种工具和库来支持...

    Python-profiling一个交互式Python性能分析工具

    Python-profilng是一个强大的交互式Python性能分析工具,它允许开发者深入理解代码的运行时性能,从而找到程序的瓶颈并优化代码。在Python开发过程中,调试工具是必不可少的,特别是对于那些性能敏感的应用,理解...

    Python技术如何进行性能测试.docx

    3. **Python性能测试工具**: - **timeit模块**:内置工具,用于测量代码片段的执行时间,适合简单的性能比较。 - **pytest-benchmark插件**:全面的性能测试工具,支持基准测试和负载测试,生成详细报告。 - **...

    Python性能优化经验谈.pdf

    3、Python性能优化工具 Python内置了丰富的性能优化工具来帮助我们定位性能瓶颈,如:profile、cProfile和hotshot。它们易于使用,而且有完备的支持文档可供参考。使用这些工具可以快速找到瓶颈代码段和最佳优化...

    Python性能优化:掌握性能分析工具的实战指南

    # Python性能优化:掌握性能分析工具的实战指南 Python 是一种高级编程语言,因其简洁的语法和可读性被广泛采用。Python 的设计哲学强调代码的简洁与清晰,使其成为初学者的理想选择,并且同样受到专业开发者的青睐...

    Python造数据工具

    在实际应用中,Python造数据工具可以帮助我们快速构造大规模的测试数据,这对于数据库性能测试、软件功能验证以及数据分析模型的训练都非常有帮助。此外,它还能在教育场景下作为教学辅助工具,让学生通过实际操作...

    Python性能测试工具Locust安装及使用

    一个开源性能测试工具。 define user behaviour with python code, and swarm your system with millions of simultaneous users. 使用Python代码来定义用户行为。用它可以模拟百万计的并发用户访问你的系统。 官方...

    python高性能

    #### 二、Python性能瓶颈定位与优化 - **理解Python底层架构:** 本书首先介绍了Python是如何抽象计算机硬件架构的,这对于理解程序运行机制至关重要。 - **性能瓶颈检测:** 通过使用性能分析工具(如profiler)来...

    自动化测试工具,自动化测试框架,性能测试工具,测试报告工具 软件测试面试题,自动测试面试题,Java面试题,Python面试题

    本文将深入探讨自动化测试工具、自动化测试框架、性能测试工具、测试用例管理和测试报告工具,以及与之相关的面试问题,特别是与Java和Python编程语言相关的面试题。 首先,自动化测试工具如Selenium、Appium和...

    用Python编写分析Python程序性能的工具的教程

    对于简单的性能测试,可以使用`time`命令进行粗粒度的计算。例如,在终端中运行`$ time python yourprogram.py`,会显示程序的`real`、`user`和`sys`时间,分别表示总耗时、用户CPU时间(不包括内核操作)和系统CPU...

    Python-云计算产品性能测试指南

    在Python-云计算产品性能测试指南中,我们主要探讨如何利用Python技术进行云计算产品的性能评估,特别是在Debian系统环境下,针对云服务器、云数据库和对象存储这三种基础云服务。作为root用户,我们可以全面控制和...

    Python-Python写的工具类

    11. **代码性能分析**:工具类可能包含性能计时器,帮助开发者定位代码中的瓶颈。 12. **加密解密**:提供简单的加密和解密功能,如MD5、SHA系列、AES等。 13. **图形用户界面**:如果涉及到GUI,可能有Tkinter、...

    Python pi 性能测试器(代码+exe) zip

    Python性能测试不仅关注计算速度,还关注内存使用和算法的复杂性。通过这个工具,开发者或爱好者可以比较不同Python版本、不同硬件配置下的π计算性能,或者测试优化代码的效果。此外,它也为教学和学习提供了实践...

    python抓包工具集合(for 2.5,for windows)

    WinPcap不仅用于抓包,还可以用于网络监控、数据分析、安全检测等,是许多网络分析工具的基础,包括Wireshark。 接下来,`dpkt-1.7.win32.exe` 是dpkt的Windows兼容版本。dpkt是一个用Python编写的快速、简单、不...

    性能测试工具流程图:jmeter、loadrunner、python

    性能测试工具流程图:jmeter、loadrunner、python

    Python远程调试工具的设计与实现

    为了验证工具的有效性,进行了实际部署和测试,分别在Windows和Linux环境下运行调试工具和Python测试程序。测试结果证实了该工具在连接通用性、调试功能性等方面达到了预期设计目标。 总的来说,Python远程调试工具...

    Python-python工具合集用来快速复用极致执行

    标题中的“Python-python工具合集用来快速复用极致执行”暗示了这个压缩包可能包含了一系列用于提高Python编程效率和执行性能的工具。这些工具可能是库、框架或者脚本,旨在帮助开发者快速重用代码,优化程序,从而...

    Python+locust 性能测试教程

    Locust是一个由Python编写的开源性能测试工具,它以用户友好、分布式和基于脚本的方式进行负载测试。本教程将深入探讨如何利用Python和Locust进行性能测试,以下是一些关键知识点: 1. **Python基础知识**:Python...

    Python 机器学习工具包SKlearn的安装与使用

    Python 机器学习工具包 SKlearn 是基于 Python 语言的机器学习工具包,主要用 Python 编写,建立在 Numpy、Scipy、Pandas 和 Matplotlib 的基础上,也用 Cython 编写了一些核心算法来提高性能。Sklearn 包括六大功能...

    基于Java、Shell、Python语言的BenchmarkSQL 5.1版本TPCC性能测试工具源码

    该项目是一款基于Java、Shell和Python语言的TPCC性能测试工具源码,版本5.1。该工具支持75个文件,包括19个SQL脚本、13个Shell脚本、11个Java源文件、10个JAR包文件、8个R脚本文件、2个Git忽略文件以及其他类型的...

Global site tag (gtag.js) - Google Analytics