python异常处理机制
python提供了两个非常重要的功能来处理python程序在运行中出现的异常和错误。你可以使用该功能来调试python程序。
1 2 | 异常处理: 断言(Assertions) |
python标准异常
异常名称 | 描述 |
---|---|
BaseException | 所有异常的基类 |
SystemExit | 解释器请求退出 |
KeyboardInterrupt | 用户中断执行(通常是输入^C) |
Exception | 常规错误的基类 |
StopIteration | 迭代器没有更多的值 |
GeneratorExit | 生成器(generator)发生异常来通知退出 |
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 | 尚未实现的方法 |
SyntaxError | Python 语法错误 |
IndentationError | 缩进错误 |
TabError | Tab 和空格混用 |
SystemError | 一般的解释器系统错误 |
TypeError | 对类型无效的操作 |
ValueError | 传入无效的参数 |
UnicodeError | Unicode 相关的错误 |
UnicodeDecodeError | Unicode 解码时的错误 |
UnicodeEncodeError | Unicode 编码时错误 |
UnicodeTranslateError | Unicode 转换时错误 |
Warning | 警告的基类 |
DeprecationWarning | 关于被弃用的特征的警告 |
FutureWarning | 关于构造将来语义会有改变的警告 |
OverflowWarning | 旧的关于自动提升为长整型(long)的警告 |
PendingDeprecationWarning | 关于特性将会被废弃的警告 |
RuntimeWarning | 可疑的运行时行为(runtime behavior)的警告 |
SyntaxWarning | 可疑的语法的警告 |
UserWarning | 用户代码生成的警告 |
一、什么是异常?
1 2 3 4 | 异常即是一个事件,该事件会在程序执行过程中发生,影响了程序的正常执行。 一般情况下,在Python无法正常处理程序时就会发生一个异常。 异常是Python对象,表示一个错误。 当Python脚本发生异常时我们需要捕获处理它,否则程序会终止执行。 |
二、异常处理
捕捉异常可以使用try/except语句。
try/except语句用来检测try语句块中的错误,从而让except语句捕获异常信息并处理。
如果你不想在异常发生时结束你的程序,只需在try里捕获它。
语法:
以下为简单的try....except...else的语法:
1 2 3 4 5 6 7 8 | try : <语句> #运行别的代码 except <名字>: <语句> #如果在 try 部份引发了 'name' 异常 except <名字>,<数据>: <语句> #如果引发了 'name' 异常,获得附加的数据 else : <语句> #如果没有异常发生 |
try的工作原理是,当开始一个try语句后,python就在当前程序的上下文中作标记,这样当异常出现时就可以回到这里,try子句先执行,接下来会发生什么依赖于执行时是否出现异常。
1 2 3 | 如果当 try 后的语句执行时发生异常,python就跳回到 try 并执行第一个匹配该异常的except子句,异常处理完毕,控制流就通过整个 try 语句(除非在处理异常时又引发新的异常)。 如果在 try 后的语句里发生了异常,却没有匹配的except子句,异常将被递交到上层的 try ,或者到程序的最上层(这样将结束程序,并打印默认的出错信息)。 如果在 try 子句执行时没有发生异常,python将执行 else 语句后的语句(如果有 else 的话),然后控制流通过整个 try 语句。 |
1.使用except而带多种异常类型
你也可以使用相同的except语句来处理多个异常信息,如下所示:
1 2 3 4 5 6 7 8 | try : 正常的操作 ...................... except(Exception1[, Exception2[,...ExceptionN]]]): 发生以上多个异常中的一个,执行这块代码 ...................... else : 如果没有异常执行这块代码 |
2.使用except处理所有异常类型
1 2 3 4 5 6 7 8 | try : 正常的操作 ...................... exceptException as e: 发生以上多个异常中的一个,执行这块代码 ...................... else : 如果没有异常执行这块代码 |
3.try-finally 语句
1 2 3 4 5 | try : <语句> finally : <语句> #退出 try 时总会执行 raise |
4.异常的参数
一个异常可以带上参数,可作为输出的异常信息参数。
你可以通过except语句来捕获异常的参数,如下所示:
1 2 3 4 5 | try : 正常的操作 ...................... except ExceptionType, Argument: 你可以在这输出 Argument 的值... |
变量接收的异常值通常包含在异常的语句中。在元组的表单中变量可以接收一个或者多个值。
元组通常包含错误字符串,错误数字,错误位置
5.触发异常
我们可以使用raise语句自己触发异常
raise语法格式如下:
1 | raise [Exception [, args [, traceback]]] |
语句中 Exception 是异常的类型(例如,NameError)参数标准异常中任一种,args 是自已提供的异常参数。
最后一个参数是可选的(在实践中很少使用),如果存在,是跟踪异常对象。
6.自定义异常
通过创建一个新的异常类,程序可以命名它们自己的异常。异常应该是典型的继承自Exception类,通过直接或间接的方式。
以下为与RuntimeError相关的实例,实例中创建了一个类,基类为RuntimeError,用于在异常触发时输出更多的信息。
在try语句块中,用户自定义的异常后执行except块语句,变量 e 是用于创建Networkerror类的实例。
1 2 3 | class Networkerror(RuntimeError): def __init__(self, arg): self.args = arg |
在你定义以上类后,你可以触发该异常,如下所示:
1 2 3 4 | try : raise Networkerror( "Bad hostname" ) except Networkerror,e: print e.args |
两个特殊的处理异常的方法
断言(assert)
1 | assert expression[,reason] |
其中assert是断言的关键字。执行该语句的时候,先判断表达式expression,如果表达式为真,则什么都不做;如果表达式不为真,则抛出异常。reason跟之前谈到的异常类的实例一样。
上下文管理(with语句)
如果你使用try, except, finally代码仅仅是为了保证共享资源(如文件,数据)的唯一分配,并在任务结束后释放它,那么这个with语句可以让你从try, except, finally中解放出来!语法如下:
1 2 | with context_expr [ as var ]: with_suite |
举个例子: view plain
1 2 3 | >>> with open( '/root/test.py' ) as f: ... for line in f: ... print line |
使用with语句来使用这些共享资源,我们不用担心会因为某种原因而没有释放他。但并不是所有的对象都可以使用with语句,只有支持上下文管理协议(context management protocol)的对象才可以,那哪些对象支持该协议呢?如下表:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | file decimal .Context thread.LockType threading.Lock threading.RLock threading.Condition threading.Semaphore threading.BoundedSemaphore |
sys模块获取异常
另一种获取异常信息的途径是通过sys模块中的exc_info()函数。该函数回返回一个三元组:(异常类,异常类的实例,跟中记录对象)。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | >>> try : ... 1/0 ... except: ... import sys ... tuple = sys.exc_info() ... >>> print tuple (<type 'exceptions.ZeroDivisionError' >, ZeroDivisionError( 'integer division or modulo by zero' ,), <traceback object at 0x7f538a318b48>) >>> for i in tuple: ... print i ... <type 'exceptions.ZeroDivisionError' > #异常类 integer division or modulo by zero #异常类的实例 <traceback object at 0x7f538a318b48> #跟踪记录对象 |
抄自于:https://blog.csdn.net/zengxiantao1994/article/details/58661944
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具