别再用 print 语句来调试代码了

本文转载自公众号:Python开发者(id:PythonCoder)


调试 Python 代码的时候,你一般采用什么方法调?有些人用 PDB,有些用 IDE 自带的 Debug 功能,不过相信很多人使用的是 Print 语句,因为简单粗暴,其实用 Print 是最低效的。


下面介绍一个很棒的代码调试包,目前该项目在 GitHub 上目已斩获 10K+ Star。


640?wx_fmt=png



PySnooper 是个什么东西?

640?wx_fmt=jpeg


如果你写的 Python 代码不能按如期那样运行,你会绞尽脑汁想为啥出错了。虽然你希望有支持断点的成熟调试器,但或许你现在不想去设置这样的调试器。


你想知道哪些行代码是正常运行,哪些行不正常。据说大多数人会在可疑位置使用 print 输出语句。


其实 PySnooper 的作用有点类似,你不用小心谨慎地用 print 输出语句,只需在想调试的函数中个装饰器。然后得到函数的详细日志,包括运行了哪些行、何时运行,以及何时更改了局部变量。


为什么 PySnooper 能从其他智能调试工具中脱颖而出?


因为你可以在不需要进行任何设置的情况下将其用于糟糕的、庞大的企业代码库中。只需打开装饰器(如下示例所示),并将输出重定向到一个专用的日志文件,将日志文件路径指定为第一个参数。


使用范例


范例是一个把数字转成二进制的函数。

 
 
import pysnooper	
	
@pysnooper.snoop()	
def number_to_bits(number):	
    if number:	
        bits = []	
        while number:	
            number, remainder = divmod(number, 2)	
            bits.insert(0, remainder)	
        return bits	
    else:	
        return [0]	
	
number_to_bits(6)


输出范例

 
 
Starting var:.. number = 6	
21:14:32.099769 call         3 @pysnooper.snoop()	
21:14:32.099769 line         5     if number:	
21:14:32.099769 line         6         bits = []	
New var:....... bits = []	
21:14:32.099769 line         7         while number:	
21:14:32.099769 line         8             number, remainder = divmod(number, 2)	
New var:....... remainder = 0	
Modified var:.. number = 3	
21:14:32.099769 line         9             bits.insert(0, remainder)	
Modified var:.. bits = [0]	
21:14:32.099769 line         7         while number:	
21:14:32.099769 line         8             number, remainder = divmod(number, 2)	
Modified var:.. number = 1	
Modified var:.. remainder = 1	
21:14:32.099769 line         9             bits.insert(0, remainder)	
Modified var:.. bits = [1, 0]	
21:14:32.099769 line         7         while number:	
21:14:32.099769 line         8             number, remainder = divmod(number, 2)	
Modified var:.. number = 0	
21:14:32.099769 line         9             bits.insert(0, remainder)	
Modified var:.. bits = [1, 1, 0]	
21:14:32.099769 line         7         while number:	
21:14:32.099769 line        10         return bits	
21:14:32.099769 return      10         return bits


对这个库感兴趣的话可以用用看:

https://github.com/cool-RR/PySnooper


好文章,在看❤️

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值