这3个Python实时可视化工具包来帮你了解性能瓶颈

 更新时间:2021年06月16日 15:57:20   作者:Python学习与数据挖掘  
由于Python的动态性和多功能性,它比其他语言的速度要慢.有时复杂的计算或算法需要大量时间才能在Python中执行.因此需要跟踪代码的执行流,深入了解性能瓶颈,需要的朋友可以参考下

前言

Python中的日志模块可用于跟踪代码的事件,并可用于确定代码崩溃的原因。有效地使用记录器还可以跟踪代码片段的时间复杂度。日志记录可能很有用,但它技术性太强,需要适当的实现。在本文中,我们将讨论3个这样的开源的Python库,它们可以帮助开发人员在几行代码中可视化程序的执行。

一、Pyheat

Pyheat 是一个开源的 Python 库,帮助开发人员获得代码执行的逐行时间分布。Pyheat不是以表格格式显示,而是用热图表示运行每行代码所需的时间。

Pyheat 可以使用从 PyPl 安装

pip install py-heat

引入包

from pyheat import PyHeat

用法

Pyheat可用于为Python模块的每行代码生成时间编号的热图。将Python文件的路径作为参数传递给PyHeat函数。

ph = PyHeat('merge_sort.py')
ph.create_heatmap()
ph.show_heatmap()

上面提到的代码生成了一个热图,表示 在merge_sort.py 模块中运行每一行代码所需的时间(秒)。

从上面的热图来看,虽然第17行中的循环需要花费大部分时间(7秒)来执行。热图有助于开发人员识别花费大量时间执行的代码片段,这些代码片段可能会进一步优化。

更多详情:

https://github.com/csurfer/pyheat

二、Heartrate

Heartrate 是一个开源的 Python 库,提供 Python 程序执行的实时可视化。它提供了一行一行的执行可视化,每个行的执行次数由数字决定。它在浏览器的单独窗口中显示代码的执行情况。

Heartrate 可以通过以下方式从PyPl安装:

pip install heartrate

用法

导入包(import heartrate)后,请使用heartrate.trace(browser=True)函数,该函数将打开一个浏览器窗口,显示调用trace()的文件的可视化效果。

在执行代码时,浏览器中会弹出一个窗口,如果现在你可以按照 http://localhost:9999 观察执行的输出可视化。

每行最左边的数字表示执行特定行的次数。条形图显示了最近被点击的线条-较长的条形图表示点击次数较多,较浅的颜色表示点击次数较多。它还显示了一个活动堆栈跟踪。

更多详情:

https://github.com/alexmojaki/heartrate

三、Snoop

Snoop 是另一个可以用作调试工具的包。Snoop 帮助你识别局部变量的值并跟踪程序的执行。Snoop 主要用作一种调试工具,用于找出 Python 代码为什么没有执行你认为应该执行的操作。

所有这一切都是可能的,只需在你想要跟踪的函数之前使用 snoop 装饰器。

可以使用以下方法从 PyPl 安装 Snoop 库:

pip install snoop

用法

更多详情:

https://github.com/alexmojaki/snoop

结论

在本文中,我们介绍了3个库,它们可以用来可视化Python代码的执行。这些库帮助开发人员深入挖掘代码,发现并理解性能瓶颈,只需添加几行代码即可实现。

到此这篇关于这3个Python实时可视化工具包来帮你了解性能瓶颈的文章就介绍到这了,更多相关Python实时可视化工具包内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • TensorFlow tensor的拼接实例

    TensorFlow tensor的拼接实例

    今天小编就为大家分享一篇TensorFlow tensor的拼接实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-01-01
  • Python单元测试入门到精通讲解

    Python单元测试入门到精通讲解

    单元测试是软件开发中不可或缺的一部分,有助于确保代码的正确性、可维护性和可扩展性,在Python中,有丰富的工具和库可用于进行单元测试,本文将为你提供一个全面的指南,从入门到精通,轻松掌握Python单元测试的方方面面
    2023-11-11
  • Python3爬虫发送请求的知识点实例

    Python3爬虫发送请求的知识点实例

    在本篇文章里小编给大家分享的是一篇关于Python3爬虫发送请求的知识点实例,需要的朋友们可以学习下。
    2020-07-07
  • 基于打开pycharm有带图片md文件卡死问题的解决

    基于打开pycharm有带图片md文件卡死问题的解决

    这篇文章主要介绍了基于打开pycharm有带图片md文件卡死问题的解决,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-04-04
  • 如何利用Pandas删除某列指定值所在的行

    如何利用Pandas删除某列指定值所在的行

    工作中通常会遇到大量的数据集需要处理,其中的一项就是将含有某些数据的行删除掉,下面这篇文章主要给大家介绍了关于如何利用Pandas删除某列指定值所在的行的相关资料,需要的朋友可以参考下
    2022-04-04
  • Python打印酷炫日志的方法详解

    Python打印酷炫日志的方法详解

    在Python中,日志是一种非常重要的工具,可以帮助我们更好地了解程序的运行情况,本文将介绍如何使用logging模块来打印炫酷的日志,需要的可以参考一下
    2023-06-06
  • Matplotlib实战之百分比柱状图绘制详解

    Matplotlib实战之百分比柱状图绘制详解

    百分比堆叠式柱状图是一种特殊的柱状图,可以用于可视化比较不同类别或组的百分比或比例的图表,下面我们就来介绍一下如何使用Matplotlib绘制百分比柱状图,需要的可以参考下
    2023-08-08
  • Tensorflow2.1 完成权重或模型的保存和加载

    Tensorflow2.1 完成权重或模型的保存和加载

    这篇文章主要为大家介绍了Tensorflow2.1 完成权重或模型的保存和加载,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • python使用jpype导入多个Jar的异常问题及解决

    python使用jpype导入多个Jar的异常问题及解决

    这篇文章主要介绍了python使用jpype导入多个Jar的异常问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • Pandas+Numpy+Sklearn随机取数的实现示例

    Pandas+Numpy+Sklearn随机取数的实现示例

    使用Python、pandas、numpy、scikit-learn来实现随机打乱、抽取和切割数据,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧
    2024-03-03

最新评论