python-19-异常处理
一.说明
这篇是python中的基础系列的异常处理?为什么要异常处理?因为python脚本在运行时,发生异常我们就需要捕获异常进行处理,否则整个程序就会终止!
那么如何进行异常处理,在python中提供2种处理方式:
1.捕获:通过try、except、else和finally语句来实现
2.断言:自定义异常,使用 raise 语句
二.捕获
-
基本结构
try:尝试执行一段可能会抛出异常的代码。
except:捕获并处理指定的异常。如果没有指定,默认会捕获所有异常。
else:如果
try代码块没有引发异常,则执行这部分代码。finally:无论是否发生异常,这部分代码都会被执行,通常用于清理资源。
-
示例
try: # 尝试执行可能会引发异常的代码 numerator = 10 denominator = 0 result = numerator / denominator except ZeroDivisionError: # 处理特定的异常 print("错误:除数不能为零!") except Exception as e: # 处理其他未指定的异常 print(f"发生了其他错误:{e}") else: # 如果没有异常发生,执行这部分代码 print("计算结果是:", result) finally: # 无论如何都会执行 print("程序执行完毕。") ###处理多个异常 try: # 可能引发多种异常的代码 num = int(input("请输入一个数字: ")) print(10 / num) except (ValueError, ZeroDivisionError) as e: print(f"输入错误:{e}")注意:用
except Exception可以捕获所有异常
三.断言
什么是断言?其实就是自定义异常,通过raise语句来完成,但是会分为 引发现有异常、引发自定义异常、引发特定异常
-
引发现有异常
try: x = 1 / 0 # 这会引发 ZeroDivisionError except ZeroDivisionError as e: print("捕获到异常:", e) raise # 重新抛出异常 -
引发自定义异常
class MyError(Exception): pass def check_value(x): if x < 0: raise MyError("输入的值不能小于零!") try: check_value(-1) # 这会引发 MyError except MyError as e: print("捕获到自定义异常:", e) #捕获到自定义异常: 输入的值不能小于零! -
引发特定的异常
def divide(a, b): if b == 0: raise Exception("除数不能为零!") return a / b try: divide(10, 0) # 这会引发 ValueError except Exception as e: print("捕获到异常:", e) #捕获到异常: 除数不能为零! ########### try: x = 1 / 0 except ZeroDivisionError as e: raise ValueError("发生了一个值错误") from e
四.python所有标准异常类
| 异常名称 | 描述 |
|---|---|
| BaseException | 所有异常的基类 |
| SystemExit | 解释器请求退出 |
| KeyboardInterrupt | 用户中断执行(通常是输入^C) |
| Exception | 常规错误的基类 |
| StopIteration | 迭代器没有更多的值 |
| GeneratorExit | 生成器(generator)发生异常来通知退出 |
| SystemExit | Python |
| Python | 解释器请求退出 |
| StandardError | 所有的内建标准异常的基类 |
| ArithmeticError | 所有数值计算错误的基类 |
| FloatingPointError | 浮点计算错误 |
| OverflowError | 数值运算超出最大限制 |
| ZeroDivisionError | 除(或取模)零 |
| AssertionError | 断言语句失败 |
| AttributeError | 对象没有这个属性 |
| EOFError | 没有内建输入,到达EOF |
| EnvironmentError | 操作系统错误的基类 |
| IOError | 输入/输出操作失败 |
| OSError | 操作系统错误 |
| WindowsError | 系统调用失败 |
| ImportError | 导入模块/对象失败 |
| KeyboardInterrupt | 用户中断执行(通常是输入^C) |
| LookupError | 无效数据查询的基类 |
| IndexError | 序列中没有没有此索引(index) |
| KeyError | 映射中没有这个键 |
| MemoryError | 内存溢出错误(对于Python |
| NameError | 未声明/初始化对象 |
| UnboundLocalError | 访问未初始化的本地变量 |
| ReferenceError | 弱引用(Weak reference)试图访问已经垃圾回收了的对象 |
| RuntimeError | 一般的运行时错误 |
| NotImplementedError | 尚未实现的方法 |
| SyntaxError | 语法错误 |
| 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 | 用户代码生成的警告 |
五.总结
Python 异常处理就介绍这么多,没啥复杂内容,如果不添加则突然出现意外情况,则会导致整个程序终止!
所以在我们没有把握的情况下,可以对异常进行提前捕获!避免程序终止!
创作整理不易,请大家多多关注 多多点赞,有写的不对的地方欢迎大家补充,我来整理,再次感谢!
457

被折叠的 条评论
为什么被折叠?



