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
  1. try:  
  2.     print("逻辑处理代码块")  
  3.   
  4. except Exception as e:  
  5.     print("代码块执行错误异常", e)  
  6.     #在测试时,当程序跑完后没有出错,可以用这个显示
  7. else:  
  8.     print("逻辑代码块执行无错误执行此部分")  
  9.   
  10. finally:  
  11.     print("无论有无错误都执行的代码块部分")  

如上所示, python的异常捕获时调用了Exception类, 这个是一个异常的基类,e为异常的一个对象类似于

e = Exception()

finally 意义:

例:当ftp服务器断开连接后,可以执行清楚缓存数据工作

但是我们知道,这样实例化后的 e 应该是一个对象, 如果执行print(e)应该是一个内存地址才对,比如:

[python]  view plain  copy
  1. class A():  
  2.     pass  
  3.   
  4. a = A()  
  5. print(a)  
  6. 结果:  
  7. <__main__.A object at 0x00000000031ACE48>  

那为什么当我们调用print(e)时返回了一个错误信息呢。

让我们看看下面的例子:

[python]  view plain  copy
  1. class A():  
  2.     def __init__(self):  
  3.         pass  
  4.   
  5.     def __str__(self):  
  6.         return "class A str function"  
  7.   
  8. a = A()  
  9. print(a)  
  10.   
  11. 结果:  
  12. class A str function  

没错,当给类增加一个__str__函数后,当print(a) 就不再是内存地址了,而是自动调用了 __str__函数。所以异常处理时 print(e) 也是调用了 Exception的__str__函数。


assert  《》判断一个条件是否成立。必要的条件不满足,不会往下执行。

明确的告诉别人,这条语句是至关重要的。

raise 异常

我们在使用 try...exception 语句执行代码的过程中,系统出现异常后会将错误信息返回给 变量e,看下面例子:

[python]  view plain  copy
  1. a = 1  
  2. b = 2  
  3. try:  
  4.     c = a + b  
  5.     if c == 4:  
  6.         print(c)  
  7.     else:  
  8.         raise Exception("出错了")  
  9. except Exception as e:  
  10.     print(e)  
  11. 结果:  
  12. 出错了  

没错,通过raise我们可以将错误信息通过Except类返回给e,这样就能输出我们自定义的错误信息了,是不是方便看了。既然这样,我们可以自定义一个类


自定义异常

看下面的例子:

[python]  view plain  copy
  1. class MyException(Exception):  
  2.     CODE1 = "10000"  # 用户名密码错误  
  3.     CODE2 = "10001"  # 用户不存在  
  4.   
  5.     def __init__(self, error_msg):  
  6.         self._msg = error_msg  
  7.   
  8.     def __str__(self):  
  9.         if self._msg == "10000":  
  10.             return "用户名密码错误"  
  11.         if self._msg == "10001":  
  12.             return "用户不存在"  
  13.   
  14. if __name__ == "__main__":  
  15.     user = input("用户名:")  
  16.     pwd = input("密码:")  
  17.     try:  
  18.         if user == "peter":  
  19.             if pwd == "12345":  
  20.                 print("登录成功")  
  21.             else:  
  22.                 raise MyException("10000")  
  23.         else:  
  24.             raise MyException("10001")  
  25.     except MyException as e:  
  26.         print(e)                                                                                                                          
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值