在python中,如果异常并未被处理或捕捉_抛出异常是什么意思

在python中,如果异常并未被处理或捕捉_抛出异常是什么意思一文掌握Pyhton的异常捕获和抛出,包括Python内置异常类型、自定义异常类等。

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

异常信息


在这里插入图片描述
Python使用异常类来管理异常信息。当发生异常的时候,程序会抛出一个异常信息,自动根据代码的层次查找异常处理信息。当代码发生异常而没有指定处理异常的方法是,Traceback会打印发生异常时代码执行栈的情况。

Traceback由三部分组成:

  • 信息头
    提醒使用者这是Traceback信息。
  • 出错位置
    显示出错位置,显示顺序和异常信息对象传播方向是相反的。
  • 异常信息
    显示异常类型,具体的异常信息。

在这里插入图片描述

捕获异常


语法
try:
    statements1
except ExceptionType:
    statements2

先运行statements1,若没有异常则不会运行statements2
在这里插入图片描述

否则把异常类型和ExceptionType比较,一致就执行statements2
在这里插入图片描述
捕获异常不一定要在异常发生的地方捕获,在异常对象传播的路径上捕获都可以。
在这里插入图片描述
捕获异常的信息参数:
try:
    statements1
except (ExceptionType) as Argument:
    statements2
在这里插入图片描述

多重异常处理


在这里插入图片描述

上面只是一种异常的情况,对于多重异常,总结了3种方法。

  1. 多次except
    在这里插入图片描述

  2. except后带括号
    在这里插入图片描述

  3. except后什么也不带
    在这里插入图片描述

else
try:
    statements1
except ExceptionType:
    statements2
else:
    statements3

else语句的作用是如果statements1没有发生异常才会执行statements3
在这里插入图片描述
在这里插入图片描述

finally
try:
    statements1
except ExceptionType:
    statements2
finally:
    statements3

finally语句的作用是无论是否发生异常,都会执行statements3
在这里插入图片描述
在这里插入图片描述

插播反爬信息 )博主CSDN地址:https://wzlodq.blog.csdn.net/

当然了,else和finally可以一起用。
在这里插入图片描述
在这里插入图片描述

抛出异常


在这里插入图片描述

除了代码错误自动抛出异常外,在Python中可以使用raise语句来主动抛出异常。
语法
raise_stmt ::= "raise" [expression ["," expression ["," expression]]]
raise语句后面可以接1~3个表达式,第一个第二个分别表示类型和值,第三个不填写,填写的话必须是一个traceback对象。

3种常用写法

  1. raise后接实例化对象
    在这里插入图片描述
  2. raise后接异常类名
    在这里插入图片描述
  3. raise后接异常类和类的初始化参数
    在这里插入图片描述

内置异常类型


前面提到的好几种异常类型,实际上都是Python内置的异常类型。
所有的异常都是继承BaseException,常用的内部异常都继承Exception。
如下所示,+表示该类是上一层的子类,|用来对齐,比较常见的用注释标明了。

BaseException
 + SystemExit
 + KeyboardInerrrput
 + Exception
 |  + GeneratonrExit
 |  + StopIterration
 |  + StandardError
 |  |  + ArithmeticError
 |  |  |  + FloatingPointError
 |  |  |  + OverflowError
 |  |  |  + ZeroDivisonErroe  # 被除数为0
 |  |  + AssertionError
 |  |  + AttributeError  # 访问对象不存在的属性
 |  |  + EnvironmentError
 |  |  |  + IOError  # 写不存在的文件或其他IO错误
 |  |  |  + OSError
 |  |  |  |  + WindowsError(Windows)
 |  |  |  |  + VMSError(VMS)
 |  |  + EOFError
 |  |  + ImportError
 |  |  + LookupError
 |  |  |  + IndexError  # 访问不存在的列表元素
 |  |  |  + KeyError  # 访问字典不存在的Key
 |  |  + MemoryError
 |  |  + NameError  # 访问不存在的变量名称
 |  |  |  + UnboundLocalError
 |  |  + ReferenceError
 |  |  + RuntimeError
 |  |  |  + NotImplementedError
 |  |  + SyntaxError
 |  |  |  + IndentationError
 |  |  |  |  + TableError
 |  |  + SystemError
 |  |  + TypeError  # 类型使用了不支持的操作
 |  |  + ValueError
 |  |  + UnicodeError
 |  |  |  |  + UnicodeDecodeError
 |  |  |  |  + UnicodeEncodeError
 |  |  |  |  + UnicodeTranslateError
 + Warning
 |  + DeprecationWarning
 |  + PendingDeprecationWarning
 |  + RuntimeWarning
 |  + SyntaxWarning
 |  + UserWarning
 |  + FutureWarning
 + ImportWarning
 + UnicodeWarning

