Python入门(5):异常处理

news2025/4/3 2:49:39

目录

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"])  # 可能引发KeyError
    print(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 = email
        self.message = message
        super().__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 = code

def 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 / 0
    except 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 ve
    except RuntimeError as re:
        print(f"当前异常: {re}")
        print(f"原始异常: {re.__cause__}")

3.5  异常处理装饰器

from functools import wraps

def 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}")
                raise
        return wrapper
    return decorator

# 使用装饰器
import logging
logger = logging.getLogger(__name__)

@handle_errors(logger)
def risky_operation():
    """可能失败的操作"""
    raise ValueError("出错了!")

try:
    risky_operation()
except ValueError:
    print("操作失败已处理")

注意,良好的异常处理策略应该:

  1. 只捕获能处理的异常

  2. 保留原始异常信息

  3. 提供有意义的错误消息

  4. 适当记录错误日志

  5. 在适当的时候重新抛出异常

如果您觉得本文章对您有帮助,别忘了点赞、收藏加关注,更多干货内容将持续发布,您的支持就是作者更新最大的动力。本专栏将持续更新,有任何问题都可以在评论区讨论

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2326913.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Scala(三)

本节课学习了函数式编程&#xff0c;了解到它与Java、C函数式编程的区别&#xff1b;学习了函数的基础&#xff0c;了解到它的基本语法、函数和方法的定义、函数高级。。。学习到函数至简原则&#xff0c;高阶函数&#xff0c;匿名函数等。 函数的定义 函数基本语法 例子&…

什么是 Java 泛型

一、什么是 Java 泛型&#xff1f; 泛型&#xff08;Generics&#xff09; 是 Java 中一种强大的编程机制&#xff0c;允许在定义类、接口和方法时使用类型参数。通过泛型&#xff0c;可以将数据类型作为参数传递&#xff0c;从而实现代码的通用性和类型安全。 简单来说&…

Unity中根据文字数量自适应长宽的对话气泡框UI 会自动换行

使用Ugui制作一个可以根据文本数量自动调整宽度,并可以自动换行的文字UI 或者不要独立的Bg,那么一定要把bg的img设置成切片

【小也的Java之旅系列】02 分布式集群详解

文章目录 前言为什么叫小也 本系列适合什么样的人阅读正文单体优点缺点 CAP为什么CAP不可能全部满足&#xff1f;CAP 三选二 分布式事务分布式方案——SeataXA模式&#xff08;强一致&#xff09;AT模式&#xff08;自动补偿&#xff0c;默认模式&#xff09;TCC模式&#xff0…

Ubuntu里安装Jenkins

【方式1】&#xff1a;下载war包&#xff0c;直接运行&#xff0c;需提前搭建Java环境&#xff0c;要求11或17&#xff0c;不推荐&#xff0c;war包下载地址&#xff0c;将war包上传到服务器&#xff0c;直接使用命令启动 java -jar /data/jenkins/jenkins.war【方式2】&#…

C++包管理工具vcpkg的安装使用教程

前言 使用vcpkg可以更方便地安装各种库&#xff0c;省去配置的时间和配置失败的风险&#xff0c;类似python中的anaconda&#xff0c;懒人必备 参考 安装参考&#xff1a;https://bqcode.blog.csdn.net/article/details/135831901?fromshareblogdetail&sharetypeblogde…

微服务面试题:配置中心

&#x1f9d1; 博主简介&#xff1a;CSDN博客专家&#xff0c;历代文学网&#xff08;PC端可以访问&#xff1a;https://literature.sinhy.com/#/?__c1000&#xff0c;移动端可微信小程序搜索“历代文学”&#xff09;总架构师&#xff0c;15年工作经验&#xff0c;精通Java编…

Qt msvc2017程序无法用enigma vitrual box打包,用winrar打包

我们通常打包Qt程序用Enigma virtual box。这样我们的程序就可以在别的电脑上也能运行&#xff0c;但是有时候&#xff0c;我们发现Enigma virtual box在打包的时候&#xff0c;对于msvc2017需要编译的程序中引用webengineview模块&#xff0c;打包时候发现不能运行。 我们如何…

微服务集成测试 -华为OD机试真题(A卷、JavaScript)

题目描述 现在有n个容器服务&#xff0c;服务的启动可能有一定的依赖性&#xff08;有些服务启动没有依赖&#xff09;&#xff0c;其次&#xff0c;服务自身启动加载会消耗一些时间。 给你一个n n 的二维矩阵useTime&#xff0c;其中useTime[i][i]10表示服务i自身启动加载需…

Mac: 运行python读取CSV出现 permissionError

