Pysooper是什么?

我们写代码会经常出现bug,有的人会使用断点调试器,但是设置这样的断点调试器是花时间的。

所以很多人会在可能出现错误的地方print打印来输出语句。

Pysooper的作用有点类似,你不必小心谨慎的使用print语句,只需要在想要调试的函数中引入一个装饰器。就可以得到函数的详细日志,包括运行了那些行,何时运行,以及何时更改了局部变量。

使用示例

写一个函数,将数字转换为二进制

import pysnooper

@pysnooper.snoop()
def num_to_bits(number):
if number:
bits = []
while number:
# 一个数除以2, 商和余数
number, remainder = divmod(number, 2)
# 将余数放到列表的开始位,也就是0位
bits.insert(0, remainder)
return bits
else:
return [0] num_to_bits(6)

可以看下它的运行:

# 开始
Starting var:.. number = 6
17:35:13.264157 call 4 def num_to_bits(number):
17:35:13.264157 line 5 if number:
17:35:13.264157 line 6 bits = []
New var:....... bits = []
17:35:13.265157 line 7 while number:
17:35:13.265157 line 8 number, remainder = divmod(number, 2)
# 第一次值变化
New var:....... remainder = 0
Modified var:.. number = 3
17:35:13.265157 line 9 bits.insert(0, remainder)
Modified var:.. bits = [0]
17:35:13.265157 line 7 while number:
17:35:13.265157 line 8 number, remainder = divmod(number, 2)
# 第二次值变化
Modified var:.. number = 1
Modified var:.. remainder = 1
17:35:13.265157 line 9 bits.insert(0, remainder)
Modified var:.. bits = [1, 0]
17:35:13.265157 line 7 while number:
17:35:13.265157 line 8 number, remainder = divmod(number, 2)
#第三次值变化
Modified var:.. number = 0
17:35:13.265157 line 9 bits.insert(0, remainder)
Modified var:.. bits = [1, 1, 0]
17:35:13.265157 line 7 while number:
# 跳出循环
17:35:13.265157 line 10 return bits
17:35:13.265157 return 10 return bits
# 得到终值
Return value:.. [1, 1, 0]

又学到了一种调试的方法。

初试PySnooper的更多相关文章

  1. caffe初试(一)happynear的caffe-windows版本的配置及遇到的问题

    之前已经配置过一次caffe环境了: Caffe初试(一)win7_64bit+VS2013+Opencv2.4.10+CUDA6.5配置Caffe环境 但其中也提到,编译时,用到了cuda6.5,但 ...

  2. 初试Nodejs——使用keystonejs创建博客网站2(修改模板)

    上一篇(初试Nodejs——使用keystonejs创建博客网站1(安装keystonejs))讲了keystonejs的安装.安装完成后,已经具备了基本的功能,我们需要对页面进行初步修改,比如,增加 ...

  3. 项目中初试PHP单元测试

    只能叫初试,前面虽然做了一些PHPUnit与团队所用框架的整合,但在整个团队还没有人可以主动推动这个事情,而作为Leader最重要的一种能力应该是"让正确的事情发生",所以今天开始 ...

  4. VPS -Digital Ocean -初试以及VPN的搭建

    首先恭喜你找到这篇博客,它会带你走出困境. 题外话(请忽略):一直以来想搞一个VPS,终于在自己的刺激下试了一下Digital Ocean,还没有使用很长时间不做太多评论,唯一给我的感觉是各种操作还算 ...

  5. 初试微信小程序

    2016年11月3日,微信小程序终于公测了,大家可以正式开发了.早在这之前,应公司要求,和同事就早早的试了一下微信小程序的开发,特此记录一下: 微信官方小程序文档:https://mp.weixin. ...

  6. Win7+VS2013初试Thrift

    win7环境下VS2013编译boost_1_58_0步骤: 官网下载boost_1_58_0(直接下载),解压 cmd窗口cd到boost_1_58_0,执行bootstrap.bat cmd窗口获 ...

  7. java web分页查询初试

    ssh2分页查询初试,放着记录学习一下. entity:student.java: package com.zte.entity; /** * 数据持久化,跟数据库的的相应的表的字段是对应的. * * ...

  8. Windows Phone开发(2):竖立自信,初试锋茫

    原文:Windows Phone开发(2):竖立自信,初试锋茫 上一篇文章中,我们聊了一些"大炮"话题,从这篇文章开始,我们一起来学习WP开发吧. 一.我们有哪些装备. 安装完VS ...

  9. .Net 4.5 异步编程初试(async和await)

    .Net 4.5 异步编程初试(async和await) 前言 最近自己在研究Asp.Net Web API.在看到通过客户端来调用Web API的时候,看到了其中的异步编程,由于自己之前没有接触过, ...

随机推荐

  1. How to set spring boot active profiles with maven profiles

    In the previous post you could read about separate Spring Boot builds for a local development machin ...

  2. vs插件-基于TFS的源码记录可视化

    插件地址:https://marketplace.visualstudio.com/items?itemName=AlexandrBiryukov.TFSSourceControlHistoryVis ...

  3. 选择排序SelectionSort

    转自https://www.cnblogs.com/shen-hua/p/5424059.html a) 原理:每一趟从待排序的记录中选出最小的元素,顺序放在已排好序的序列最后,直到全部记录排序完毕. ...

  4. stop_token.go

    package engine import (     "bufio"     "log"     "os" ) type StopToke ...

  5. logger.go

    package app //日志接口 type Logger interface {     Output(maxdepth int, s string) error }

  6. 「关于一种处理关于$p$成多项式的数论函数筛法」

    张博航原知乎网址 张博航原博客网址 引入: 给一个完全积性函数$f$,求其前缀和 $$S(n)=\sum_{i=1}^nf(i)$$ 初步思考: 考虑由于所求函数为完全积性函数,我们很容易用一个线性筛 ...

  7. 树链剖分的一种妙用与一类树链修改单点查询问题的时间复杂度优化——2018ACM陕西邀请赛J题

    题目描述 有一棵树,每个结点有一个灯(初始均是关着的).每个灯能对该位置和相邻结点贡献1的亮度.现有两种操作: (1)将一条链上的灯状态翻转,开变关.关变开: (2)查询一个结点的亮度. 数据规模:\ ...

  8. Java开源生鲜电商平台-性能优化以及服务器优化的设计与架构(源码可下载)

    Java开源生鲜电商平台-性能优化以及服务器优化的设计与架构(源码可下载) 说明:Java开源生鲜电商平台-性能优化以及服务器优化的设计与架构,我采用以下三种维度来讲解 1.  代码层面. 2.  数 ...

  9. Keepalived + nginx实现高可用性和负载均衡

    在前面的一篇中讲到了Heartbeat作为高可用服务架构的解决方案,今天有试验了一种全新的解决方案,即采用Keepalived来实现这个功能. Keepalived 是一种高性能的服务器高可用或热备解 ...

  10. python书籍推荐:python编码推荐(高清完整pdf)

    目录INF-qa Python 编码规范................................................................................ ...