Python 学习之异常
1. 异常简介:
-
异常是一个事件,该事件会在程序执行过程中发生,影响了程序的正常执行。一般情况下,在 Python 无法正常处理程序时就会发生一个异常。异常是 Python 对象,表示一个错误。当 Python 脚本发生异常时我们需要捕获处理它,否则程序会终止执行
-
造成异常的原因:1. 程序编写有问题造成,产生 Bug ,必须处理 2. 用户输入造成的 3. 无法预料的异常:磁盘已满、断网等
-
Python 的错误其实也是类 class,错误类型种类很多。而且所有的错误类型都继承自 BaseException
-
为什么要处理异常?为了使程序遇到问题时不让程序结束,而越过错误继续向下执行。Python 内置了一套异常处理机制,来帮助我们进行错误处理
-
处理异常:try except finally 作用:try 语句块用来检测程序中的错误,从而让 except 语句捕获错误信息并处理。执行完 except 后,如果有 finally 语句块,则执行 finally 语句块,至此,执行完毕。
2. 常用操作:
1. 报出对应的异常:
try:
print(3 / 0)
except ZeroDivisionError as e:
print("除数为零了")
except NameError as e:
print("变量未定义")
else: # 注意:else语句可有可无
print("代码没有问题")
print("程序继续执行")
2. 报出对应的异常:
try:
print(4 / 0)
except: # 使用 except 捕获常规错误,而不使用任何的错误类型
print("程序出现了错误")
# 使用 except 带着多种异常,匹配到其中一种即报错
try:
print(5 / 0)
except(NameError, ZeroDivisionError):
print("出现了 ZeroDivisionError 或 NameError")
3. 特殊情况
"""
特殊:
1.错误其实是 class(类),所有的错误都继承自 BaseException,所以在
捕获的时候,它不仅捕获了该类型的错误,还把子类一网打尽
"""
try:
print(5 / 0)
except BaseException as e:
print("出现了BaseException")
except ZeroDivisionError as e:# 不会被执行
print("除数为零了")
"""
2.跨越多层调用,main 调用了 func2 ,2 调用了 1 ,
1 出现了错误,但是只要main捕获到了就可以处理
"""
def func1(num):
print(1 / num)
def func2(num):
func1(num)
def main():
func2(0)
try:
main()
except ZeroDivisionError as e:
print("调用的函数出现了错误")
4.try except finally
try:
print(1 / 0)
except ZeroDivisionError as e:
print("除数为零了")
finally:
print("finally是一定会被执行的")
try:
print(1 / 0)
finally:
print("finally是一定会被执行的")
5.1 print() 语句调试
"""
通过 print() 把可能有问题的变量打印出来
用 print()最大的坏处是将来还得删掉它,
想想程序里到处都是print(),运行结果也会包含很多垃圾信息
"""
def div(a, b):
print(b) # b可能会为 0
print(a / b)
div(10, 1)
5.2 assert 断言调试
"""
用 print() 来查看的地方,都可以用断言(assert)来替代:
断言失败时,assert 语句本身就会抛出 AssertionError
"""
def func(num, div):
assert (div != 0), "div不能为零"
return num / div
print(func(10, 0))
5.3 logging 调试
import logging
logging.basicConfig(level=logging.DEBUG)
"""
logging 的好处:允许你指定记录信息的级别,有debug,info,warning,error
4个级别,当我们指定 level=logging.INFO 时,logging.DEBUG 就不起作用了。
级别高的覆盖级别低的,所以可以输出不同级别的信息,也不用删除,最后统一控制输出各个级别的信息。
logging的另一个好处是通过简单的配置,一条语句可以同时输出到不同的地方,比如console和文件
"""
def div(a, b):
logging.info(b)
print(a / b)
div(10, 0)
以上为个人整理,有问题的地方还请大家多提提意见。
给你点赞
出差还不忘发帖,精神可嘉