【Python】错误、调试和测试

错误处理try...except...

有时候我们写程序的时候,会出现一些错误或异常,导致程序终止。使用try…except,这样程序就不会因为异常而中断。把可能发生错误的语句放在try模块里,用except来处理异常。

  • except可以处理一个专门的异常,也可以处理一组圆括号中的异常
  • 如果except后没有指定异常,则默认处理所有的异常
  • 每一个try,都必须至少有一个except
# r = 10/0,可能会报错,所以放在try语句后面
try:
    r = 10/0
# 如果触发异常,则处理异常;不触发就跳过
except Exception as e:
    print(e)
    r = 10/1
    print(r)
# 无论是否触发异常,退出try语句时都会执行finally后的语句
finally:
    print(r)
	
'''
division by zero
10.0
10.0
'''

如果没有错误发生,可以在except语句块后面加一个else,当没有错误发生时,会自动执行else语句:

try:
     assert 2*2 == 4
except Exception as e:
    print(e)
else:
    print('no error!')
finally:
    print('finally..')

'''
no error!
finally..
'''

记录错误:如果不捕获错误,自然可以让Python解释器来打印出错误堆栈,但程序也被结束了。既然我们能捕获错误,就可以把错误堆栈打印出来,然后分析错误原因,同时,让程序继续执行下去。

Python内置的logging模块可以非常容易地记录错误信息:

import logging

def main():
    try:
        r = 10/0
        print(r)
    except Exception as e:
        logging.exception(e)

main()
print('END')

'''
logging把错误记录下来以后,继续执行后面的语句
ERROR:root:division by zero
Traceback (most recent call last):
  File "D:/PycharmData/apiautotest/data/apilabel/1.py", line 12, in main
    r = 10/0
ZeroDivisionError: division by zero
END
'''

抛出错误raise:捕获到异常以后,raise会将错误原样抛出,后面的代码将不会被执行

断言assert

assert的意思是,表达式n != 0应该是True,否则,根据程序运行的逻辑,后面的代码肯定会出错。

如果断言失败,assert语句本身就会抛出AssertionError

assert 1 == 2

'''
Traceback (most recent call last):
  File "D:/PycharmData/apiautotest/data/apilabel/1.py", line 1, in <module>
    assert 1 == 2
AssertionError
'''

logging

logging不会抛出错误,而且可以输出到文件

import logging
logging.basicConfig(level=logging.INFO)

s = '0'
n = int(s)
logging.info('n = %d' % n)
print(10 / n)

'''
INFO:root:n = 0
Traceback (most recent call last):
  File "D:/PycharmData/apiautotest/data/apilabel/1.py", line 7, in <module>
    print(10 / n)
ZeroDivisionError: division by zero
'''

logging允许指定记录信息的级别,有debug,info,warning,error等几个级别,当我们指定level=INFO时,logging.debug就不起作用了。同理,指定level=WARNING后,debug和info就不起作用了。

logging的另一个好处是通过简单的配置,一条语句可以同时输出到不同的地方,比如console和文件。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值