当前位置: 首页 > news >正文

python编程之异常处理

1、异常处理概念

程序运行过程中如果发生错误(包括语法错误和异常),程序就会用回溯(traceback)来终止执行。通过python解释器来捕获异常,处理异常来实现程序继续运行。

语法错误:也称为解析错误,顾名思义就是代码语法错误,不符合解释器或者编译器语法,比如我们刚学python的时候经常遇到的错误 SyntaxError

异常:代码的语法是正确的,但是由于不合法的输入值等因素造成的程序运行错误,如被除数是0会引发 ZeroDivisionError 类型的错误。

异常是python对象

2、内置异常

官网地址:Built-in Exceptions — Python 3.11.3 documentation

异常名称描述
BaseException所有异常的基类
SystemExit解释器请求退出
KeyboardInterrupt用户中断执行(通常是输入^C)
GeneratorExit生成器(generator)发生异常来通知退出
Exception常规错误的基类
StopIteration迭代器没有更多的值
StandardError所有的内建标准异常的基类
ArithmeticError所有数值计算错误的基类
FloatingPointError浮点计算错误
OverflowError数值运算超出最大限制
ZeroDivisionError除(或取模)零 (所有数据类型)
AssertionError断言语句失败
AttributeError对象没有这个属性
EOFError没有内建输入,到达EOF 标记
EnvironmentError操作系统错误的基类
IOError输入/输出操作失败
OSError操作系统错误
WindowsError系统调用失败
ImportError导入模块/对象失败
LookupError无效数据查询的基类
IndexError序列中没有此索引(index)
KeyError映射中没有这个键
MemoryError内存溢出错误(对于Python 解释器不是致命的)
NameError未声明/初始化对象 (没有属性)
UnboundLocalError访问未初始化的本地变量
ReferenceError弱引用(Weak reference)试图访问已经垃圾回收了的对象
RuntimeError一般的运行时错误
NotImplementedError尚未实现的方法
SyntaxErrorPython 语法错误
IndentationError缩进错误
TabErrorTab 和空格混用
SystemError一般的解释器系统错误
TypeError对类型无效的操作
ValueError传入无效的参数
UnicodeErrorUnicode 相关的错误
UnicodeDecodeErrorUnicode 解码时的错误
UnicodeEncodeErrorUnicode 编码时错误
UnicodeTranslateErrorUnicode 转换时错误
Warning警告的基类
DeprecationWarning关于被弃用的特征的警告
FutureWarning关于构造将来语义会有改变的警告
OverflowWarning旧的关于自动提升为长整型(long)的警告
PendingDeprecationWarning关于特性将会被废弃的警告
RuntimeWarning可疑的运行时行为(runtime behavior)的警告
SyntaxWarning可疑的语法的警告
UserWarning用户代码生成的警告
3、异常处理

3.1  try...except...语句

语法格式:

try:    "代码块" 
except ExceptionName:    "捕获指定类型的异常,执行此代码块" 
except Exception:    "捕获异常,执行此代码块"

try 语句的工作原理如下:

  • 首先,执行try子句(tryand except关键字之间的语句)。

  • 如果没有异常发生,则将跳过except子句,并且该try语句的执行 完成。

  • 如果在try子句执行期间发生异常,则该子句的其余部分将被跳过。然后,如果其类型与以except关键字命名的异常匹配 ,则执行except子句。

  • 如果发生与except子句中命名的异常不匹配的异常,则将其传递给外部try语句。

try 语句的工作原理如下:

  • 首先,执行try子句(tryand except关键字之间的语句)。

  • 如果没有异常发生,则将跳过except子句,并且该try语句的执行 完成。

  • 如果在try子句执行期间发生异常,则该子句的其余部分将被跳过。然后,如果其类型与以except关键字命名的异常匹配 ,则执行except子句。

  • 如果发生与except子句中命名的异常不匹配的异常,则将其传递给外部try语句。

说明:

  • 一个 try 语句可能有多个 except 子句,以指定不同异常的处理程序

  • except 后面可以是一个类型异常类型,也可以是多个异常类型,使用()括起来。

  • except  后面不接异常类型,会捕获所有异常。

  • 也可以使用 as 给异常类型起别名,方便在异常处理代码块中调用。

  • try...except...可以是嵌套结构

实例:

try:    
    a = 1/0 
except ZeroDivisionError as e:    # 捕获到异常的时候执行此代码块    
    print('捕获到异常啦!')    
    print(e) 
except:    
    print('未知错误') ------------------------------------------------------------------
    运行结果:捕获到异常啦!division by zero

3.2  else 语句

语法格式:

try:    "代码块" 
except Exception:    "捕获异常,执行此代码块" 
else:    "没有异常,执行此代码块" 

说明:

  • else 语句只有当try代码块没有异常,并且执行完之后执行。

实例:

try:    assert 1 == 1 
except:    print('捕获到异常啦!') 
else:    # 没有捕获异常的时候执行此代码块    
    print("程序正常运行") 
---------------------------------------------------------------运行结果:程序正常运行

3.3  finally 语句

语法格式:

try:    "代码块" 
except Exception:    "捕获异常,执行此代码块" 
else:    "没有异常,执行此代码块" 
finally:    "无论是否捕获异常都会执行的代码块"

说明:

  • 无论 try 块是否发生异常,都会执行 finally 语句的代码块

  • finally 在我们操作文件的时候很有用,无论是打开还是编辑文件之后都要执行保存文件的操作,起到释放资源的作用。

实例:

try:    assert 1 == 2 
except (AssertionError,ZeroDivisionError) :    
    print('捕获到异常啦!') 
    except:    
        print('未知错误') 
    else:    
        print('程序正常运行') 
    finally:    print("程序继续运行") 
    --------------------------------------------------------------------运行结果:捕获到异常啦!程序继续运行

