PySnooper Python 自动 Debug 工具开源项目

我要开发同款
匿名用户2019年04月24日
91阅读

技术信息

开源地址
https://github.com/cool-RR/PySnooper
授权协议
MIT

作品详情

PySooper在GitHub上自嘲是一个“乞丐版”调试工具(poorma'sdebugger)。

一般情况下,在编写Pytho代码时,如果想弄清楚为什么Pytho代码没有按照预期执行、哪些代码在运行哪些没在运行、局部变量又是什么,我们会使用包含断点和观察模式等功能的调试器,或者直接使用prit语句打印出来。

但上面的方法都比较麻烦,例如使用调试器需要进行繁琐的设置,使用prit打印也要很仔细。与它们相比,使用 PySooper只需为要调试的函数添加一个装饰器即可,这样就能获得运行函数详细的log,包括执行的代码行和执行时间,以及局部变量发生变化的确切时间。

之所以称为“乞丐版”,相信是因为PySooper使用起来十分简单,开发者可以在任何庞大的代码库中使用它,而无需进行任何设置。只需添加装饰器,并为日志输出地址指定路径。

示例

下面的代码写了一个函数将传入的值转换为二进制码,并返回一个二进制列表。要使用PySooper,只需为函数添加@pysooper.soop()装饰器即可:

importpysooper@pysooper.soop()defumber_to_bits(umber):ifumber:bits=[]whileumber:umber,remaider=divmod(umber,2)bits.isert(0,remaider)returbitselse:retur[0]umber_to_bits(6)

输出如下

Startigvar:..umber=621:14:32.099769call3@pysooper.soop()21:14:32.099769lie5ifumber:21:14:32.099769lie6bits=[]Newvar:.......bits=[]21:14:32.099769lie7whileumber:21:14:32.099769lie8umber,remaider=divmod(umber,2)Newvar:.......remaider=0Modifiedvar:..umber=321:14:32.099769lie9bits.isert(0,remaider)Modifiedvar:..bits=[0]21:14:32.099769lie7whileumber:21:14:32.099769lie8umber,remaider=divmod(umber,2)Modifiedvar:..umber=1Modifiedvar:..remaider=121:14:32.099769lie9bits.isert(0,remaider)Modifiedvar:..bits=[1,0]21:14:32.099769lie7whileumber:21:14:32.099769lie8umber,remaider=divmod(umber,2)Modifiedvar:..umber=021:14:32.099769lie9bits.isert(0,remaider)Modifiedvar:..bits=[1,1,0]21:14:32.099769lie7whileumber:21:14:32.099769lie10returbits21:14:32.099769retur10returbits

安装

使用pip进行安装

pipistallpysooper

功能介绍

PySnooper 在 GitHub 上自嘲是一个“乞丐版”调试工具(poor man's debugger)。 一般情况下,在编写 Python 代码时,如果想弄清楚为什么 Python 代码...

声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态

评论