免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1878 | 回复: 0
打印 上一主题 下一主题

python 调试相关 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-08-26 20:13 |只看该作者 |倒序浏览

python 调试相关

  Normal
  0
  
  7.8 磅
  0
  2
  
  false
  false
  false
  
   
   
   
   
   
   
   
   
   
   
   
   
  
  MicrosoftInternetExplorer4



st1\:*{behavior:url(#ieooui) }
/* Style Definitions */
table.MsoNormalTable
        {mso-style-name:普通表格;
        mso-tstyle-rowband-size:0;
        mso-tstyle-colband-size:0;
        mso-style-noshow:yes;
        mso-style-parent:"";
        mso-padding-alt:0cm 5.4pt 0cm 5.4pt;
        mso-para-margin:0cm;
        mso-para-margin-bottom:.0001pt;
        mso-pagination:widow-orphan;
        font-size:10.0pt;
        font-family:"Times New Roman";
        mso-fareast-font-family:"Times New Roman";
        mso-ansi-language:#0400;
        mso-fareast-language:#0400;
        mso-bidi-language:#0400;}
File information
2009-8-26
磁针石:xurongzhong#gmail.com
博客:
oychw.cublog.cn
据说是用Eclipse的pydev插件可以方便调测。
以下原文转自:http://hi.baidu.com/%B7%C7%D6%F7%C1%F7%B5%B3%D4%B1/blog/item/9a0a64db0878e7d3b7fd48ef.html
使用pdb调试Python程序
来源:暂无
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
本文讨论在没有方便的IDE工具可用的情况下,使用pdb调试python程序

源码例子
例如,有模拟税收计算的程序:

#!/usr/bin/python
def debug_demo(val):
                 if val

debug_demo函数计算4500的入账所需的税收。

如何调试?

1.加入断点

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

#!/usr/bin/python
[color="#0000ff"]_DEBUG=True
def debug_demo(val):
                 if _DEBUG == True:
                                 import pdb
                                 pdb.set_trace()
                 if val


2.开始运行调试

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

> /usr/local/qspace/user_network/debug_demo.py(7)debug_demo()
-> if val
-> val
  
  查看代码上下文,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      8                                          print "level 1"
     9                                          print 0
10                          elif val

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

  监视变量:p 变量名

(Pdb) p val
4500
(Pdb)   

单步执行: n

-> elif val                   elif val

加入断点:b 行号

(Pdb) b 14

运行到断点: c

(Pdb) c
> /*****
-> print "level 3"
(Pdb) l
     9                                          print 0
10                          elif val                                   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 命令。就可以得到命令的详细帮助。
  不过,我个人认为一般无需启动这种调试方法,一般使用日志输出进行调试即可,除非遇到了非常微妙的错误。这时,单步调试的威力便显示出来了。




本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/21908/showart_2037960.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP