问题
在使用Spyder(3.2.3)调试代码的时候,惊奇地发现它的debug功能简直是个bug:
- 插入的断点没有效果
- 调试过程中变量不会实时显示,直到退出调试的时候才全部显示出来
在stack overflow上看到这似乎是一个诟病已久的问题(?)
同时有人说是版本问题,尝试过3.3,4.0等几个版本后问题并没有解决,所以利用 pdb&ipdb 命令调试。
环境
Spyder 4.0.0
Python 3.8.3
ipdb简单使用方法
- 导入
import pdb
- 设置断点:在需要设置断点的代码前面一行插入
pdb.set_trace() # breakpoint
- 断点设置好以后,点debug按钮进入调试,此时代码自动停在第一行,同时控制台会显示 >ipdb ,在后面直接输入命令对应的字母即可。输入h会显示出所有命令:
- 几个最常用的命令,一般情况下够用了
ipdb> c # continue,继续执行到下一个断点
ipdb> q # quit,退出调试
ipdb> s # step,当前行如果调用了函数,则进入函数体
ipdb> n # next,运行下一行,不会进入函数体
ipdb> j line_number # jump,运行到指定行数
ipdb> p variable_name # print,打印变量名
ipdb> # 直接按回车,重复执行上一个命令