文章内容为原创,欢迎转载请注明出处
作者: EflyPro->晦明禅师
文章来源:公众号“睿江云计算”
今天我们要为大家介绍的是,如何调试python程序
0.安装基础包
我们以Ubuntu 16.04 为例子
sudo apt-get install gdb python2.7-dbg1.如何调试python代码
我们会使用python自带的pdb模块来调试代码,在熟悉pdb功能前,先写一个测试代码 1.py
a = 1b = 1c = a + bprint 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)这个调用上
下期预告
下期的【人生苦短,我用python】系列,将为大家介绍如何使用python的commands模块调用linux shell命令,同时附上一个实际例子给大家参考。敬请期待!