linux看待python_使用开源可视化工具来理解你的 Python 代码|Linux 中国

bfce8ff7f72466668112680bab7e27a9.png

导读:VizTracer 工具可以可视化并跟踪 Python 代码,让你可以更深入地了解其工作原理。

本文字数:1544,阅读时长大约:2分钟

https://linux.cn/article-12819-1.html

作者:Tian Gao

译者:xiao-song-123

随着 Python 项目变得越来越大、越复杂,理解起它来就变得充满挑战性。即使是你自己独自编写了整个项目,也不可能完全知道项目是如何工作的。为了能更好的理解你的代码,调试和分析代码变得至关重要。

VizTracer

是一个这样的工具,它通过跟踪和可视化 Python 代码的执行过程,来帮助你对代码的理解。无需对源代码进行任何更改,VizTracer 即可记录函数的入口 / 出口,函数参数 / 返回值以及任意变量,然后通过Trace-Viewer使用直观的谷歌前端界面来显示数据。

下面是一个运行蒙特卡洛树搜索的例子:

974cd2c9bfa0d981821eb3988cbaf45a.png

Monte Carlo tree search visualization

每个函数都在时间线上以堆栈的形式记录和可视化,这样你就可以看到在运行程序时发生了什么。你可以放大查看任意特定点的详细信息:

818fdc28529d84dc79ada428539c4141.png

Zooming in on VizTracer visualization

VizTracer 还可以自动记录函数参数和返回值。你可以单击函数条目并查看详细信息:

da60493c90262cb8b7e9b0d8a40601a1.png

Viewing VizTracer details

或者你可以创建一个全新的信号,并用它来记录变量。例如,这显示了执行梯度下降时的成本值:

VizTracer gradient descent

与其他设置复杂的工具相比,VizTracer 使用起来非常简单,并且没有任何依赖关系。你可以从 pip 安装它:

你也可以通过输入来跟踪你的程序( 是你脚本的名称):

VizTracer 将在你的工作目录中生成一个 HTML 报告,你可以在 Chrome 浏览器中打开它。

VizTracer 还提供了其他高级功能,比如过滤器功能,你可以使用它过滤掉不想跟踪的函数,获得更清晰的报告。例如,要仅包含文件中的函数,你需要:

记录函数参数和返回值:

记录与某个正则表达式匹配的任意变量:

你可以通过对源代码进行较小的修改来获得其他功能,例如自定义事件来记录数值和对象。

VizTracer 还包括一个虚拟调试器(vdb),它可以调试 VizTracer 的日志文件。可以用 vdb 调试你运行中的代码(与pdb非常相似)以便你了解代码流。有用的是,它还支持时间回溯,因为它知道发生的一切。

与一些原型不同,VizTracer 使用纯 C 语言实现其核心,这将极大地减少开销,使其达到类似于cProfile的水平。

VizTracer 是开源的,在 Apache 2.0 许可下发布,支持所有常见的操作系统平台(Linux、macOS 和 Windows)。你可以在GitHub上了解关于它的更多特性并访问源代码。

via:https://opensource.com/article/20/11/python-code-viztracer

作者:Tian Gao选题:lujun9972译者:xiao-song-123校对:wxy

本文由LCTT原创编译,Linux中国荣誉推出

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值