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")
需要
登录
才可以提问哦
: