Python 系列之异常处理
python提供的异常处理
AttributeError 试图访问一个对象没有的树形,比如foo.x,但是foo没有属性x
IOError 输入/输出异常;基本上是无法打开文件
ImportError 无法引入模块或包;基本上是路径问题或名称错误
IndentationError 语法错误(的子类) ;代码没有正确对齐
IndexError 下标索引超出序列边界,比如当x只有三个元素,却试图访问x[5]
KeyError 试图访问字典里不存在的键
KeyboardInterrupt Ctrl+C被按下
NameError 使用一个还未被赋予对象的变量
SyntaxError Python代码非法,代码不能编译(个人认为这是语法错误,写错了)
TypeError 传入对象类型与要求的不符合
UnboundLocalError 试图访问一个还未被设置的局部变量,基本上是由于另有一个同名的全局变量,
导致你以为正在访问它
ValueError 传入一个调用者不期望的值,即使值的类型是正确的
try....except格式如下
[python] view plain copy
- try:
- print("逻辑处理代码块")
- except Exception as e:
- print("代码块执行错误异常", e)
- #在测试时,当程序跑完后没有出错,可以用这个显示
- else:
- print("逻辑代码块执行无错误执行此部分")
- finally:
- print("无论有无错误都执行的代码块部分")
如上所示, python的异常捕获时调用了Exception类, 这个是一个异常的基类,e为异常的一个对象类似于
e = Exception()
finally 意义:
例:当ftp服务器断开连接后,可以执行清楚缓存数据工作
但是我们知道,这样实例化后的 e 应该是一个对象, 如果执行print(e)应该是一个内存地址才对,比如:
[python] view plain copy
- class A():
- pass
- a = A()
- print(a)
- 结果:
- <__main__.A object at 0x00000000031ACE48>
那为什么当我们调用print(e)时返回了一个错误信息呢。
让我们看看下面的例子:
[python] view plain copy
- class A():
- def __init__(self):
- pass
- def __str__(self):
- return "class A str function"
- a = A()
- print(a)
- 结果:
- class A str function
没错,当给类增加一个__str__函数后,当print(a) 就不再是内存地址了,而是自动调用了 __str__函数。所以异常处理时 print(e) 也是调用了 Exception的__str__函数。
assert 《》判断一个条件是否成立。必要的条件不满足,不会往下执行。
明确的告诉别人,这条语句是至关重要的。
raise 异常
我们在使用 try...exception 语句执行代码的过程中,系统出现异常后会将错误信息返回给 变量e,看下面例子:
[python] view plain copy
- a = 1
- b = 2
- try:
- c = a + b
- if c == 4:
- print(c)
- else:
- raise Exception("出错了")
- except Exception as e:
- print(e)
- 结果:
- 出错了
没错,通过raise我们可以将错误信息通过Except类返回给e,这样就能输出我们自定义的错误信息了,是不是方便看了。既然这样,我们可以自定义一个类
自定义异常
看下面的例子:
[python] view plain copy
- class MyException(Exception):
- CODE1 = "10000" # 用户名密码错误
- CODE2 = "10001" # 用户不存在
- def __init__(self, error_msg):
- self._msg = error_msg
- def __str__(self):
- if self._msg == "10000":
- return "用户名密码错误"
- if self._msg == "10001":
- return "用户不存在"
- if __name__ == "__main__":
- user = input("用户名:")
- pwd = input("密码:")
- try:
- if user == "peter":
- if pwd == "12345":
- print("登录成功")
- else:
- raise MyException("10000")
- else:
- raise MyException("10001")
- except MyException as e:
- print(e)