文章目录
1. 异常的本质;调试核心理念
python中一切都是对象,异常也采用对象的方式来处理。处理过程:
- 抛出异常:在执行一个方法时,如果发生异常,则这个方法生成代表该异常的一个对象,停止当前执行路径,并把异常对象提交给解释器。
- 捕获异常:解释器得到该异常后,寻找相应的代码来处理该异常。
2. try … 一个except结构
- 语法:
try:
被监控的有可能引发异常的语句块
except BaseException [as e]:
异常处理语句块
- 测试:
print('step0')
try:
print('step1')
a = 3/0
print('step2')
except BaseException as e
print('step3')
print(e)
print(type(e))
print('程序结束!')
# 示例:循环输入数字,如果不是数字则抛出异常;如果输入88,则循环结束
while True:
try:
x = int(input('请输入一个数字:'))
print('输入数字:',x)
if x == 88:
print('退出程序')
break
except BaseException as e:
print(e)
print('异常,输入的不是一个数字!')
print('循环数字输入结束!')
3. try多个except结构
-
语法:注意Exception1不能是下边异常的父类,那样不会再往下执行了。
try: 被监控的,可能会引发异常的语句块 except Exception1: 处理Exception1的语句块 except Exception2: 处理Exception2的语句块 ... exception BaseException: 处理可能被遗漏的异常的语句块
-
测试:
try: a = input('请输入一个除数:') b = input('请输入一个除数:') c = float(a)/float(b) print(c) except ZeroDivisionError: print('异常,不能除以0') except ValueError: print('异常,不能将字符串转化成数字') except NameError: print('异常,变量不存在') except BaseException as e: print(e)
4. try…except…else 结构
- 没有捕获到异常的话,执行
else
语句
try:
a = input('请输入一个除数:')
b = input('请输入一个除数:')
c = float(a)/float(b)
print(c)
except ZeroDivisionError:
print('异常,不能除以0')
except ValueError:
print('异常,不能将字符串转化成数字')
except NameError:
print('异常,变量不存在')
except BaseException as e:
print(e)
else:
print('除的结果是:', c)
5. finally结构
- try…except…finally 结构中,finally块无论是否发生异常都会被执行;通常用来释放try块中的申请的资源。
try:
a = input('请输入一个除数:')
b = input('请输入一个除数:')
c = float(a)/float(b)
print(c)
except ZeroDivisionError:
print('异常,不能除以0')
except ValueError:
print('异常,不能将字符串转化成数字')
except NameError:
print('异常,变量不存在')
except BaseException as e:
print(e)
else:
print('除的结果是:', c)
finally:
print('我是finally语句,无论发生异常与否,都执行!')
try:
f = open('d:/a.text','r')
content = f.readline()
print(content)
except:
print('文件未找到!')
finally:
print('程序关闭!')
try:
f.close()
except BaseException as e:
print(e)
print('程序执行结束!')
7. return 语句和异常处理问题
- 由于return有两种作用:结束方法的运行;返回值。我们一般不把return放到异常处理结构中,而是放到方法的最后。
8. 常见异常解决、汇总
SyntaxError
:语法错误NameError
:尝试访问一个没有申明的变量ZeroDivisionError
:除数为0错误ValueError
:数值错误TypeError
:类型错误AttributeError
:访问对象不存在的属性IndexError
:索引越界异常KeyError
:字典的关键字不存在
9. with上下文管理
-
finally 块是由于无论异常发生与否都会执行,通常是我们释放资源的代码。其实,我们还可以通过
with
来下文管理,更方便的实现释放资源的操作。但是,with
不是用来取代try,只是做为补充,方便我们在文件管理,网络通信时的开发。 -
语法:
with context_exprssion(as var):
语句块
with open('d:/a.text','r') as f:
content = f.readline()
print(content)
print('程序结束!')
10. trackback 模块
import traceback
try:
print('step1')
num=1/0
except:
traceback.print_exc()
######### 将异常信息输出到指定的文件中 ##########
try:
print('step1')
num=1/0
except:
with open('d:/a.text', 'a') as f:
traceback.print_exc(flie=f)
11. 自定义异常类
-
程序开发中,有时候我们也需要自己定义异常类,自定义异常类一般都是运行时的异常,通常继承Exception,或其子类即可。命名一般以 Error、Exception为后缀。
-
自定义异常由
raise
语句抛出
class AgeError(Exception):
def __init__(self, errorInfo):
super().__init__(self)
self.errorInfo = errorInfo
def __str__(self):
return str(self.errorInfo)+'年龄错误!应该在1-150之间!'
######### 测试代码 #############
if __name__ == '__main__': # 如果为True,则模块是作为独立文件运行,可以执行测试代码
age = int(input('输入一个年龄:'))
if age<1 or age>150:
raise AgeError(age)
else:
print('正常年龄:', age)
12. pycharm 开发环境的调试(断点)
-
进行调试的核心是设置断点,程序执行到断点时,暂时挂起,停止执行。就像看视频按下停止一样,我们可以详细的观看停止处的每一个细节。
-
step over:若当前执行的是一个函数,则会把这个函数当做整体一步执行完成。不会进入函数内部。
-
step into:若当前执行的是一个函数,则会进入这个函数的内部。
-
step out:当单步执行到子函数内部时,用step out就可以执行子函数余下部分,并返回到上一层函数。
-
run to cursor:运行到光标处
-
观察器(watch)