美图齐众专注资阳网站设计 资阳网站制作 资阳网站建设
资阳网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

人生苦短我用Python[0x02]如何调试Python程序

今天为大家介绍如何调试Python程序。

0. 安装基础包

以Ubuntu 16.04 为例子

sudo apt-get install gdb python2.7-dbg

1. 如何调试python代码

 我们会使用python自带的pdb模块来调试代码,在熟悉pdb功能前,先写一个测试代码 1.py

 
 
 
 
  1. a = 1 
  2. b = 1 
  3. c = a + b 
  4. 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函数来模拟一个被挂起的程序

 
 
 
 
  1. import time 
  2. time.sleep(10000) 

 把程序运行起来 python 2.py 先查看已经运行起来2.py的pid,然后再执行命令

 
 
 
 
  1. gdb python pid 
  2. #查看当前堆栈信息 
  3. py-bt 
  4. #我们可以看到,程序目前挂在time.sleep(10000)这个调用上 

【本文是专栏机构作者“睿江云EflyCloud”的原创文章,转载请联系原作者】

戳这里,看该作者更多好文

【责任编辑:xinxiaoliang TEL:(010)68476606】 


文章标题:人生苦短我用Python[0x02]如何调试Python程序
文章网址:http://www.zsjierui.cn/article/djehhsp.html

其他资讯