最近发现了一个Python程序执行的简单实时可视化神器,名字叫 heartrate,安装完运行可以看到下面这样的炫酷过程。
虽然很炫酷,但有点看不懂。
来解释下,左边的动态数字代表每行被触发的次数。变化的蓝色条形图代表了当时被触发的行,较长的条形图表示被触发次数越多,越签的颜色代表被触发的时间越近。
heartrate 的代码高亮部分主要是依赖了executing库:
https://github.com/alexmojaki/executing
除此外,它还可以显示实时堆栈跟踪,有点意思。
pip install --user heartrate
该库目前只支持Python 3.5以上的版本。
import heartrate; heartrate.trace(browser=True)
敲完这一行代码后,将会开始表演:
在文件视图中,堆栈跟踪位于底部。在堆栈跟踪中,可以单击要跟踪的文件的堆栈条目以在该行打开该文件的可视化。
trace 仅跟踪调用它的线程。要跟踪多个线程,必须在每个线程中调用它,每次都使用不同的端口。
files
另外,该库还有个files的功能,files 可以确定跟踪哪些文件。
首先,它必须是可调用的,需要一个「文件路径」的参数。如果该文件应该被跟踪,则返回True,例如:
# 加在主程序里
from heartrate import trace, filestrace(files=files.path_contains(‘my_app‘, ‘my_library‘))
可以根据不同需要使用不同的跟踪功能:
但默认为跟踪包含注释“ # heartrate”的文件。
如果要跟踪多个文件,则可以通过两种方式查看页面的外观:
host
服务器的HTTP主机。要运行可从任何地方访问的远程服务器,请使用‘0.0.0.0‘,默认‘127.0.0.1‘。
port
服务器的HTTP端口,默认9999。
browser
如果为True,则会自动打开一个浏览器选项卡,其中显示了trace调用该文件的可视化效果,默认为False。
daemon
设置包含服务器的线程是否是守护线程。将其设置为true可以在程序其余部分完成后关闭服务器。
GitHub主页:
https://github.com/alexmojaki/heartrate
转自:https://mp.weixin.qq.com/s/U6XUbl0qioC97fh_a0LAiw
原文:https://www.cnblogs.com/geoffreygao/p/13542331.html