共计 2148 个字符,预计需要花费 6 分钟才能阅读完成。
一、概述
写好的代码能直接运行的概率非常低,总会在不经意间出现各种各样的 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") |
正文完
星哥玩云-微信公众号
