python 是面向对象的语言,所以程序抛出的异常也是类。
常见的异常类
1.nameerror:尝试访问一个没有申明的变量
2.zeropisionerror:除数为 0
3.syntaxerror:语法错误
4.indexerror:索引超出序列范围
5.keyerror:请求一个不存在的字典关键字
6.ioerror:输入输出错误(比如你要读的文件不存在)
7.attributeerror:尝试访问未知的对象属性
8.typeerror:传给函数的参数类型不正确,比如给 int 函数传入字符型
自定义异常类
尽管内建的异常类已经包括大部分情况,但如果需要创建自己的异常类,可以采用下面的方法:
代码如下:
class customexception(exception): # exception 为所有异常的基类
# 处理异常的代码
捕获异常
代码如下:
try:
# 需要进行捕获异常的代码,只有出现异常之前的代码被最终执行
except (exception1,exception2,…) as argument:
# 捕获到 (exception1,exception2,…) 里的异常才执行本段代码
# argument 是一个异常类的实例,包含异常的具体信息
except:
# 捕获到 (exception1,exception2,…) 以外的异常执行本段代码,用 sys 模块的 exc_info() 函数可以获取异常信息
else:
# 如果没有捕获到异常则执行本段代码
finally:
# 无论是否捕获到异常都执行本段代码
上述语句并不都是必须的,譬如 try…except…、try…finally… 或者 try…except…else… 语句都是可行的。我们还可以 用 try…except…else… 代替 if…else…。
抛出异常
如果我们想要在自己编写的程序中主动抛出异常,可以采用如下两种方法:
raise exception(reason)
exception 必须是一个异常类的名称。可选项 reason 用来传递异常的信息。
assert expression[,reason]
assert 是断言的关键字。当表达式 expression 为真则什么都不做,否则抛出 assertionerror 异常。reason 提供异常的信息。
上下文管理器
由于对象 file 支持上下文管理协议,因此可以采用下面的方法打开文件:
代码如下:
with open(‘filename’) as fp:
# 无论本段代码是否出现异常,文件对象 fp 均能正确关闭
example
代码如下:
import sys
def p(num, den):
print(‘_________________ (‘,num,’,’,den,’)\n’)
try:
ans = num/den
assert den != num, ‘equal’ # 断言:分子分母不相等
den = ‘changed’ # 如果执行本语句之前未出现异常,改变 den 的值
if num % 2: # 如果分子为奇数,则抛出异常
raise valueerror(‘odd’)
except zeropisionerror as e:
print(‘except … as …\n\t’, e)
except:
print(‘except\n\t’, sys.exc_info())
else:
print(‘else\n\t’, ans)
finally:
print(‘finally\n\t’, den)
p(1,0) # 除数为零,为 zeropisionerror 异常类
p(1,1) # 分子等于分母,断言为假,抛出异常
p(2,1) # 无异常
p(3,1) # 分子为奇数,通过 raise 抛出异常
p(3,’x’) # 不属于 zeropisionerror 的其他异常
运行结果:
代码如下:
_________________ ( 1 , 0 )
except … as …
pision by zero
finally
0
_________________ ( 1 , 1 )
except
(, assertionerror(‘equal’,), )
finally
1
_________________ ( 2 , 1 )
else
2.0
finally
changed
_________________ ( 3 , 1 )
except
(, valueerror(‘odd’,), )
finally
changed
_________________ ( 3 , x )
except
(, typeerror(“unsupported operand type(s) for /: ‘int’ and ‘str'”,), )
finally
x