关于PySnooper 永远不要使用print进行调试的问题
PySnooper是一个非常方便的调试器。如果您正在试图弄清楚为什么您的Python代码没有按照您的预期去做,您会希望使用具有断点和监视功能的成熟Debug工具,但是许多Debug工具配置起来非常麻烦。
现在,有了PySnooper,您并不需要配置那么复杂的Debug工具,就能够完成对整个代码的分析。它能告诉您哪些代码正在运行,以及局部变量的值是什么。
其实,PySnooper就是替代了一行一行print的重复性工作,给你的代码一个pysnooper装饰器,它能自动识别到语句和变量并将其值print出来:
importpysnooper @pysnooper.snoop() defnumber_to_bits(number): ifnumber: bits=[] whilenumber: number,remainder=divmod(number,2) bits.insert(0,remainder) returnbits else: return[0] number_to_bits(6)
效果如下:
Sourcepath:...1.py Startingvar:..number=6 23:03:35.990701call4defnumber_to_bits(number): 23:03:35.991699line5ifnumber: 23:03:35.991699line6bits=[] Newvar:.......bits=[] 23:03:35.991699line7whilenumber: 23:03:35.991699line8number,remainder=divmod(number,2) Modifiedvar:..number=3 Newvar:.......remainder=0 23:03:35.991699line9bits.insert(0,remainder) Modifiedvar:..bits=[0] 23:03:36.004664line7whilenumber: 23:03:36.005661line8number,remainder=divmod(number,2) Modifiedvar:..number=1 Modifiedvar:..remainder=1 23:03:36.005661line9bits.insert(0,remainder) Modifiedvar:..bits=[1,0] 23:03:36.007657line7whilenumber: 23:03:36.007657line8number,remainder=divmod(number,2) Modifiedvar:..number=0 23:03:36.008655line9bits.insert(0,remainder) Modifiedvar:..bits=[1,1,0] 23:03:36.008655line7whilenumber: 23:03:36.009651line10returnbits 23:03:36.009651return10returnbits Returnvalue:..[1,1,0] Elapsedtime:00:00:00.020945
可以看到,它将每一行变量的值都输出到屏幕上,方便你调试代码。
仅仅需要写一行代码—使用装饰器就可以实现这个方便的调试功能,比起一行行写print,这可方便多了。
0.安装模块
使用这个模块,你只需要使用Pip安装PySnooper:
pipinstallpysnooper
接下来讲讲这个模块其他好用的功能:
1.支持日志文件
如果你觉得print到屏幕上不方便,还可以将其输出到log文件中,你只需要将装饰器那一行改为:
@pysnooper.snoop('/my/log/file.log')
2.读取局外变量或其他表达式
如果你想读取在装饰器作用范围以外的变量或者表达式的值,还可以使用watch参数:
@pysnooper.snoop(watch=('foo.bar','self.x["whatever"]'))
3.如果你不想用装饰器,也可以用上下文的形式调试
没错,装饰器有限定的使用条件,使用起来比较局限,因此pysnooper还支持使用with的上下文形式:
importpysnooper importrandom deffoo(): lst=[] foriinrange(10): lst.append(random.randrange(1,1000)) withpysnooper.snoop(): lower=min(lst) upper=max(lst) mid=(lower+upper)/2 print(lower,mid,upper) foo()
效果如下,只有上下文里的代码才会被调试出来:
Newvar:.......i=9 Newvar:.......lst=[681,267,74,832,284,678,...] 09:37:35.881721line10lower=min(lst) Newvar:.......lower=74 09:37:35.882137line11upper=max(lst) Newvar:.......upper=832 09:37:35.882304line12mid=(lower+upper)/2 74453.0832 Newvar:.......mid=453.0 09:37:35.882486line13print(lower,mid,upper) Elapsedtime:00:00:00.000344
当我们只需要调试部分代码的时候,这个上下文形式的调试方法非常方便。
此外,PySnooper还有许多更强大的用法,大家可以看他们的高级使用文档:
https://github.com/cool-RR/PySnooper/blob/master/ADVANCED_USAGE.md
到此这篇关于PySnooper永远不要使用print进行调试的文章就介绍到这了,更多相关PySnooperprint调试内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。