欢迎关注小睿的微信公众号:郭小睿同学
,每天更新小知识、笔记、案例、学习资源~
什么是异常?
异常即是一个事件,该事件会在程序执行过程中发生,影响了程序的正常执行。
任何语言编写的程序都会存在错误,或“异常”,很容易造成程序的崩溃。
错误分为两种:
- 语法错误
- 过不了python解释器的语法检测,必须在程序执行前就改正。
- 逻辑错误
- 在程序执行中,我们触发了某些异常机制,好比我们下面举得的“除零”的例子。
异常的种类有哪些?
在python中不同的异常可以用不同的类型(python中统一了类与类别,类型即类)取标识,一个异常标识一种错误。
异常类 | 说明 |
---|---|
AttributeError | 试图访问一个对象没有的树形,比如foo.x,但是foo没有属性x |
IOError | 输入/输出异常;基本上是无法打开文件 |
ImportError | 语法错误(的子类) ;代码没有正确对齐 |
IndentationError | 试图访问一个对象没有的树形,比如foo.x,但是foo没有属性x |
IndexError | 下标索引超出序列边界,比如当x只有三个元素,却试图访问x[5] |
KeyError | 试图访问字典里不存在的键 |
KeyboardInterrupt | Ctrl+C被按下 |
NameError | 使用一个还未被赋予对象的变量 |
SyntaxError | Python代码非法,代码不能编译 |
TypeError | 传入对象类型与要求的不符合 |
UnboundLocalError | 试图访问一个还未被设置的局部变量,基本上是由于另有一个同名的全局变量,导致你以为正在访问它 |
ValueError | 传入一个调用者不期望的值,即使值的类型是正确的 |
异常处理的定义及目的
一般情况下,程序员需要编写特定的代码,专门用来捕捉这个异常(这段代码与程序逻辑无关,与异常处理有关)。
如果捕捉成功则进入另外一个处理分支,执行你为其定制的逻辑,使程序不会崩溃,这就是异常处理。
目的:
- 保证程序的健壮性与容错性。
- 使程序代码混乱最小化。
- 捕获并保留诊断信息,通知合适的人员。
- 采用合适的方式结束异常活动。
- 满足用户完美的体验需求。
案例讲解
1、如果错误发生的条件是可预知的,我们需要用if进行处理,在错误发生之前进行预防。
AGE=10
while True:
age=input('>>: ').strip()
if age.isdigit(): #只有在age为字符串形式的整数时,下列代码才不会出错,该条件是可预知的
age=int(age)
if age == AGE:
print('you got it')
break
2、如果错误发生的条件是不可预知的,则需要用到try…except:在错误发生之后进行处理。
def spam(divideBy):
return 42 / divideBy
print(spam(2))
print(spam(0))
我们run这个程序,会出现这个错误。
当一个整数除以零的时候,就会发生ZeroDivisionError
。根据错误信息中给出的行号
,我们可以知道是spam()
中的return语句
导致了这个错误。
我们可以使用try和except
语句来处理这个语句。
把会产生错误的语句放到try里面,如果错误发生,程序就会自动执行到except语句中去。
def spam(divideBy):
try:
return 42 / divideBy
except:
print("Error:Invalid argument.")
print(spam(2))
print(spam(0))
print(spam(4))
偷偷告诉你,我们还可以使用try...finally
语句。
无论是否发生异常都将会执行最后的代码。
s1 = 'hello'
try:
int(s1)
except IndexError as e:
print(e)
except KeyError as e:
print(e)
except ValueError as e:
print(e)
finally:
print('无论异常与否,都会执行该模块,通常是进行清理工作')
什么时候用异常处理?
有的同学会这么想,学完了异常处理后,觉得它很强大,我要为我的程序处处都加上try…except,这样就可以不去思考它会不会有逻辑错误啊,这样就很好啊,多省脑细胞,这样其实并不好,为什么呢?
异常处理本就不是“背锅侠”,只有在错误发生的条件无法预知的情况下,才应该加上try…except~