Python 之 try...except...else...finally 异常处理

2024-05-25 21:08

本文主要是介绍Python 之 try...except...else...finally 异常处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. Python 运行过程中的异常理解

python 程序在运行期检测到的错误称为 “异常”,大多数异常都不会被程序主动处理,最终会产生一个错误信息致使程序终止运行或者崩溃。要保证程序如预期的正常运行,就需要主动去处理一些可预见的 “异常” ,Python 中可以用 try … except … finally 来捕获异常并做处理。
异常包含:1)python 内建异常; 2)自定义异常,下面会逐一介绍这两类异常。

2. try except 异常处理理解和使用

import systry:											# try 语句				print("执行期望的代码")
except OSError as err:							# 捕获系统相关异常并做处理print("捕获OSError相关错误, error: ", err)
except (RuntimeError, TypeError, NameError):    # 一个 except 中包含多个异常print("捕获***错误")
except:				# 通配符,捕获所有的异常。慎用此法,因为它会轻易隐藏一个实际的程序错误, 可以使用这种方法打印一条错误信息,然后重新抛出异常(允许调用者处理这个异常)print("捕获未知错误:", sys.exc_info()[0])raise			# 手动抛出一个异常,终止程序 
else:				# else 语句用于当 try 语句没有异常时,如果需要执行一些代码,可以加上 else 语句,此时会执行 else 语句中的代码# 使用 else 子句比在 try 子句中附加代码要好,因为这样可以避免 try … except 意外的截获本来不属于它们保护的那些代码抛出的异常。print("没有错误,执行") 
finally:			# 不管有没有错误都会执行 finally 中的代码print("不管有没有错,都执行finally") 

2.1 try 语句工作原理

在这里插入图片描述

  • 首先,执行 try 子句 (在 try 和 except 关键字之间的部分)。
  • 如果没有异常发生, except 子句 在 try 语句执行完毕后就被忽略了。
  • 如果在 try 子句执行过程中发生了异常,那么该子句其余的部分就会被忽略。
  • 如果异常匹配于 except 关键字后面指定的异常类型,就执行对应的except子句。然后继续执行 try 语句之后的代码。
  • 如果发生了一个异常,在 except 子句中没有与之匹配的分支,它就会传递到上一级 try 语句中。
  • 如果最终仍找不到对应的处理语句,它就成为一个 未处理异常,终止程序运行,显示提示信息。

2.2 代码示例

''' 调用 k8s api 进行删除pv资源示例 ''''
def delete(self, pv_name):"""删除 PersistentVolume 函数:param pv_name: 要删除的PV名字:return:Ture:   删除成功False   删除失败"""try:# 判断 pv 是否在集群中存在resp = self.corev1_api.read_persistent_volume(name=pv_name)logger.info("pv: %s confirm exist, res: %s\n" % (pv_name, resp))try:# 存在,执行删除动作res = self.corev1_api.delete_persistent_volume(name=pv_name)res = res.to_dict()logger.info("pv: %s delete succeed\n" % pv_name)return True, resexcept ApiException as e:logger.error("Exception when calling CoreV1Api->delete_persistent_volume: %s\n" % e)return False, "Error delete pv, %s" % eexcept ApiException as e:if e.status == 404:logger.error("pv: %s NotExist, cant delete\n" % pv_name)return False, "NotExist, 当前PV: %s, 集群中不存在" % pv_namelogger.error("Exception when calling CoreV1Api->read_persistent_volume: %s\n" % e)return False, "Error read pv, %s" % e

3. python 自带的常用异常继承关系和含义说明

BaseException				# 新的所有异常的基类,都由此衍生而来+-- SystemExit				# 解释器请求退出+-- KeyboardInterrupt		# Ctrl+C 被按下时,程序被强行终止+-- GeneratorExit			# 生成器发生异常通知退出+-- Exception				# 常规错误的基类,继承 BaseException+-- StopIteration		# 迭代器没有更多的值错误+-- StopAsyncIteration+-- ArithmeticError|    +-- FloatingPointError|    +-- OverflowError|    +-- ZeroDivisionError+-- AssertionError		+-- AttributeError			# 对象没有要使用的属性错误+-- BufferError				+-- EOFError					+-- ImportError				# 导入模块/对象失败报错|    +-- ModuleNotFoundError+-- LookupError				# 无效数据查询的基类|    +-- IndexError|    +-- KeyError+-- MemoryError				# 内存溢出报错+-- NameError					# 使用一个还未赋值对象的变量错误|    +-- UnboundLocalError+-- OSError					# 系统相关的错误|    +-- BlockingIOError|    +-- ChildProcessError|    +-- ConnectionError|    |    +-- BrokenPipeError|    |    +-- ConnectionAbortedError|    |    +-- ConnectionRefusedError|    |    +-- ConnectionResetError|    +-- FileExistsError		# 试图创建一个已经存在的文件错误|    +-- FileNotFoundError	# 试图打开一个不存在的文件错误|    +-- InterruptedError|    +-- IsADirectoryError	# |    +-- NotADirectoryError	# |    +-- PermissionError		# 文件权限错误|    +-- ProcessLookupError|    +-- TimeoutError			# 超时报错+-- RuntimeError				# 一般的运行错误+-- SyntaxError				# 语法错误|    +-- IndentationError		# 缩进错误|         +-- TabError 		# Tab 与 空格混用错误+-- SystemError				# 解释器请求退出+-- TypeError					# 传入的对象类型与要求不符+-- ValueError		# 传入一个调用者不期望的值,一般就是编码转换的错误|    +-- UnicodeError					# Unicode 相关的错误|         +-- UnicodeDecodeError 		# Unicode 解码时的错误|         +-- UnicodeEncodeError		# Unicode 编码时的错误|         +-- UnicodeTranslateError	# Unicode 转换时的错误+-- Warning						# 警告的基类+-- DeprecationWarning+-- PendingDeprecationWarning+-- RuntimeWarning+-- SyntaxWarning+-- UserWarning+-- FutureWarning+-- ImportWarning+-- UnicodeWarning+-- BytesWarning+-- ResourceWarning

