组团学

Python代码调试

阅读 (178936)

一、概述

写好的代码能直接运行的概率非常低,总会在不经意间出现各种各样的BUG,有的BUG很简单,看看错误提示就能修改好。但是有的BUG很复杂,需要一些调试的手段来发现并解决错误

二、print

print是最简单最原始的调试方式

def func(x): print("-----------1") print(x) ret = 10 / x print("-----------2") return ret func(0)

缺点:将来得删除调试的print,运行结果也会包含一些垃圾信息

三、断言

  • 使用

    凡是用print来辅助调试的地方,都可以缓存断言(assert)语句

  • 逻辑

    当程序执行到assert语句时,首先计算第一个表达式的值,如果值为真则继续向下运行。否则断言失败,assert语句会抛出AssertionError异常,异常的信息为第二个表达式的值

  • 缺点

    如果将所有的print换成assert也好不到哪里去

  • 优点

    在启动程序时可以通过命令参数关闭assert

  • 代码

    def func(x): assert x != 0, "x is zero" ret = 10 / x return ret func(0)

四、logging

使用:把所有的print替换成logging也是可以的,和assert相比logging不会抛出异常,把错误输入到文件

import logging #配置输出级别 logging.basicConfig(level=logging.ERROR) ''' CRITICAL = 50 FATAL = CRITICAL ERROR = 40 WARNING = 30 WARN = WARNING INFO = 20 DEBUG = 10 NOTSET = 0 ''' def func(x): logging.error("x = %d"%(x)) ret = 10 / x return ret func(0)

五、pdb

  • 使用

    python的调试器,让程序以单步方式一句一句的运行,可以随时查看运行的状态

  • 以pdb方式调试代码

    需要使用黑屏终端: python -m pdb 文件名称

  • 调试命令

    n:单步执行代码

    p: 变量名

    q:退出调试

  • 基本使用

    a = 1 print("-------------------------0") b = a + 1 print("-------------------------1") print("-------------------------2") c = 2 print("-------------------------3") print("-------------------------4") print("-------------------------5") d = 0 print("-------------------------6") c / d print("-------------------------7") print("-------------------------8") f = 10 print("-------------------------9")

    缺点:麻烦,如果有100000代码,认为错误可能出现在第9000左右,需要运行到9000行才行

  • 自定义开始断点

    import pdb a = 1 print("-------------------------0") b = a + 1 print("-------------------------1") print("-------------------------2") c = 2 print("-------------------------3") print("-------------------------4") print("-------------------------5") d = 0 #自定义断点 pdb.set_trace() print("-------------------------6") c / d print("-------------------------7") print("-------------------------8") f = 10 print("-------------------------9")

六、IDE断点

def func(): print("**********1") print("**********2") print("**********3") print("**********4") a = 1 print("-------------------------0") b = a + 1 print("-------------------------1") print("-------------------------2") c = 2 print("-------------------------3") print("-------------------------4") func() print("-------------------------5") d = 0 print("-------------------------6") c / d print("-------------------------7") print("-------------------------8") f = 10 print("-------------------------9")
需要 登录 才可以提问哦