使用这个开源工具来监控 Python 中的变量

开源 后端
Watchpoints 是一个简单但功能强大的工具,可以帮助你在调试 Python 时监控变量。

[[392003]]

Watchpoints 是一个简单但功能强大的工具,可以帮助你在调试 Python 时监控变量。

在调试代码时,你经常面临着要弄清楚一个变量何时发生变化。如果没有任何高级工具,那么可以选择使用打印语句在期望它们更改时输出变量。然而,这是一种非常低效的方法,因为变量可能在很多地方发生变化,并且不断地将其打印到终端上会产生很大的干扰,而将它们打印到日志文件中则变得很麻烦。

这是一个常见的问题,但现在有一个简单而强大的工具可以帮助你监控变量:watchpoints

“监视点”的概念在 C 和 C++ 调试器中很常见,用于监控内存,但在 Python 中缺乏相应的工具。watchpoints 填补了这个空白。

安装

要使用它,你必须先用 pip 安装它:

  1. $ python3 -m pip install watchpoints

在Python中使用 watchpoints

对于任何一个你想监控的变量,使用 watch 函数对其进行监控。

  1. from watchpoints import watch
  2.  
  3. a = 0
  4. watch(a)
  5. a = 1

当变量发生变化时,它的值就会被打印到标准输出

  1. ====== Watchpoints Triggered ======
  2.  
  3. Call Stack (most recent call last):
  4. <module> (my_script.py:5):
  5. > a = 1
  6. a:
  7. 0
  8. ->
  9. 1

信息包括:

  • 变量被改变的行。
  • 调用栈。
  • 变量的先前值/当前值。

它不仅适用于变量本身,也适用于对象的变化:

  1. from watchpoints import watch
  2.  
  3. a = []
  4. watch(a)
  5. a = {} # 触发
  6. a["a"] = 2 # 触发

当变量 a 被重新分配时,回调会被触发,同时当分配给 a 的对象发生变化时也会被触发。

更有趣的是,监控不受作用域的限制。你可以在任何地方观察变量/对象,而且无论程序在执行什么函数,回调都会被触发。

  1. from watchpoints import watch
  2.  
  3. def func(var):
  4.     var["a"] = 1
  5.  
  6. a = {}
  7. watch(a)
  8. func(a)

例如,这段代码打印出:

  1. ====== Watchpoints Triggered ======
  2.  
  3. Call Stack (most recent call last):
  4.  
  5. <module> (my_script.py:8):
  6. > func(a)
  7. func (my_script.py:4):
  8. > var["a"] = 1
  9. a:
  10. {}
  11. ->
  12. {'a': 1}

watch 函数不仅可以监视一个变量,它也可以监视一个字典或列表的属性和元素。

  1. from watchpoints import watch
  2.  
  3. class MyObj:
  4.     def __init__(self):
  5.         self.a = 0
  6.  
  7. obj = MyObj()
  8. d = {"a": 0}
  9. watch(obj.a, d["a"]) # 是的,你可以这样做
  10. obj.a = 1 # 触发
  11. d["a"] = 1 # 触发

这可以帮助你缩小到一些你感兴趣的特定对象。

如果你对输出格式不满意,你可以自定义它。只需定义你自己的回调函数:

  1. watch(a, callback=my_callback)
  2.  
  3. # 或者全局设置
  4.  
  5. watch.config(callback=my_callback)

当触发时,你甚至可以使用 pdb

  1. watch.config(pdb=True)

这与 breakpoint() 的行为类似,会给你带来类似调试器的体验。

如果你不想在每个文件中都导入这个函数,你可以通过 install 函数使其成为全局:

  1. watch.install() # watch.install("func_name") ,然后以 func_name() 方式使用

我个人认为,watchpoints 最酷的地方就是使用直观。你对一些数据感兴趣吗?只要“观察”它,你就会知道你的变量何时发生变化。

尝试 watchpoints

我在 GitHub 上开发维护了 watchpoints,并在 Apache 2.0 许可下发布了它。安装并使用它,当然也欢迎大家做出贡献。 

 

责任编辑:庞桂玉 来源: Linux中国
相关推荐

2023-07-30 09:55:02

2020-11-15 18:00:49

开源可视化工具Python

2023-08-20 16:51:28

Kubernetes开源工具

2023-04-18 18:22:31

开源工具数据库

2020-02-11 20:00:29

开源开源工具天气预报

2013-04-15 11:29:28

开源系统监控工具

2013-04-16 10:51:17

开源淘宝服务器

2022-04-08 18:35:13

Linux网络带宽系统监控工具

2019-05-20 15:08:07

PythonPyPI库attrs

2022-02-25 11:51:11

KubeScrape开源监控工具

2010-03-09 15:00:33

Python变量

2021-02-19 10:21:33

黑客攻击l安全

2021-08-31 09:41:57

LinuxiPhone开源工具

2021-09-01 09:47:25

Linux 工具 开发

2021-07-09 05:24:24

云监控工具开源云平台

2009-03-31 16:41:38

网络性能网络监控开源

2019-11-01 09:00:00

Kubernetes开源监控工具

2020-05-03 12:50:19

开源监控工具网络监控开源

2017-06-13 16:07:21

开源网络监控服务器

2010-03-01 17:13:29

Fedora make
点赞
收藏

51CTO技术栈公众号