python调试总结

By | 12月30日
Advertisement

调试通常采用两种方式,打印日志调试以及运行时实时跟踪调试。

一.打印日志:

1. print
不要看不起print,这是一切调试的起点,即便是调试Java或者C这种巨麻烦的编译语言,print仍然是常用工具。当然,我们讲的是Python,是比Java和C要方便100倍的动态解释语言,因此这个print就更有力了。至于语法如何,不用我讲了吧。

2.logging
logging是一个远比print更强大的调试工具。Python的logging模块非常强大,任何一个严肃的Py开发人员都应该学会使用这个模块。建议大家从Python的文档入手,学习这个模块。这里我就不多讲了。

二.实时跟踪调试

1.IDE跟踪调试

推荐使用pycharm等IDE,进行debug。查看变量,设置断点。

2.pdb

pdb可以实时跟踪调试,设置断点,查看变量等等,如果需要进入代码中去跟踪错误原因,而此时又没有可用的IDE,或者图形化界面,推荐采用该方法。

pdb的调试指令参考:http://www.cnblogs.com/qi09/archive/2012/02/10/2344959.html

1).加入断点

在需要插入断点的地方,加入红色部分代码:如果_DEBUG值为True,则在该处开始调试(加入_DEBUG的原因是为了方便打开/关闭调试)。

#!/usr/bin/python
_DEBUG=True
def debug_demo(val):
if _DEBUG == True:
import pdb
pdb.set_trace()
if val <= 1600 :
print "level 1"
print 0
elif val <= 3500 :
print "level 2"
print (val - 1600) * 0.05
elif val <= 6500 :
print "level 3"
print (val - 3500) * 0.10 + (3500-1600) * 0.05
else:
print "level 4"
print (val - 6500) * 0.20 + (6500-3500) * 0.10 + (3500-1600) * 0.05
#~def debug_demo
if __name__ == "__main__":
debug_demo(4500)

2).开始运行调试

运行程序./debug_demo.py,得到

> /usr/local/qspace/user_network/debug_demo.py(7)debug_demo()
-> if val <= 1600 :
(Pdb)

-> val <= 1600 : 指示当前执行的语句,(Pdb)等待你的调试指令. pdb的指令很丰富,输入h指令可以查看指令的使用方法。下面简单介绍常用指令:

查看代码上下文,l(小写L)

(Pdb) l
2 _DEBUG=True
3 def debug_demo(val):
4 if _DEBUG == True:
5 import pdb
6 pdb.set_trace()
7 -> if val <= 1600 :
8 print "level 1"
9 print 0
10 elif val <= 3500 :
11 print "level 2"
12 print (val - 1600) * 0.05
(Pdb)

左边是行号,右边是代码正文。

监视变量:p 变量名

(Pdb) p val
4500
(Pdb)

单步执行: n

-> elif val <= 3500 :
(Pdb) l
5 import pdb
6 pdb.set_trace()
7 if val <= 1600 :
8 print "level 1"
9 print 0
10 -> elif val <= 3500 :
11 print "level 2"
12 print (val - 1600) * 0.05
13 elif val <= 6500 :
14 print "level 3"
15 print (val - 3500) * 0.10 + (3500-1600) * 0.05

加入断点:b 行号

(Pdb) b 14

(Pdb) b 查看所有断点编号

(Pdb) clear 1 删除断点编号为1的断点

运行到断点: c

