文章内容为原创,欢迎转载请注明出处

作者: EflyPro->晦明禅师

文章来源:公众号“睿江云计算

     今天我们要为大家介绍的是,如何调试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的变量值。

640?wx_fmt=jpeg&tp=webp&wxfrom=5&wx_lazy=1

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)这个调用上

640?wx_fmt=jpeg&tp=webp&wxfrom=5&wx_lazy=1

下期预告

下期的【人生苦短,我用python】系列,将为大家介绍如何使用python的commands模块调用linux shell命令,同时附上一个实际例子给大家参考。敬请期待!