pdb

第4种方式是启动Python的调试器pdb,让程序以单步方式运行,可以随时查看运行状态。我们先准备好程序:

# err.py
s = '0'
n = int(s)
print(10 / n)

然后启动:

$ python -m pdb err.py
> /Users/michael/Github/learn-python3/samples/debug/err.py(2)<module>()
-> s = '0'

以参数-m pdb启动后,pdb定位到下一步要执行的代码-> s = '0'。输入命令l来查看代码:

(Pdb) l
1 # err.py
2 -> s = '0'
3 n = int(s)
4 print(10 / n)

输入命令n可以单步执行代码:

(Pdb) n
> /Users/michael/Github/learn-python3/samples/debug/err.py(3)<module>()
-> n = int(s)
(Pdb) n
> /Users/michael/Github/learn-python3/samples/debug/err.py(4)<module>()
-> print(10 / n)

任何时候都可以输入命令p 变量名来查看变量:

(Pdb) p s
'0'
(Pdb) p n
0

输入命令q结束调试,退出程序:

(Pdb) q

这种通过pdb在命令行调试的方法理论上是万能的,但实在是太麻烦了,如果有一千行代码,要运行到第999行得敲多少命令啊。还好,我们还有另一种调试方法。

pdb.set_trace()

这个方法也是用pdb,但是不需要单步执行,我们只需要import pdb,然后,在可能出错的地方放一个pdb.set_trace(),就可以设置一个断点:

# err.py
import pdb s = '0'
n = int(s)
pdb.set_trace() # 运行到这里会自动暂停
print(10 / n)

运行代码,程序会自动在pdb.set_trace()暂停并进入pdb调试环境,可以用命令p查看变量,或者用命令c继续运行:

$ python err.py
> /Users/michael/Github/learn-python3/samples/debug/err.py(7)<module>()
-> print(10 / n)
(Pdb) p n
0
(Pdb) c
Traceback (most recent call last):
File "err.py", line 7, in <module>
print(10 / n)
ZeroDivisionError: division by zero

这个方式比直接启动pdb单步调试效率要高很多,但也高不到哪去。

最新文章

  1. 解决“LINK : fatal error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏”问题
  2. 链地址法实现HashMap
  3. Sharepoint学习笔记—习题系列--70-573习题解析 -(Q35-Q39)
  4. JUnit org.junit.runner.Request.classWithoutSuiteMethod解决方法
  5. struts2 &lt;s:iterator&gt; status属性
  6. 关于使用vss版本管理工具中的sln,suo文件作用
  7. iOS 支付宝应用(备用参考)
  8. uc/os初始化
  9. mysql--help不可用
  10. Android_简单笔记一
  11. POJ 1584 A Round Peg in a Ground Hole
  12. docker镜像文件导入与导出
  13. 打开和创建SqlCe(.sdf文件)
  14. Python内置函数(25)——frozenset
  15. Android中RadioGroup的初始化和简单的使用
  16. RPA简介
  17. 【转】linux清屏的几种方法
  18. python web cgi
  19. 20165231 2017-2018-2 《Java程序设计》第7周学习总结
  20. python之property属性

热门文章

  1. 【TC SRM 718 DIV 2 B】Reconstruct Graph
  2. Mysql学习总结(9)——MySql视图原理讲解与使用大全
  3. Top 22 Free Responsive HTML5 Admin &amp; Dashboard Templates 2018
  4. C++ 递归位置排列算法及其应用
  5. .Net写的比较清晰的接口
  6. ajax如何上传文件(整理)
  7. 51Nod 圆与三角形
  8. HDU 2564 饭卡
  9. 最大子段和 模板题 51Nod 1049
  10. class的写法