(Pdb) c
> /*****
-> print "level 3"
(Pdb) l
9 print 0
10 elif val <= 3500 :
11 print "level 2"
12 print (val - 1600) * 0.05
13 elif val <= 6500 :
14 B-> print "level 3"
15 print (val - 3500) * 0.10 + (3500-1600) * 0.05
16 else:
17 print "level 4"
18 print (val - 6500) * 0.20 + (6500-3500) * 0.10 + (3500-1600) * 0.05
19

执行到函数返回前: r

(Pdb) r
level 3
195.0
--Return--
> /****()

->None
-> print (val - 3500) * 0.10 + (3500-1600) * 0.05
(Pdb)

说明:

pdb还有很多其他很多有用的指令,读者可以自行探索。输入h,h 命令。就可以得到命令的详细帮助。

不过,我个人认为一般无需启动这种调试方法,一般使用日志输出进行调试即可,除非遇到了非常微妙的错误。这时,单步调试的威力便显示出来了

Similar Posts:

  • Python的学习(二十九)---- linux下python调试

    之前一直在window下写python脚本,习惯用eclipse调试编辑,突然换到在linux环境下,有点不适应... python有自带的pdb库,可以实现简单的调试功能,基本命令与gdb类似,不过功能不会有gdb那么强大,pdb主要支持多断点设置(可条件设置),代码级单步调试,查看堆栈信息,代码查看,post-mortem调试, 详细信息可以查看: http://docs.python.org/2/library/pdb.html 用pdb调试有多种方式可选: 1. 命令行启动目标程序,加上

  • 使用winpdb进行python调试

    winpdb类似于pdb调适工具,他们最大的不同是winpdb提供了一个图形化的调试界面. 安装方法: windows下: 1)首先安装wxpython, install the wxPython runtime ,可以找一个exe格式的直接安装. 2)安装winpdb, Winpdb source package,下载源码,然后运行python setup.py install ,ok! winpdb的教程: http://winpdb.org/tutorial/WinpdbTutorial.

  • python调试方法

    下载Eric:http://sourceforge.net/projects/eric-ide/files/eric4/stable/4.5.20/ 解压之后,在命令窗口中输入如下命令: 然后在python34目录里面找到eric4.bat,双击运行,然后就可以加入py文件进行调试了.

  • 使用pudb调试python

    本博客主要用于讲解如何使用pudb进行python调试: 1.安装 sudo pip install pudb pip list查看安装结果: 2.使用 测试程序: #!/usr/bin/env python # -*- coding: utf-8 -*- from pudb import set_trace set_trace() def min(a,b): minValue = 0 if(a >= b): minValue = b else: minValue = a return minV

  • python 安装调试 wxpython+ulipad

    python 调试 wxpython+ulipad python开发很便捷,但是调试起来却很费解. 我用的是稳定版的python2.7 1.IDE是UliPad4.0,UliPad已包含了python调试工具winpdb 2.安装好以后里面可以看到debug的按钮,甲壳虫一样的.很显眼的. 3.Ulipad需要设置环境变量,"我的电脑-右键属性-高级-环境变量" 另外Python安装后也需要设置变量. 常见问题: 1.在win下经常会找不到python解释器, 打开Ulipad,点击&

  • NotePad++ 中用NppExec配置Python 运行调试环境

    在NotePad++ 中设定Python调试环境可以使用NppExec插件. 这个插件提供了输出捕获.错误信息高亮.错误定位等等功能,十分强大,下面就来说说具体的设定方法: 首先,我们需要下载NppExec的插件: 1.1. 可以到下面的这个地址 http://sourceforge.net/projects/npp-plugins/files/NppExec/ 比如我这里选择了 NppExec ver. 0.4.2.1 Unicode for Notepad++ ver. 5.1+. 1.2.

  • Python开发环境Wing IDE使用技巧之Blender的Python代码调试

    Wing IDE是一个集成开发环境,可用于开发.测试和调试为Blender编写的Python代码,Blender是一个开源的3 D内容创建系统.Wing IDE提供自动完成.调用提示.强大的调试器.以及许多其他功能,可帮助用户编写.浏览和理解Python代码. Wing IDE官方最新版免费下载地址 Blender的Python脚本加载的方式,使他们难以在Python调试器中进行调试.下面的存根文件可以用来解决这些问题: import os import sys # MODIFY THESE:

  • Python、Lua和 Ruby之优劣

    Python Python的优点: 1.Python比其它语言有更多扩展模块. 2.在网上可以找到很多Python教程.不仅如此,还有大量的英文书籍和资料.Python.org有很多为初学者准备的依主题组织的资料.教程和编程指南,此外还有很多链接和参考. 3.很多人都喜欢Python语言的语法,因为它清晰易读. 4.Python在支持库上大占优势,因为它有很多库,而且大部分都有完善的文档支持. 5.很多工具可以用于Python,但难以找到适用于Lua和Ruby的. Python的不足: 1.现有

  • Python程序员必知必会的开发者工具

    对于开发者来说,最实用的帮助莫过于帮助他们编写代码文档了.pydoc模块可以根据源代码中的docstrings为任何可导入模块生成格式良好的文档.Python包含了两个测试框架来自动测试代码以及验证代码的正确性:1)doctest模块,该模块可以从源代码或独立文件的例子中抽取出测试用例.2)unittest模块,该模块是一个全功能的自动化测试框架,该框架提供了对测试准备(test fixtures), 预定义测试集(predefined test suite)以及测试发现(test discov

  • 八个最佳Python IDE

    八个最佳Python IDE 作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs Python是一种功能强大.语言简洁的编程语言.本文向大家推荐8个适合Python开发的IDE. 1. Eclipse with PyDev http://pydev.org/ Eclipse+PyDev插件,很适合开发Python Web应用,其特征包括自动代码完成.语法高亮.代码分析.调试器.以及内置的交互浏览器. 2. Komodo Edit http://komod

Tags: