0. 作用
代码调试工具,在部分场景下,提升代码调试效率
1. 安装
pip install PySnooper
2. 简单使用
以函数为单位进行调试的,它默认只会跟踪函数体内的局部变量
data:image/s3,"s3://crabby-images/3e5fb/3e5fb84bc1a15eae2f6d3adfd42e424bdcb6d2e1" alt=""
3. 详细使用
3.1 重定向到日志文件
添加传参output=filename
data:image/s3,"s3://crabby-images/c74ef/c74efb37d1ffc4333d8fc5b30b111cb1cdf92f4c" alt=""
3.2 跟踪非局部变量
添加传参watch="参数名"
data:image/s3,"s3://crabby-images/855b4/855b4d0239f22e4d2caab979d34d585b164d923f" alt=""
data:image/s3,"s3://crabby-images/f9adc/f9adc52bd13864efec37aec5b73c288296c92d85" alt=""
-
watch
接收一个可迭代对象,如list、tuple -
watch
接收的单个对象,建议使用字符串,否则会报错:TypeError: compile() arg 1 must be a string, bytes or AST object
3.3 跟踪列表或字典的所有项/属性
添加传参watch_explode=("a",)
# func()添加装饰器
@pysnooper.snoop(output=filename, watch_explode=("a", "dict2"))
data:image/s3,"s3://crabby-images/61878/618789413631f131a1077a90a003576439554754" alt=""
3.4 跟踪函数深度
添加传参depth=2
,默认1
data:image/s3,"s3://crabby-images/991e2/991e21d620610c6dbb2cd40599849b584c90f72c" alt=""
3.5 设置调试日志的前缀
添加传参prefix
方便为不同的函数添加不同的标志,以便区分
@pysnooper.snoop(output=filename, prefix="百草:")
data:image/s3,"s3://crabby-images/89b45/89b450bbf63ff794a8adc074b479b9592a6f881a" alt=""
3.6 设置最大输出长度
添加传参max_variable_length
,默认100
默认情况下,PySnooper 输出的变量和异常信息,如果超过 100 个字符,被会截断为 100 个字符
设置None,则表示从不拦截
data:image/s3,"s3://crabby-images/4c911/4c9119b6ff2c4e202ba3e547a3c5c79d10c8235f" alt=""
3.7 支持多线程调试模式
添加传参thread_info=True
,默认False
@pysnooper.snoop(output=filename, thread_info=True)
def func():
...
data:image/s3,"s3://crabby-images/749bf/749bf0e6e77287f52259511aa9bad2ed968c4fbd" alt=""
3.8 支持自定义对象的输出
添加传参custom_repr
,接收元组对象,默认空元组
元组对象中,可以定义:指定特定类型的对象以特定格式进行输出
方法一:(XX类型,custom_repr_func自定义函数)
PySnooper 在打印对象的调试信息时,会逐个判断它是否是 XX类型的对象,若是,就将该对象传入custom_repr_func函数中,由该函数来决定如何显示这个对象的信息。
注:
XX类型,可以是类即自定义数据类型,也可以是基本数据类型,如list
data:image/s3,"s3://crabby-images/92ce0/92ce00451b86a6ddfe5dd0bacd94d366f1bf89d9" alt=""
data:image/s3,"s3://crabby-images/9e22b/9e22b75b4aa636567eee5cdc4bf6bd17d9e22958" alt=""
方法二:(判断条件,custom_repr_func自定义函数)
data:image/s3,"s3://crabby-images/a1d77/a1d77ee89079ce54c32cf1e1d0a3017ce15b404a" alt=""
注:
网友评论