在MAC机器里&#xff0c;之前一直运行程序在某个指定的目录下读取excel和csv文件&#xff0c;没有出现错误&#xff0c;有一天突然出现错误&#xff1a;permissionError:[Errno 1] Operation not permitted&#xff0c; 具体错误信息如下&#xff1a; 经过调查得知&#xff0c…

UE5 学习笔记 FPS游戏制作30 显示击杀信息 水平框 UI模板(预制体)

文章目录 一制作单条死亡信息框水平框的使用创建一个水平框添加子元素调整子元素顺序子元素的布局插槽尺寸填充对齐 制作UI 根据队伍&#xff0c;设置文本的名字和颜色声明变量 将变量设置为构造参数根据队伍&#xff0c;设置文本的名字和颜色在构造事件中&#xff0c;获取玩家…

西门子TCP通讯过程中硬件连接突然断开

通信原理探秘又结合在工作中遇到的问题,关注到了通讯中的KeepAlive定时器的设置,所以做了如下实验。 硬件: 1513PLC TCP客户端 PC TCP服务器 前提条件:禁用PLC侧KeepAlive 程序: 测试流程: 打开PC端网络调试助手,设置为TCP服务器,打开链接; PC端打开WireShack软…

2025宁德时代测评Verify考什么?网申测评如何通过SHL笔试|附真题线上笔试考点、高分攻略、CATL新能源科技SHL测评宁德社招题目、面试攻略、求职建议

——职小豚 带你拆解新能源巨头招聘密码 一、宁德时代&#xff1a;新能源赛道「超级独角兽」 作为全球动力电池龙头&#xff0c;宁德时代&#xff08;CATL&#xff09;的江湖地位无需多言&#xff1a; 技术硬实力&#xff1a;麒麟电池、钠离子电池、无钴电池等黑科技加持&…

Spring Boot @RequestParam 解析参数时的常见问题及解决方案

1&#xff0c;遇到的问题&#xff1a;将后端接口写完后我想通过PostMan进行简单的测试一下&#xff0c;一不小心就遇到了这样的情况&#xff1a; org.springframework.web.bind.MissingServletRequestParameterException: Required Integer parameter contractId is not prese…

Firefox 浏览器同步一个账户和书签网址

Firefox 浏览器同步一个账户和书签网址 Firefox 支持跨设备接续浏览&#xff0c;可实现电脑、手机与平板无缝衔接。无论您在使用哪台设备上使用 Firefox&#xff0c;都能获取书签、浏览历史、保存的密码等信息。当然也能实现windows、ios、linux、android系统中安装firefox浏览…

Maven多模块项目,其他项目引用子模块的依赖,无法打包,提示没有找到依赖

背景&#xff1a; 微服务项目 每个服务都是单独的项目&#xff0c;会存在依赖关联的问题&#xff0c;在子模块的下面 depoly 之后&#xff0c;就会出现别的项目&#xff0c;无法package 原因&#xff1a; 多模块项目&#xff0c;depoly 需要在父模块下面执行

mediacodec服务启动时加载media_codecs.xml

media.codec服务启动时&#xff0c; 会创建 implementation::Omx 和 implementation::OmxStore&#xff0c; 构造 Omx时&#xff0c; 会解析codec相关的xml文件&#xff0c;一般从会如下目录中&#xff0c; // from getDefaultSearchDirs() { "/product/etc",&quo…

本地部署DeepSeek-R1(Dify压力测试和性能调优)

安装压测软件 为了有效测试&#xff0c;应在局域网设备测试&#xff0c;我这里用的服务器是局域网内的Ubuntu&#xff0c;下载的压测软件是WRK apt install wrk测试脚本 为了省事我直接在/root目录下新建lua脚本 vim test.lua脚本内容如下&#xff0c;app-xxxx更换为你工作…

自动备份文件到服务器,自动备份文件到服务器有哪些方法?

将SQL Server数据库自动备份文件到服务器&#xff0c;可以通过多种方法实现。以下是几种常用的方法&#xff1a; 一、使用SQL Server Management Studio&#xff08;SSMS&#xff09;和SQL Server代理 配置SQL Server代理&#xff1a;确保SQL Server代理服务已启动。如果未启…

Ollama+open-webui搭建私有本地大模型详细教程

Ollamaopen-webui搭建私有本地大模型详细教程 1. 什么是 Ollama&#xff1f; 1.1. Ollama 简介 ​ Ollama 是一个轻量级的 AI 模型运行时&#xff0c;专注于简化 AI 模型的部署和使用。它支持多种预训练模型&#xff08;如 Llama、Vicuna、Dolly 等&#xff09;&#xff0c;…