异常

异常

  • 广义上的错误分为错误和异常
  • 错误指的是可以人为避免
  • 异常是指,在语法和逻辑正确的前提下,出现的问题
  • 在python里,异常是一个类,可以处理和使用

异常的分类

AssertError                   断言语句(assert)失败
AttributeError                 尝试访问未知的对象属性
EOFError                     用户输入文件末尾标志EOF(ctrl+d)
FloatingPointError               浮点计算错误
GeneratorExit                  generator.close()方法调用的时候
ImportError                   导入模块失败的时候
IndexError                    索引超出序列的范围
KeyError                     字典中查找一个不存在的关键字
KeyboardInterrupt               用户输入中断键(Ctrl+c)
MemoryError                   内存溢出(可以通过删除对象释放内存)
NameError                     尝试访问一个不存在的变量
NotImplementedError              尚未实现的方法
OSError                      操作系统产生的异常(例如打开一个不存在的文件)
OverflowError                  数值运算超出最大限制
ReferenceError                 弱引用(weak reference)试图访问一个已经被垃圾回收机制回收了的对象
RuntimeError                  一般的运行时错误
StopIteration                 迭代器没有更多的值
SyntaxError                   python的语法错误
IndentationError               缩进错误
TabError                     Tab和空格混合使用
SystemError                   Python编译器系统错误
SystemExit                    python编译器进程被关闭
TypeError                    不同类型间的无效操作
UnboundLocalError               访问一个未初始化的本地变量(NameError的子类)
UnicodeError                  Unicode相关的错误(ValueError的子类)
UnicodeEncodeError              Unicode编码时的错误(UnicodeError的子类)
UnicodeDecodeError              Unicode解码时的错误(UnicodeError的子类)
UnicodeTranslateError            Unicode转换的错误(UnicodeError的子类)
ValueError                   传入无效的参数
ZeroDivisionError               除数为零
l = [1,2,3,4,5]
print(100/0)
---------------------------------------------------------------------------

ZeroDivisionError                         Traceback (most recent call last)

<ipython-input-2-869d1a983e23> in <module>
      1 l = [1,2,3,4,5]
----> 2 print(100/0)
ZeroDivisionError: division by zero

异常处理

  • 不能保证程序永远正确运行

  • 但是,必须保证程序在最坏的情况下得到的问题被妥善处理

  • python的异常处理模块全部语法为:

    try: 
        尝试实现某个操作,
        如果没有出现异常,任务就可以完成
        如果出现异常,将异常从当前代码块扔出去尝试解决异常
        
    except 异常类型1:
        解决方案1:用于尝试在此处处理异常解决问题
        
    except 异常类型2:
        解决方案2:用于尝试在此处处理异常解决问题
        
    except (异常类型1,异常类型2...)
        解决方案:针对多个异常使用相同的处理方式
        
    except:
        解决方案:索引异常的解决方案
        
    else:
        如果没有出现任何异常,将会执行此处代码
        
    finally:
        管你有没有异常都要执行的代码
    
  • 流程

    1. 执行try下面的语句
    2. 如果出现异常,则在except语句里查找对应异常并进行处理
    3. 如果没有出现异常,则执行else语句内容
    4. 最后,不管是否出现异常,都要执行finally语句
  • 除except(最少一个)以外,else喝finally可选

# 简单异常案例
try:
    num = int(input("plz input your number:"))
    rst = 100/num
    print("计算结果是:{0}".format(rst))
except:
    print("出错了,搞毛线")
    # exit是退出程序的意思
    exit()
    
plz input your number:0
出错了,搞毛线
# 简单异常案例
# 给出提示信息
try:
    num = int(input("plz input your number:"))
    rst = 100/num
    print("计算结果是:{0}".format(rst))
# 捕获异常后,把异常实例化,出错信息会在实例化里
# 注意以下写法
# 以下语句是捕获ZeroDivisionError异常并实例化实例
except ZeroDivisionError as e:
    print("出现异常了,捕获它")
    print(e)
    # exit是退出程序的意思
    exit()

# 问题:为什么我们可以直接打印出实例e,此时的实例e应该实现了那个函数
plz input your number:0
出现异常了,捕获它
division by zero

# 简单异常案例
# 给出提示信息
try:
    num = int(input("plz input your number:"))
    rst = 100/num
    pritn("计算结果是:{0}".format(rst))
# 如果十多种error的情况
# 需要把越具体的错误,越往前放
# 在异常类继承关系中,越是子类的异常,越要往前放
# 越是父类的异常,越要往后放


# 在处理异常的时候,一旦拦截到某一个异常,则不再继续往下查看,
# 直接进行下一个代码,即有finally则执行finally语句块,否则就执行下一个大的语句


except ZeroDivisionError as e:
    print("出现异常了,捕获它")
    print(e)
    # exit是退出程序的意思
    exit()
except NameError as e:
    print("名字写错了")
    print(e)
    exit()
except AttributeError as e:
    print("属性有问题")
    print(e)
    exit()
    
# 所有异常都是继承自Exception
# 如果写上下面这句话,任何一场都会拦截住
# 而且,下面这句话一旦是最后一个exception
except Exception as e:
    print("出了什么错?")
    print(e)

except ValueError as e:
    print("NO.......................")
    
print("hahahaha")

plz input your number:hahs
出了什么错?
invalid literal for int() with base 10: 'hahs'
hahahaha

用户手动引发异常

  • 当某些情况,用户希望自己引发一个异常的时候,可以使用
  • raise 关键字来引发异常
# raise案例-1
try:
    print("你xxx")
    print(3.1415926)
    # 手动引发一个异常
    # 注意语法:raise ErrorClassName
    raise ValueError
    print("Π死了")
except NameError as e:
    print("NameError")
except ValueError as e:
    print("ValuuError")
except Exception as e:
    print("有异常")
finally:
    print("我肯定会被执行的")

你xxx
3.1415926
ValuuError
我肯定会被执行的

# raise案例-1
# 自定义异常
# 需要注意:自定义异常必须是系统异常的子类
class YueError(ValueError):
    pass

try:
    print("你xxx")
    print(3.1415926)
    # 手动引发一个异常
    # 注意语法:raise ErrorClassName
    raise YueError
    print("Π死了")
except NameError as e:
    print("NameError")
except YueError as e:
    print("YueError")
except ValueError as e:
    print("ValuuError")
except Exception as e:
    print("有异常")
finally:
    print("我肯定会被执行的")

你xxx
3.1415926
YueError
我肯定会被执行的

# else语句案例
try:
    num = int(input("plz input your number:"))
    rst = 100/num
    print("计算结果是:{0}".format(rst))
except Exception as e:
    print("Exception")
else:
    print("No Exception")
finally:
    print("反正我会被执行")

plz input your number:19
计算结果是:5.2631578947368425
No Exception
反正我会被执行

关于自定义异常

  • 只要是raise异常,则推荐自定义异常
  • 在自定义异常的时候,一般包含以下内容:
    • 自定义发生异常的异常代码
    • 自定义发生异常后的问题提示
    • 自定义发生异常的行数
  • 最终的目的是,一旦发生异常,方便程序员快速定位错误现场
prin("sdfsfsf")

---------------------------------------------------------------------------

NameError                                 Traceback (most recent call last)

<ipython-input-7-18fced7d78ac> in <module>
----> 1 prin("sdfsfsf")

NameError: name 'prin' is not defined

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值