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格式如下
try: print("逻辑处理代码块") except Exception as e: print("代码块执行错误异常", e) #在测试时,当程序跑完后没有出错,可以用这个显示 else: print("逻辑代码块执行无错误执行此部分") finally: print("无论有无错误都执行的代码块部分")
如上所示, python的异常捕获时调用了Exception类, 这个是一个异常的基类,e为异常的一个对象类似于
e = Exception()
finally 意义:
例:当ftp服务器断开连接后,可以执行清楚缓存数据工作
但是我们知道,这样实例化后的 e 应该是一个对象, 如果执行print(e)应该是一个内存地址才对,比如:
class A(): pass a = A() print(a) 结果: <__main__.A object at 0x00000000031ACE48>
那为什么当我们调用print(e)时返回了一个错误信息呢。
让我们看看下面的例子:
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,看下面例子:
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,这样就能输出我们自定义的错误信息了,是不是方便看了。既然这样,我们可以自定义一个类
自定义异常
看下面的例子:
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)