美文网首页
python四个性能检测工具,包括函数的运行内存、时间等等...

python四个性能检测工具,包括函数的运行内存、时间等等...

作者: Python集中营 | 来源:发表于2022-04-30 13:26 被阅读0次

python虽然是一门'慢语言',但是也有着比较多的性能检测工具来帮助我们优化程序的运行效率。

【阅读全文】

这里总结了五个比较好的python性能检测工具,包括内存使用、运行时间、执行次数等方面。

首先,来编写一个基础的python函数用于在后面的各种性能测试。

def base_func():
    for n in range(10000):
        print('当前n的值是:{}'.format(n))

1、memory_profiler进程监视

memory_profiler是python的非标准库,所以这里采用pip的方式进行安装。
它能够监视进程、了解内存使用等情况。

pip install memory_profiler

安装好memory_profiler库以后,直接使用注解的方式进行测试

from memory_profiler import profile

@profile
def base_func1():
    for n in range(10000):
        print('当前n的值是:{}'.format(n))


base_func1()

# Line #    Mem usage    Increment  Occurrences   Line Contents
# =============================================================
#     28     45.3 MiB     45.3 MiB           1   @profile
#     29                                         def base_func():
#     30     45.3 MiB      0.0 MiB       10001       for n in range(10000):
#     31     45.3 MiB      0.0 MiB       10000           print('当前n的值是:{}'.format(n))

从返回的数据结果来看,执行当前函数使用了45.3 MiB的内存。

2、timeit 时间使用情况

timeit是python的内置模块,可以测试单元格的代码运行时间,由于是内置模块所以并不需要单独安装。

import timeit

def base_func2():
    for n in range(10000):
        print('当前n的值是:{}'.format(n))

res = timeit.timeit(base_func2,number=5)

print('当前的函数的运行时间是:{}'.format(res))

当前的函数的运行时间是:0.9675800999999993

根据上面函数的运行返回结果,函数的运行时间是0.96秒。

3、line_profiler行代码运行时间检测

如果在只需要检测函数的局部运行时间的话就可以使用line_profiler了,它可以检测出每行代码的运行时间。
line_profiler是python的非标准库,使用的使用pip的方式安装一下。

pip install line_profiler

最简便的使用方式直接将需要测试的函数加入即可。

def base_func3():
    for n in range(10000):
        print('当前n的值是:{}'.format(n))

from line_profiler import LineProfiler

lp = LineProfiler()

lp_wrap = lp(base_func3)

lp_wrap()

lp.print_stats()

# Line #      Hits         Time  Per Hit   % Time  Line Contents
# ==============================================================
#     72                                           def base_func3():
#     73     10001     162738.0     16.3      4.8      for n in range(10000):
#     74     10000    3207772.0    320.8     95.2          print('当前n的值是:{}'.format(n))

从运行结果可以看出每行代码的运行时间及比例,注意这里的时间单位是微妙。

4、heartrate可视化检测工具

heartrate最值得推荐的是可以在网页上面向检测心率一样检测程序的执行过程,同时,
他还是非标准库,使用pip的方式进行安装。

# pip install heartrate

import heartrate

heartrate.trace(browser=True)

def base_func4():
    for n in range(10000):
        print('当前n的值是:{}'.format(n))

运行以后,控制台打印如下日志:

#  * Serving Flask app "heartrate.core" (lazy loading)
#  * Environment: production
#    WARNING: This is a development server. Do not use it in a production deployment.
#    Use a production WSGI server instead.
#  * Debug mode: off

并且自动打开浏览器地址:http://127.0.0.1:9999

file

【往期精彩】

python-turtle绘制雪容融,已打包成exe可直接运行(附源码)

如何将多张图片合成mp4视频格式,并加入背景音乐...

模型已经写好了,怎么表白就看你的了!

python如何实现网络测试,了解一下speedtest-cli...

又是樱花盛开的季节,使用小乌龟来画一颗樱花树吧!

相关文章

  • python四个性能检测工具,包括函数的运行内存、时间等等...

    python虽然是一门'慢语言',但是也有着比较多的性能检测工具来帮助我们优化程序的运行效率。 【阅读全文】[ht...

  • react性能优化

    性能检测工具 安装react性能检测工具: 然后在./app/index.js中加入参数: 运行程序,在操作之前在...

  • 性能参数

    性能指标 执行时间: 一段代码从开始运行到运行结束,所使用的时间 CPU时间: 函数或线程占用CPU的时间 内存分...

  • python 用来计算函数运行时间的装饰器

    为了更好的测试自己编写Python代码的性能和运行时间,特意搞了一个装饰器来监控函数的运行时间。代码如下

  • JVM整理

    主要包括: 内存结构、判断对象存活、垃圾回收算法、垃圾收集器、GC日志、类加载机制、基本参数调优、基本性能检测工具...

  • mongostat命令

    mongostat mongodb自带性能检测工具,它会间隔固定时间获取mongodb的当前运行状态,并输信息,感...

  • 常见的Android面试题

    如何避免OOM?内存检测工具,MAT使用流程。屏幕适配?性能检测、优化?ActivityManagerServic...

  • 《高性能iOS应用开发》核心优化

    一、移动应用的性能 性能指标 内存 运行所需最小 RAM,内存平均值和峰值,内存泄漏 电量消耗 初始化时间 惰性初...

  • linux PHP7环境安装性能分析工具xhprof扩展及使用

    前言 性能分析是衡量应用程序在代码级别的相对性能。性能分析将捕捉的事件包括:CPU的使用,内存的使用,函数的调用时...

  • 从原理分析PHP性能

    从原理分析PHP的性能,主要从以下几个方面:内存管理、变量、函数、运行机制、网络模型来进行分析。 1.内存管理 类...

网友评论

      本文标题:python四个性能检测工具,包括函数的运行内存、时间等等...

      本文链接:https://www.haomeiwen.com/subject/gelyyrtx.html