今天为大家介绍如何调试Python程序。
0. 安装基础包
以Ubuntu 16.04 为例子
sudo apt-get install gdb python2.7-dbg
1. 如何调试python代码
我们会使用python自带的pdb模块来调试代码,在熟悉pdb功能前,先写一个测试代码 1.py
- a = 1
- b = 1
- c = a + b
- print c
使用pdb模块静态调试python代码,执行pdb 1.py返回如下
输入 h 返回pdb的命令列表,里面包含了所有命令及其简写,比如h是代表help
查看代码内容命令是list,简写是l,其中list命令的参数格式是 list [first, last],默认情况下list会输出文件的前11行代码,比如我们的文件代码只有几行,再list的时候提示EOF文件已经结束了,如果再想看代码的话,可以用list 0来从开头看起。
我们现在要测试断点功能,b 3,代表我要在代码第3行下一个断点,r是代表run把程序跑起来,然后程序会停留在我断点的位置,这个时候我可以用p把a和b的变量值内容打印出来,然后我再n代表next继续运行,然后我再打印c的变量值。
2. 如何已经在运行的python程序
上面讲了如何调试python程序的一些基础知识,接下来我们要介绍的是如何调试一个已经在运行的python程序,比如在实际工作中,写了一个python程序在运行了,然后发现程序有异常或者挂住无法响应业务了,这个时候可以用gdb attach这个进程,然后查看调用栈信息,从而可以获知目前程序挂载那个地方。
先写一个测试代码 2.py,我们用time.sleep函数来模拟一个被挂起的程序
- import time
- time.sleep(10000)
把程序运行起来 python 2.py 先查看已经运行起来2.py的pid,然后再执行命令
- gdb python pid
- #查看当前堆栈信息
- py-bt
- #我们可以看到,程序目前挂在time.sleep(10000)这个调用上
【本文是51CTO专栏机构作者“睿江云EflyCloud”的原创文章,转载请联系原作者】
【责任编辑:xinxiaoliang TEL:(010)68476606】