异常基础
1.python基础之注释2.python语言学习路线(基础)3.python源码结构4.python发展史及python应用场景5.变量6.bug及debug7.常见数据类型及其转换8.字符串格式化9.转义符10.字符串在货币、日期、精度的处理11.字符编解码12.字符编解码及其相互转换13.内置函数-help-帮助文档14.内置函数print-输出15.内置函数input16.运算符17.int的缓存策略(特别容易混)18.判断语句19.random模块20.判断语句+ random的应用-剪刀石头布游戏21.三元运算符(if else的简写)22.循环语句-while23.循环语句-while-练习题24.循环语句for循环25.循环语句 + else26.字符串类str27.正则在字符串中的简单应用28.列表(List)29.列表list的sort方法的坑30.列表综合应用-8个教室随机分配到3个教室31.元组32.自动组包 & 自动解包33.字典34.集合35.公共操作36.公共操作-推导式(集合、列表、字典)37.函数定义、调用、闭包38.拆包和交换变量值39.函数的变量作用域、返回值、参数40.函数递归41.匿名函数(lambda表达式)0142.内置函数abs43.内置函数round44.内置函数abs0245.高阶函数46.内置高阶函数map47.内置高阶函数reduce48.内置函数reduce49.学生管理系统-函数&循环&运算符综合练习50.文件操作之语法51.文件操作2-最佳实践52.文件操作之seek53.文件及文件夹操作54.面向对象基本概念55.面向对象之类、对象的定义56.添加和获取对象属性57.面向对象之魔法方法58.魔法函数 __repr__() 和 __str__()的区别59.魔法方法__len__60.魔法方法之__getitem__(self, key)、__setitem__(self, key, value) 和 __delitem__(self, key) 61.魔法方法之__iter__(self) && __next__(self)62.TypeError: iter() returned non-iterator of type 'MyIterable'63.魔法方法之__contains__()64.魔法方法之__call__65.魔法方法之__getattr__(), __setattr__(), 和 __delattr__66.__eq__(), __lt__(), 和 __gt__() 67.案例:烤地瓜68.案例:给房子置办家具69.继承70.继承之子类复用父类的属性、方法71.继承的分类72.MRO73.继承之子类重写父类同名属性和方法74.⼦类调⽤⽗类的同名⽅法和属性75.私有属性&&方法的定义&访问限制76.setter&getter方法访问私有属性77.__mro__属性78.python 面向对象3大特征详解79. 类属性和实例属性80.类属性和实例属性最佳实践81.类方法82.静态方法
83.异常基础
84.多组异常处理基础85.多组异常处理86.使用Python内置的错误信息87.捕获所有异常88.手动抛异常(raise)89.try-except-else-finally90.断言assert在异常中应用91.自定义异常类92.模块93.常见的5种模块导入94.模块的定位顺序95.__all__变量限制、明确导入范围96.包97.时间模块datetime98.多任务编程之并发、并行概念99.进程实现多任务(进程概念、单进程、多进程执行多任务)1. 什么是异常
跟java异常(Exception)一样,都是指在程序执行过程中发生的错误或异常情况。当程序出现异常时,会中断正常的执行流程,并转而执行异常处理的逻辑。
2. 什么情况下触发异常
异常可以由多种原因引起,例如:
- 语法错误:代码不符合Python语法规则。
- 运行时错误:在代码执行期间发生了错误,如除零错误、索引错误等。
- 逻辑错误:程序逻辑错误导致了异常情况,如值错误、类型错误等。
当遇到异常时,Python会抛出相应的异常对象。
这些异常对象属于异常类的实例,它们包含有关异常的相关信息,如异常类型和错误消息。
通过捕获和处理这些异常,我们可以更好地控制程序的流程,并提供适当的错误处理机制。
3. 异常的处理
异常处理通常使用try-except
语句来实现。在try
块中,放置可能引发异常的代码;在except
块中,指定要处理的异常类型,并提供相应的处理逻辑。如果没有匹配的except
块,异常将被传递给上层调用栈,直到找到匹配的异常处理器或程序终止。
try: # 可能会引发异常的代码 result = 10 / 0 # 除以零会引发 ZeroDivisionError 异常 print("这行代码不会被执行") except ZeroDivisionError: # 处理 ZeroDivisionError 异常 print("除零错误发生") print("异常捕获,处理完成后继续执行") # 输出: # 除零错误发生 # 异常捕获,处理完成后继续执行
4. 异常处理程序-try-except
4.1 一个除数为0的错误
1 def division(x, y): 2 return x / y 3 4 5 print(division(8, 6)) # 1.3333333333333333 6 ''' 7 Traceback (most recent call last): 8 File "F:\python\base\base\037异常\异常01-一个除数为0的错误.py", line 6, in <module> 9 print(division(5, 0)) 10 ^^^^^^^^^^^^^^ 11 File "F:\python\base\base\037异常\异常01-一个除数为0的错误.py", line 2, in division 12 return x / y 13 ~~^~~ 14 ZeroDivisionError: division by zer 15 ''' 16 print(division(5, 0)) # 报错 17 18 print(division(6, 3)) # 报错后,程序终止,此句未执行
当一个程序发生了异常,程序就会将异常传递给上层调用栈,直到找到匹配的异常处理器或程序终止。如果没有处理线程或程序将会终止。
4.2 语法
1 try: 2 # 可能会引发异常的代码块 3 # ... 4 except 异常类: # 如果没有异常类,则捕获所有异常 5 # 异常处理代码
1 def division(x, y): 2 try: 3 return x / y 4 except ZeroDivisionError: 5 print("除数不可为0") 6 7 8 print(division(8, 6)) # 1.3333333333333333 9 print(division(5, 0)) # 报错被捕获,但函数还是有返回值,为None 10 11 print(division(6, 3)) # 异常被捕获处理,程序没有终止,因此此句执行了.输出:2.0
5. 异常处理-try-except-else
5.1 语法
1 try: 2 # 可能会引发异常的代码块 3 # ... 4 except ExceptionType1: # 如果没有异常类,捕获所有的异常 5 # 处理 ExceptionType1 类型的异常的代码 6 # ... 7 else: 8 # 在没有引发异常时执行的代码块
def division(x, y): try: result = x / y except ZeroDivisionError: print("除数不可为0") else: # 程序无异常,返回结果 print("程序无异常发生") return result print(division(8, 6)) # 1.3333333333333333 print(division(5, 0)) # 报错被捕获,但函数还是有返回值,为None print(division(6, 3)) # 异常被捕获处理,程序没有终止,因此此句执行了.输出:2.0 ''' 输出: 1.3333333333333333 除数不可为0 None 程序无异常发生 2.0 '''
else块(可选):在try块中的代码没有引发任何异常时执行的代码块。
else语句场景:
-
需要处理异常以外的代码逻辑:
else
块中的代码会在try
块中的代码没有引发任何异常时执行。这样可以将正常的代码逻辑放在else
块中,而将异常处理逻辑放在except
块中,使代码更加清晰和可读。 - 异常处理与成功处理分离:else块中的代码只会在没有异常发生时执行,因此可以将对于异常情况的处理与正常情况的处理分离开来,提高代码的可读性和可维护性。
1 ''' 2 通过try-except-else统计一个文件中的字数 3 ''' 4 test_file = "except文件.txt" 5 6 try: 7 # 使用encoding='utf-8',避免UnicodeDecodeError异常 8 with open(file=test_file,encoding='utf-8') as file_obj: # UnicodeDecodeError: 'gbk' codec can't decode byte 0x91 in position 2: illegal multibyte sequence 9 data = file_obj.read() 10 except FileNotFoundError: 11 print(f"找不到文件{test_file}") 12 else: 13 word_list = data.split() 14 print(f"{test_file}文件的字数是:{len(word_list)}")
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!