阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Python代码调试

212次阅读
没有评论

共计 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")

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-05-26发表,共计2148字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中