自定义异常类型


除了上述Python内置的异常类型外,我们也可以自定义异常类型。
虽无强制,但一般会声明自定义的异常类继承Exception。

在这里插入图片描述
一般参考Python内置类,定义一个总异常类,然后具体的每种异常继承自该类。
例如一个计算机程序将内部错误分为用户输入错误和内部逻辑错误两部分:

class BusiError(Exception):
    """程序异常错误信息总类"""
    pass
class UserInputError(BusiError):
    """用户输入信息错误"""
    def __init__(self,value):
        self.value=value
class InnerdealError(BusiError):
    """内部逻辑错误"""
    def __init__(self,class_type):
        self.class_type=class_type
try:
    print('statements1')
except(BusiError) as e:
    if type(e).__name__=="UserInputError":
        print('statements2')
    elif type(e).__name__=="InnerdealError":
        print('statements3')

这样当不知道statements1产生的具体异常时,可以使用BusiError基类来捕获对象,再根据对象类型的名字就可以知道具体是什么异常了。

在这里插入图片描述
Python系列博客持续更新中

原创不易,请勿转载本不富裕的访问量雪上加霜
博主首页:https://wzlodq.blog.csdn.net/
微信公众号:吾仄lo咚锵
如果文章对你有帮助,记得一键三连❤

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/180847.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 常见的兼容性问题解决「建议收藏」

    常见的兼容性问题解决「建议收藏」所谓的浏览器兼容性问题,是指因为不同的浏览器对同一段代码有不同的解析,造成页面显示效果不统一的情况。在大多数情况下,我们的需求是,无论用户用什么浏览器来查看我们的网站或者登陆我们的系统,都应该是统一的

    2022年8月5日
    9
  • STM32F103芯片手册带寄存器定义链接[通俗易懂]

    STM32F103芯片手册带寄存器定义链接[通俗易懂]STM32F1中文参考手册_V10-豆丁网(docin.com)

    2022年10月15日
    0
  • ViewGroup的LayoutParams理解[通俗易懂]

    ViewGroup的LayoutParams理解[通俗易懂]LayoutParams是ViewGroup的一个内部类,声明方式如下publicstaticclassLayoutParams{publicstaticfinalintMATCH_PARENT=-1;publicstaticfinalintWRAP_CONTENT=-2;publicintwidth;publicintheight;

    2022年9月15日
    0
  • zigbee组网的设计_物联网组网技术

    zigbee组网的设计_物联网组网技术目前,针对一定区域内信息和设备进行监测和控制多采用有线方式通信,网络在布线和维护过程中由于线路腐蚀和损坏造成网络中断,给正常生产工作带来影响,同时也增加了人力资源成本比重。基于此,从节省成本和网络稳定性考虑,给出一种基于ZigBee技术的多节点设备无线自组网设计方案。   基于IEEE802.15.4协议的ZigBee技术是一种新兴的短距离无线通信技术,具有功耗低、成本低

    2022年10月8日
    0
  • 现在哪款诺基亚能玩Java游戏_回忆S60(塞班)年代的JAVA游戏:有没有哪一款是你在课堂偷偷玩的?…

    现在哪款诺基亚能玩Java游戏_回忆S60(塞班)年代的JAVA游戏:有没有哪一款是你在课堂偷偷玩的?…Bounce我们把这个游戏叫为蹦球,也是诺基亚手机内置的一款游戏。需要操控一只红色的小皮球,滚动、蹦跳来一路闯关,碰触黄色的圈得分,关卡设计在今天来说都算是十分灵活的,可以来回进行冒险,不像常见的横版卷轴过关游戏,经过的关卡就不能回去了。玩这款游戏很是需要耐心,有些关卡需要特别注意机关、暗道,更有些关卡连弹跳的力度和位置都需要尝试很多次去掌握,依稀还记得按键2,5跳跃,按*(星键)可以改变蹦球形象…

    2022年7月7日
    18
  • Neokylin-Server离线环境、跨主机、使用Docker部署PXC集群

    Neokylin-Server离线环境、跨主机、使用Docker部署PXC集群Neokylin-Server离线环境、跨主机、使用Docker部署PXC集群Neokylin-Server离线环境、跨主机、使用Docker部署PXC集群一、说明二、部署过程:1.切换root账号或所有语句加sudo;2.关闭6个节点防火墙(或打开端口);3.6个节点导入rpm包后安装基础环境:4.设置所有节点;5.启动docker并导入images;6.时间同步;7.etcd集群配置;8.部署flannel网络;9.n1-n3部署pxc;10.m1-m3部署Haproxy+Keepa

    2022年8月10日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号