Python入门(5):异常处理
目录
1 异常处理基础概念
1.1 什么是异常?
1.2 异常与错误的区别
2 异常处理基础
2.1 常见内置异常类型
2.2 try-except 基本结构
2.3 捕获多个异常
2.4 抛出异常
2.4.1 使用raise语句
2.4.2 自定义异常类
3 高级异常处理技巧
3.1 不要过度捕获异常
3.2 使用上下文管理器(with语句)
3.3 记录异常信息
3.4 异常链(Exception Chaining)
3.5 异常处理装饰器
1 异常处理基础概念
1.1 什么是异常?
异常处理是Python编程中至关重要的部分,它帮助我们优雅地处理程序运行时可能出现的错误情况。
在Python中,异常是指程序执行过程中发生的意外情况,它会中断正常的程序流程。当Python遇到无法正常处理的情况时,会抛出(raise)一个异常。
# 基本异常示例
try:result = 10 / 0 # 这会引发ZeroDivisionError
except ZeroDivisionError:print("不能除以零!")
1.2 异常与错误的区别
-
语法错误(Syntax Error):代码不符合Python语法规则,程序无法运行
-
异常(Exception):程序运行时发生的意外情况,可以被捕获和处理
2 异常处理基础
2.1 常见内置异常类型
| 异常类型 | 触发场景 |
|---|---|
SyntaxError | 语法错误 |
IndentationError | 缩进错误 |
NameError | 访问未定义变量 |
TypeError | 类型操作不当 |
ValueError | 值无效或不合法 |
IndexError | 序列索引超出范围 |
KeyError | 字典键不存在 |
AttributeError | 对象没有该属性 |
IOError/OSError | 输入/输出操作失败 |
ImportError | 导入模块失败 |
ZeroDivisionError | 除数为零 |
FileNotFoundError | 文件不存在 |
2.2 try-except 基本结构
try:# 可能引发异常的代码result = 10 / 0
except ZeroDivisionError:# 处理特定异常print("不能除以零!")
except (TypeError, ValueError) as e:# 处理多种异常print(f"类型或值错误: {e}")
except Exception as e:# 捕获所有其他异常print(f"发生未知错误: {e}")
else:# 没有异常发生时执行print("一切正常!")
finally:# 无论是否发生异常都会执行print("清理工作完成")
2.3 捕获多个异常
try:# 可能引发多种异常的代码data = {"key": "value"}print(data["missing_key"]) # 可能引发KeyErrorprint(10 / 0) # 可能引发ZeroDivisionError
except (KeyError, ZeroDivisionError) as e:print(f"捕获到异常: {type(e).__name__}")
2.4 抛出异常
2.4.1 使用raise语句
def validate_age(age):if age < 0:raise ValueError("年龄不能为负数")if age > 120:raise ValueError("年龄不合理")try:validate_age(-5)
except ValueError as e:print(f"验证失败: {e}")
2.4.2 自定义异常类
示例1:
class InvalidEmailError(Exception):"""自定义异常类表示无效邮箱"""def __init__(self, email, message="无效的邮箱地址"):self.email = emailself.message = messagesuper().__init__(f"{message}: {email}")def send_email(email):if "@" not in email:raise InvalidEmailError(email)try:send_email("invalid.email")
except InvalidEmailError as e:print(e)
示例2:
class MyCustomError(Exception):"""自定义异常类"""def __init__(self, message, code):super().__init__(message)self.code = codedef validate_age(age):if age < 0:raise MyCustomError("年龄不能为负数", 400)elif age > 120:raise MyCustomError("年龄不现实", 400)try:validate_age(-5)
except MyCustomError as e:print(f"错误代码 {e.code}: {e}")
3 高级异常处理技巧
3.1 不要过度捕获异常
# 不好的做法 - 捕获过于宽泛的异常
try:do_something()
except:pass# 好的做法 - 只捕获预期的异常
try:do_something()
except ExpectedError:handle_error()
3.2 使用上下文管理器(with语句)
# 自动处理资源释放
try:with open("data.txt", "r") as f:content = f.read()
except IOError as e:print(f"文件操作失败: {e}")
3.3 记录异常信息
import logging
logging.basicConfig(filename="app.log", level=logging.ERROR)def critical_operation():try:1 / 0except Exception as e:logging.exception("操作失败") # 记录完整堆栈跟踪raise # 重新抛出异常try:critical_operation()
except Exception:print("操作失败,请查看日志")
3.4 异常链(Exception Chaining)
try:# 原始异常raise ValueError("原始错误")
except ValueError as ve:try:# 处理时引发新异常raise RuntimeError("处理错误") from veexcept RuntimeError as re:print(f"当前异常: {re}")print(f"原始异常: {re.__cause__}")
3.5 异常处理装饰器
from functools import wrapsdef handle_errors(logger):"""异常处理装饰器工厂"""def decorator(func):@wraps(func)def wrapper(*args, **kwargs):try:return func(*args, **kwargs)except Exception as e:logger.error(f"{func.__name__} 失败: {e}")raisereturn wrapperreturn decorator# 使用装饰器
import logging
logger = logging.getLogger(__name__)@handle_errors(logger)
def risky_operation():"""可能失败的操作"""raise ValueError("出错了!")try:risky_operation()
except ValueError:print("操作失败已处理")
注意,良好的异常处理策略应该:
-
只捕获能处理的异常
-
保留原始异常信息
-
提供有意义的错误消息
-
适当记录错误日志
-
在适当的时候重新抛出异常
如果您觉得本文章对您有帮助,别忘了点赞、收藏加关注,更多干货内容将持续发布,您的支持就是作者更新最大的动力。本专栏将持续更新,有任何问题都可以在评论区讨论
相关文章:
Python入门(5):异常处理
目录 1 异常处理基础概念 1.1 什么是异常? 1.2 异常与错误的区别 2 异常处理基础 2.1 常见内置异常类型 2.2 try-except 基本结构 2.3 捕获多个异常 2.4 抛出异常 2.4.1 使用raise语句 2.4.2 自定义异常类 3 高级异常处理技巧 3.1 不要过度捕…...
Scala(三)
本节课学习了函数式编程,了解到它与Java、C函数式编程的区别;学习了函数的基础,了解到它的基本语法、函数和方法的定义、函数高级。。。学习到函数至简原则,高阶函数,匿名函数等。 函数的定义 函数基本语法 例子&…...
什么是 Java 泛型
一、什么是 Java 泛型? 泛型(Generics) 是 Java 中一种强大的编程机制,允许在定义类、接口和方法时使用类型参数。通过泛型,可以将数据类型作为参数传递,从而实现代码的通用性和类型安全。 简单来说&…...
Unity中根据文字数量自适应长宽的对话气泡框UI 会自动换行
使用Ugui制作一个可以根据文本数量自动调整宽度,并可以自动换行的文字UI 或者不要独立的Bg,那么一定要把bg的img设置成切片...
【小也的Java之旅系列】02 分布式集群详解
文章目录 前言为什么叫小也 本系列适合什么样的人阅读正文单体优点缺点 CAP为什么CAP不可能全部满足?CAP 三选二 分布式事务分布式方案——SeataXA模式(强一致)AT模式(自动补偿,默认模式)TCC模式࿰…...
Ubuntu里安装Jenkins
【方式1】:下载war包,直接运行,需提前搭建Java环境,要求11或17,不推荐,war包下载地址,将war包上传到服务器,直接使用命令启动 java -jar /data/jenkins/jenkins.war【方式2】&#…...
C++包管理工具vcpkg的安装使用教程
前言 使用vcpkg可以更方便地安装各种库,省去配置的时间和配置失败的风险,类似python中的anaconda,懒人必备 参考 安装参考:https://bqcode.blog.csdn.net/article/details/135831901?fromshareblogdetail&sharetypeblogde…...
微服务面试题:配置中心
🧑 博主简介:CSDN博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/?__c1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,精通Java编…...
Qt msvc2017程序无法用enigma vitrual box打包,用winrar打包
我们通常打包Qt程序用Enigma virtual box。这样我们的程序就可以在别的电脑上也能运行,但是有时候,我们发现Enigma virtual box在打包的时候,对于msvc2017需要编译的程序中引用webengineview模块,打包时候发现不能运行。 我们如何…...
微服务集成测试 -华为OD机试真题(A卷、JavaScript)
题目描述 现在有n个容器服务,服务的启动可能有一定的依赖性(有些服务启动没有依赖),其次,服务自身启动加载会消耗一些时间。 给你一个n n 的二维矩阵useTime,其中useTime[i][i]10表示服务i自身启动加载需…...
Springboot实战:如何用Docker和Kubernetes部署微服务
前言 随着微服务架构的普及,如何高效部署和管理这些分布式服务成为了开发者面临的重要挑战。Spring Boot凭借其简化配置、快速开发的特性,成为了构建微服务的理想框架;而Docker和Kubernetes则分别解决了服务的容器化和编排问题。本文将详细介…...
Mac: 运行python读取CSV出现 permissionError
在MAC机器里,之前一直运行程序在某个指定的目录下读取excel和csv文件,没有出现错误,有一天突然出现错误:permissionError:[Errno 1] Operation not permitted, 具体错误信息如下: 经过调查得知,…...
UE5 学习笔记 FPS游戏制作30 显示击杀信息 水平框 UI模板(预制体)
文章目录 一制作单条死亡信息框水平框的使用创建一个水平框添加子元素调整子元素顺序子元素的布局插槽尺寸填充对齐 制作UI 根据队伍,设置文本的名字和颜色声明变量 将变量设置为构造参数根据队伍,设置文本的名字和颜色在构造事件中,获取玩家…...
西门子TCP通讯过程中硬件连接突然断开
通信原理探秘又结合在工作中遇到的问题,关注到了通讯中的KeepAlive定时器的设置,所以做了如下实验。 硬件: 1513PLC TCP客户端 PC TCP服务器 前提条件:禁用PLC侧KeepAlive 程序: 测试流程: 打开PC端网络调试助手,设置为TCP服务器,打开链接; PC端打开WireShack软…...
Android学习总结之算法篇三(打家劫舍)
打家劫舍一 // 动态规划 class Solution {public int rob(int[] nums) {if (nums null || nums.length 0) return 0;if (nums.length 1) return nums[0];int[] dp new int[nums.length];dp[0] nums[0];dp[1] Math.max(dp[0], nums[1]);for (int i 2; i < nums.lengt…...
【蓝桥杯】单片机设计与开发,速成备赛
一、LED模块开看,到大模板 二、刷第零讲题目(直接复制模板) 三、空降芯片模板直接调用部分(听完再敲代码) 四、第十三讲开刷省赛题(开始自己背敲模板) 五、考前串讲刷一遍 b连接࿱…...
【操作系统】Linux进程管理和调试
在 Linux 中,可以通过以下方法查看 PID(进程ID)对应的进程名称和详细信息: 1. 使用 ps 命令(最直接) ps -p <PID> -o pid,comm,cmd示例: ps -p 1234 -o pid,comm,cmd输出: P…...
2025宁德时代测评Verify考什么?网申测评如何通过SHL笔试|附真题线上笔试考点、高分攻略、CATL新能源科技SHL测评宁德社招题目、面试攻略、求职建议
——职小豚 带你拆解新能源巨头招聘密码 一、宁德时代:新能源赛道「超级独角兽」 作为全球动力电池龙头,宁德时代(CATL)的江湖地位无需多言: 技术硬实力:麒麟电池、钠离子电池、无钴电池等黑科技加持&…...
基于 Ollama DeepSeek、Dify RAG 和 Fay 框架的高考咨询 AI 交互系统项目方案
基于 Ollama DeepSeek、Dify RAG 和 Fay 框架的高考咨询 AI 交互系统 一、项目概述 本项目旨在构建一个智能化的高考咨询助手,结合 AI 大模型、知识增强(RAG)和 3D 数字人交互,为用户提供智能高考问答、志愿填报建议、政策解读等…...
【 Vue 2 中的 Mixins 模式】
Vue 2 中的 Mixins 模式 在 Vue 2 里,mixins 是一种灵活的复用代码的方式,它能让你在多个组件间共享代码。借助 mixins,你可以把一些通用的选项(像 data、methods、computed 等)封装到一个对象里,然后在多…...
Spring Boot @RequestParam 解析参数时的常见问题及解决方案
1,遇到的问题:将后端接口写完后我想通过PostMan进行简单的测试一下,一不小心就遇到了这样的情况: org.springframework.web.bind.MissingServletRequestParameterException: Required Integer parameter contractId is not prese…...
linux xargs命令学习
命令描述 xargs从标准输入中读取默认以空格分隔的项(可以使用双引号保护空格)(或单引号或反斜杠)或换行符,并执行命令(默认为/bin/echo)一次或多次,后面跟着任何初始参数从标准输入中…...
Firefox 浏览器同步一个账户和书签网址
Firefox 浏览器同步一个账户和书签网址 Firefox 支持跨设备接续浏览,可实现电脑、手机与平板无缝衔接。无论您在使用哪台设备上使用 Firefox,都能获取书签、浏览历史、保存的密码等信息。当然也能实现windows、ios、linux、android系统中安装firefox浏览…...
Maven多模块项目,其他项目引用子模块的依赖,无法打包,提示没有找到依赖
背景: 微服务项目 每个服务都是单独的项目,会存在依赖关联的问题,在子模块的下面 depoly 之后,就会出现别的项目,无法package 原因: 多模块项目,depoly 需要在父模块下面执行...
mediacodec服务启动时加载media_codecs.xml
media.codec服务启动时, 会创建 implementation::Omx 和 implementation::OmxStore, 构造 Omx时, 会解析codec相关的xml文件,一般从会如下目录中, // from getDefaultSearchDirs() { "/product/etc",&quo…...
本地部署DeepSeek-R1(Dify压力测试和性能调优)
安装压测软件 为了有效测试,应在局域网设备测试,我这里用的服务器是局域网内的Ubuntu,下载的压测软件是WRK apt install wrk测试脚本 为了省事我直接在/root目录下新建lua脚本 vim test.lua脚本内容如下,app-xxxx更换为你工作…...
自动备份文件到服务器,自动备份文件到服务器有哪些方法?
将SQL Server数据库自动备份文件到服务器,可以通过多种方法实现。以下是几种常用的方法: 一、使用SQL Server Management Studio(SSMS)和SQL Server代理 配置SQL Server代理:确保SQL Server代理服务已启动。如果未启…...
Ollama+open-webui搭建私有本地大模型详细教程
Ollamaopen-webui搭建私有本地大模型详细教程 1. 什么是 Ollama? 1.1. Ollama 简介 Ollama 是一个轻量级的 AI 模型运行时,专注于简化 AI 模型的部署和使用。它支持多种预训练模型(如 Llama、Vicuna、Dolly 等),…...
电销行业机器人外呼话术设计:关键注意事项与实践指南
随着人工智能技术的普及,电话营销行业(电销)逐渐引入智能外呼机器人以提升效率、降低成本。然而,机器人外呼的实际效果高度依赖话术设计的合理性。若话术生硬、缺乏策略,不仅可能导致客户反感,还可能引发合…...
GPT-4o 原生图像生成技术解析:从模型架构到吉卜力梦境的实现
最近不少 AI 爱好者、设计师、Vlogger 在社交平台晒出了 GPT-4o 生成的梦幻图像,尤其是吉卜力风格的作品——柔和光影、日系构图、治愈色彩、富有情感的角色表达,一下子击中了无数人的“童年回忆 审美舒适区”。 🎨 下面是一些 GPT-4o 实际生…...
