错误分为程序的错误和由用户错误的输入引起的错误,此外还有因为各种各样意外的情况导致的错误,比如在磁盘满的时候写入、从网络爬取东西的时候,网络断了。这类错误称为异常
错误处理
普通的错误处理机制就是在出错的时候返回一个错误代码,但是这样十分不方便,一是因为错误码是和正常结果一样的方式返回的,判断起来十分不方便,二是错误还需要一级一级的向上报,直到错误处理程序。
所以高级语言通常都内置了一套 try…except…finally… 的错误处理机制,Python也不例外。
try:
A#如果A中的代码执行过程中出错,就会执行B中的代码
except ZeroDivisionError as e:
B
finally:
C#C中的代码无论是否出错都会正常执行(可以不要这个)<br>。。。
如果错误有不同的类型,可以说使用多个except语句,每个语句处理一个类型的错误
另外,可以在except后面加一个else,如果没有出错,会执行else
Python 的错误其实也是一个类,所有的异常类型都是从BaseException类派生的
except在捕获错误时,不但捕获该类型的错误,而且还会把子类一网打尽
在学习过程中有什么不懂得可以加我的
python学习扣扣qun,784758214
群里有不错的学习视频教程、开发工具与电子书籍。
与你分享python企业当下人才需求及怎么从零基础学习好python,和学习什么内容
try:
foo()
except ValueError as e:
print('ValueError')
except UnicodeError as e:
print('UnicodeError')
#第二个except永远也捕获不到UnicodeError,因为UnicodeError是ValueError的子类,如果有,也被第一个except给捕获了。
使用try…except还有一个巨大的好处,就是可以跨越多层调用,比如函数main()调用foo(),foo()调用bar(),结果bar()出错了,这时,只要main()捕获到了,就可以处理。也就是说