4、主动抛出异常

raise 关键字允许我们在程序中手动抛出异常

语法:raise exceptName(reason)

try:    
    a = input("输入一个数:")    #判断用户输入的是否为数字    
    if(not a.isdigit()):        
        raise ValueError("a 必须是数字") 
except ValueError as e:    
    print("发生异常:",repr(e)) ------------------------------------------
    运行结果:输入一个数:aaa发生异常: ValueError('a 必须是数字')

说明:

  • raise 抛出的异常,也可以用 except 去捕获异常

  • raise 抛出的异常可以是内置的异常,也可以是自定义的异常

5、自定义异常(面向对象后)
  • 用户自定义异常类需要继承 Exception 类,重写父类的__init__方法(方法重载)

# 自定义异常类 
#MyException
class MyException(Exception):  # 继承异常类     
    def __init__(self,code,msg): # 重写父类的__init__方法        
        self.code = code        
        self.msg = msg # 捕获自定义异常类并打印输出异常信息
        try:    
            raise MyException('404','请求失败') 
        except MyException as e:    
            print(e) 
-------------------------------------------运行结果:('404', '请求失败')

6、异常信息传递过程

def fun1():    fun2() def fun2():    fun3() def fun3():    raise Exception("抛出异常,可以自定义异常") fun1() --------------------------------------------------------------------运行结果:Traceback (most recent call last):  File "E:/github/python/python_module/traceback_module/exception_test.py", line 16, in <module>    fun1()  File "E:/github/python/python_module/traceback_module/exception_test.py", line 8, in fun1    fun2()  File "E:/github/python/python_module/traceback_module/exception_test.py", line 11, in fun2    fun3()  File "E:/github/python/python_module/traceback_module/exception_test.py", line 14, in fun3    raise Exception("抛出异常,可以自定义异常")Exception: 抛出异常,可以自定义异常

  • 分析运行结果可以看出,异常从fun3()函数开始触发,传到 fun2()函数,再传到 fun1()函数,最后传到最外层,这个过程就是整个异常的传播轨迹。

  • 这样我们以后快速定位报错问题,只要看最后一个报错位置就行,再也不用怕控制台一堆报错信息。

7、打印异常信息

try:    a = 1/0 
except (AssertionError,ZeroDivisionError) as e:    
    print("异常信息")    
    print(e)    
    print(e.args)    
    print(str(e))    
    print(repr(e)) 
    except:    
        print('未知错误')-----------------------------------------------
        运行结果:异常信息division by zero('division by zero',)division by zeroZeroDivisionError('division by zero')

说明

  • args:返回异常的错误编号和描述字符串;

  • str(e):返回异常信息,但不包括异常信息的类型;

  • repr(e):返回较全的异常信息,包括异常信息的类型。

8、回溯

8.1 使用 sys 模块中的 exc_info 方法

import sys try:    1 / 0
except:    
    print(sys.exc_info()) -------------------------------------------------------------------
    运行结果:(<class 'ZeroDivisionError'>, ZeroDivisionError('division by zero'), <traceback object at 0x00000291DA2A8980>)

说明:

sys.exc_info( )的返回值是一个元组(type, value, traceback),其中:

  • type —— 异常的类型

  • value —— 异常的信息或者参数

  • traceback —— 包含调用栈信息的对象

8.2 使用 traceback 模块中的相关函数

  • 语法格式:traceback.print_exc(limit=None, file=None)

  • limit:用于限制显示异常传播的层数

  • file:指定将异常传播轨迹信息输出到指定文件中。如果不指定该参数,则默认输出到控制台。

mport traceback try:    1 / 0except:    print(traceback.print_exc()) --------------------------------------------------------------运行结果:NoneTraceback (most recent call last):  File "E:/github-projects/python-test/python_basics/traceback_test.py", line 16, in <module>    1 / 0ZeroDivisionError: division by zero

http://www.dtcms.com/a/497178.html

相关文章:

  • 具身智能之旅001
  • 做动效很好的网站wordpress 博主
  • 商城网站建设模板下载注册公司费用最低多少
  • 【Kymo AI应用案例】一本教育X Kymo:用AI实现作业秒级批改
  • 农业行业网站建设网站建设与管理方案书
  • 奉化网站建设报价安装网站提示dir
  • 上海网站制作开发公司网站建设利弊
  • 做网店哪些网站比较好沧州网站建设培训
  • i/o旅程
  • 网站源码.netoa办公系统官网
  • 创建一个网站需要多少钱营销微网站建设公司
  • 萍乡网站建设可以做围棋题的网站
  • 网站建设 做一个网站需要多少钱景观设计师如何做网站
  • 泊头市网站建设品牌策划工作内容
  • 淮安哪里做网站玉林城乡住房建设厅网站
  • 收益指标的计算公式
  • 企业网站的设计论文石家庄全网seo
  • 动态ip可以做网站吗网站后台更新栏目
  • 教育网站官网入口陕西省建设厅官网查询
  • PyQt开发_小学学习辅助工具
  • 玛哈特激光落料线:当钢卷遇见“光刀”
  • 零基础学做网站宾馆的网站回款如何做分录
  • 网站推荐几个网页版游戏排行榜4399
  • wordpress如何建企业站网店详情页设计
  • 东莞市公司网站建设怎么样wordpress logo 字体颜色
  • 惠州营销网站建设公司dede做的网站怎样去换模版
  • dw和sql做网站抽奖的网站怎么做
  • 济南营销网站建设价格软文推广的优点
  • 网站开发的架构企业网站制作模板免费下载
  • 打造个人 Z-Library 镜像完整技术指南