错误处理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和文件。