4. 用户自定义异常

4.1 raise 语句理解

作用:主动抛出异常并终止程序
格式:raise 异常名称(“异常描述”)

raise RuntimeError("example error")

4.2 自定义异常方法和使用

当程序运行时内建的异常无法满足需求或者想自定义一些专属的异常,就需要进行自定义异常。
Python 异常继承关系:
在这里插入图片描述
我们可以看到 python 的异常有个大基类 BaseException,然后是异常基类 Exception,所以我们自定义类也必须继承 Exception 基类。
代码示例:

''' 自定义一个异常类 CustomError '''
class CustomError(Exception):def __init__(self,ErrorInfo):super().__init__(self) 			# 初始化继承的 Exception 父类# 也可以去掉,如果去掉则 Exception 默认的 __init__() 被覆盖self.errorinfo = ErrorInfodef __str__(self):					# __str__方法来定义需要抛出的异常信息,此时接受 raise 传入的异常信息return self.errorinfoif __name__ == '__main__':try:raise CustomError('客户异常')	# 手动抛出自定义的异常except CustomError as e:			# except 中捕获抛出的异常并做处理print(e)

这篇关于Python 之 try...except...else...finally 异常处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1002633

相关文章

Python 字符串占位

在Python中,可以使用字符串的格式化方法来实现字符串的占位。常见的方法有百分号操作符 % 以及 str.format() 方法 百分号操作符 % name = "张三"age = 20message = "我叫%s,今年%d岁。" % (name, age)print(message) # 我叫张三,今年20岁。 str.format() 方法 name = "张三"age

一道经典Python程序样例带你飞速掌握Python的字典和列表

Python中的列表(list)和字典(dict)是两种常用的数据结构,它们在数据组织和存储方面有很大的不同。 列表(List) 列表是Python中的一种有序集合,可以随时添加和删除其中的元素。列表中的元素可以是任何数据类型,包括数字、字符串、其他列表等。列表使用方括号[]表示,元素之间用逗号,分隔。 定义和使用 # 定义一个列表 fruits = ['apple', 'banana

Python应用开发——30天学习Streamlit Python包进行APP的构建(9)

st.area_chart 显示区域图。 这是围绕 st.altair_chart 的语法糖。主要区别在于该命令使用数据自身的列和指数来计算图表的 Altair 规格。因此,在许多 "只需绘制此图 "的情况下,该命令更易于使用,但可定制性较差。 如果 st.area_chart 无法正确猜测数据规格,请尝试使用 st.altair_chart 指定所需的图表。 Function signa

python实现最简单循环神经网络(RNNs)

Recurrent Neural Networks(RNNs) 的模型: 上图中红色部分是输入向量。文本、单词、数据都是输入,在网络里都以向量的形式进行表示。 绿色部分是隐藏向量。是加工处理过程。 蓝色部分是输出向量。 python代码表示如下: rnn = RNN()y = rnn.step(x) # x为输入向量,y为输出向量 RNNs神经网络由神经元组成, python

python 喷泉码

因为要完成毕业设计,毕业设计做的是数据分发与传输的东西。在网络中数据容易丢失,所以我用fountain code做所发送数据包的数据恢复。fountain code属于有限域编码的一部分,有很广泛的应用。 我们日常生活中使用的二维码,就用到foutain code做数据恢复。你遮住二维码的四分之一,用手机的相机也照样能识别。你遮住的四分之一就相当于丢失的数据包。 为了实现并理解foutain

python 点滴学

1 python 里面tuple是无法改变的 tuple = (1,),计算tuple里面只有一个元素,也要加上逗号 2  1 毕业论文改 2 leetcode第一题做出来

Python爬虫-贝壳新房

前言 本文是该专栏的第32篇,后面会持续分享python爬虫干货知识,记得关注。 本文以某房网为例,如下图所示,采集对应城市的新房房源数据。具体实现思路和详细逻辑,笔者将在正文结合完整代码进行详细介绍。接下来,跟着笔者直接往下看正文详细内容。(附带完整代码) 正文 地址:aHR0cHM6Ly93aC5mYW5nLmtlLmNvbS9sb3VwYW4v 目标:采集对应城市的

百度OCR识别结构结构化处理视频

https://edu.csdn.net/course/detail/10506

python 在pycharm下能导入外面的模块,到terminal下就不能导入

项目结构如下,在ic2ctw.py 中导入util,在pycharm下不报错,但是到terminal下运行报错  File "deal_data/ic2ctw.py", line 3, in <module>     import util 解决方案: 暂时方案:在终端下:export PYTHONPATH=/Users/fujingling/PycharmProjects/PSENe

Docker启动异常

报错信息: failed to start daemon: Error initializing network controller: error creating default "bridge" network: cannot create network b8fd8c684f0ba865d4a13d36e5282fd694bbd37b243c7ec6c9cd29416db98d4b (d