百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python的异常处理机制

off999 2024-11-19 08:35 33 浏览 0 评论

Python的异常处理机制非常强大,提供了灵活的错误捕捉和处理方式。正确使用这些结构可以使得程序更加健壮和易于维护。在实际编程中,合理地组织try-except-else-finally结构,可以优雅地解决很多潜在的运行时问题,提高程序的稳定性和用户的体验。

Python标准异常类

Python中的所有异常都是从一个名为 BaseException 的基类派生出来的。在此基类下有几个重要的子类如 Exception,它是几乎所有编程异常的基类。下面是一些常见的标准异常类及其用途:

  • Exception:几乎所有的错误类型都是从它派生的。
  • AttributeError:当属性引用或赋值失败时抛出。
  • IOError:当输入/输出操作失败时抛出,如打开文件。
  • ImportError:无法导入模块或包;通常是路径问题或名称错误。
  • IndexError:在使用序列中不存在的索引时抛出

内置异常的类层级结构如下:

BaseException
 ├── BaseExceptionGroup
 ├── GeneratorExit
 ├── KeyboardInterrupt
 ├── SystemExit
 └── Exception
      ├── ArithmeticError
      │    ├── FloatingPointError
      │    ├── OverflowError
      │    └── ZeroDivisionError
      ├── AssertionError
      ├── AttributeError
      ├── BufferError
      ├── EOFError
      ├── ExceptionGroup [BaseExceptionGroup]
      ├── ImportError
      │    └── ModuleNotFoundError
      ├── LookupError
      │    ├── IndexError
      │    └── KeyError
      ├── MemoryError
      ├── NameError
      │    └── UnboundLocalError
      ├── OSError
      │    ├── BlockingIOError
      │    ├── ChildProcessError
      │    ├── ConnectionError
      │    │    ├── BrokenPipeError
      │    │    ├── ConnectionAbortedError
      │    │    ├── ConnectionRefusedError
      │    │    └── ConnectionResetError
      │    ├── FileExistsError
      │    ├── FileNotFoundError
      │    ├── InterruptedError
      │    ├── IsADirectoryError
      │    ├── NotADirectoryError
      │    ├── PermissionError
      │    ├── ProcessLookupError
      │    └── TimeoutError
      ├── ReferenceError
      ├── RuntimeError
      │    ├── NotImplementedError
      │    └── RecursionError
      ├── StopAsyncIteration
      ├── StopIteration
      ├── SyntaxError
      │    └── IndentationError
      │         └── TabError
      ├── SystemError
      ├── TypeError
      ├── ValueError
      │    └── UnicodeError
      │         ├── UnicodeDecodeError
      │         ├── UnicodeEncodeError
      │         └── UnicodeTranslateError
      └── Warning
           ├── BytesWarning
           ├── DeprecationWarning
           ├── EncodingWarning
           ├── FutureWarning
           ├── ImportWarning
           ├── PendingDeprecationWarning
           ├── ResourceWarning
           ├── RuntimeWarning
           ├── SyntaxWarning
           ├── UnicodeWarning
           └── UserWarning

自定义异常

开发者可以通过创建一个继承自 Exception(或其子类)的新类来定义自己的异常。自定义异常通常用于处理程序特定的问题,当Python的标准异常不足以描述发生的错误时。的实现关键是继承自 Exception 类或其任何子类,并通常不需要添加任何额外的方法,可以添加所需的属性来帮助错误处理。

一个简单的自定义异常

MyError 类继承自 Exception 类,接收一个参数 value,该参数可以在抛出异常时提供额外的错误信息。

class MyError(Exception):
    """基类为Exception的自定义异常类"""
    def __init__(self, value):
        self.value = value
    def __str__(self):
        return repr(self.value)

异常处理结构

Python的异常处理结构基于几个关键的关键字:try, except, else, finally, 和 raise。


try块允许你测试一个代码块的错误,except块让你处理错误:

try:
    # 尝试执行的代码
    result = 10 / 0
except ZeroDivisionError:
    # 如果在try块中抛出ZeroDivisionError,则执行这个块
    print("除数不能为零")

可以定义多个except子句来捕获不同类型的异常:

try:
    # 尝试执行的代码
    result = 10 / int("a")
except ZeroDivisionError:
    # 处理除零错误
    print("除数不能为零")
except ValueError:
    # 处理值错误
    print("输入值错误")

一个except子句可以同时处理多个异常,这可以用一个元组来完成:

try:
    # 尝试执行的代码
    result = 10 / int("a")
except (ZeroDivisionError, ValueError) as e:
    print("发生了一个错误:", e)

想捕获所有类型的错误,可以使用Exception来捕获所有的异常:

try:
    # 尝试执行的代码
    result = 10 / int("a")
except Exception as e:
    print("发生异常:", e)

如果try块没有引发异常,则可以选择性地执行一些代码,这可以使用else子句:

try:
    # 尝试执行的代码
    result = 10 / 2
except ZeroDivisionError:
    print("除数不能为零")
else:
    print("没有发生错误")

无论是否有异常抛出finally块都会被执行。这对于执行清理工作是非常有用的,如关闭文件或释放资源:

try:
    f = open("myfile.txt")
    line = f.readline()
    result = int(line.strip())
finally:
    f.close()
    print("文件已关闭")

使用raise语句可以抛出一个指定的异常。这可以用于抛出自定义的异常,或者在捕获异常后重新抛出(可能是为了上层调用者处理):

try:
    result = 10 / 0
except ZeroDivisionError:
    print("除数不能为零")
    raise  # 重新抛出当前异常


javalang代码库的异常示例

class JavaParserBaseException(Exception):
    def __init__(self, message=''):
        super(JavaParserBaseException, self).__init__(message)
  • 作用:这是一个基础异常类,用于所有Java解析器相关的异常。它继承自Python内置的Exception类,因此它是一个标准的异常类。JavaSyntaxError继承自JavaParserBaseException
  • 构造器 (__init__方法):接收一个可选参数message,默认为空字符串。通过super()调用父类(Exception类)的构造器,传递message参数。这样,异常对象就会包含这个错误消息,当抛出异常时,可以显示或记录这个消息。
class JavaSyntaxError(JavaParserBaseException):
    def __init__(self, description, at=None):
        super(JavaSyntaxError, self).__init__()
        self.description = description
        self.at = at
    def __str__(self):
        return self.description+' tokenvalue:'+self.at.value+' position:'+str(self.at.position[0])+','+str(self.at.position[1])
  • 作用:这是一个更具体的异常类,用于表示语法错误。它继承自JavaParserBaseException,说明它是特定于Java解析错误的。
  • 构造器 (__init__方法):description:一个字符串,描述错误的详情。at:一个可选参数,默认为None。这个参数预期是一个对象,包含有关错误位置的具体信息(如tokenvalue和position)。在调用父类的构造器后,将description和at保存为实例变量。注意,这里父类构造器没有接收任何传递的信息,这意味着JavaSyntaxError主要通过自定义的__str__方法来提供错误信息。
  • 字符串表达式 (__str__方法):当尝试将这个异常转换为字符串(例如在打印异常时),__str__方法会被调用。这个方法返回的字符串包括错误描述(description),错误位置的具体信息(at.value和at.position)。这样设计是为了让异常的输出更加详细,方便开发者定位问题。

自定义异常可以使用 raise 语句抛出,类似于任何其他的异常使用方式。

raise JavaSyntaxError(description, at)

结果输出如下

javalang.parser.JavaSyntaxError: Expected type declaration tokenvalue:import position:88,1

相关推荐

Kubernetes 核心概念全景图:Pod、Node、Cluster、Control Plane 等

想真正读懂Kubernetes的底层运作,你必须理解它的“权力架构”。Pod是什么?Node是什么?ControlPlane又是做什么的?它们之间有什么关系?怎么协同工作?本篇带你构建一个...

Helm 实战:用 Helm 部署一个 Nginx 应用

这一篇,我们将动手实战:用Helm从零部署一个Nginx应用,并掌握HelmChart的结构和参数化技巧。一、准备环境在开始之前,你需要确保环境中具备以下工具:已部署的Kubernet...

从零开始:如何在 Linux 上搭建 Nginx + Node.js 高性能 Web 服务

在现代互联网服务架构中,Nginx+Node.js已成为轻量级、高性能网站的首选组合。本文将带你从零开始,一步步搭建一个高并发、高可用的Web服务平台,让新手也能轻松掌握生产级部署思路。一、...

NetBox 最新版 4.4.1 完整安装指南

NetBox最新版4.4.1完整安装指南(修正版)by大牛蛙1.系统准备#关闭SELinux和防火墙(仅测试环境)systemctldisable--nowfirewalldse...

Termux 安装 linux 宝塔面板,搭建 Nginx+PHP+Mysql web 网站环境

Termux安装linux宝塔面板,搭建Nginx+PHP+Mysqlweb服务环境,解决启动故障奶妈级教程1.到宝塔面板官网:https://www.bt.cn/new/download...

OpenEuler系统安装Nginx安装配置_openwrt安装nginx

NginxWEB安装时可以指定很多的模块,默认需要安装Rewrite模块,也即是需要系统有PCRE库,安装Pcre支持Rewrite功能。如下为安装NginxWEB服务器方法:源码的路径,而不是编...

多级缓存架构实战:从OpenResty到Redis,打造毫秒级响应系统

在传统的Web架构中,当用户发起请求时,应用通常会直接查询数据库。这种模式在低并发场景下尚可工作,但当流量激增时,数据库很容易成为性能瓶颈。多级缓存通过在数据路径的不同层级设置缓存,可以显著降低数据库...

如何使用 Nginx 缓存提高网站性能 ?

快速加载的站点提供了更好的用户体验并且可以拥有更高的搜索引擎排名。通过Nginx缓存提高你的网站性能是一个有效的方法。Nginx是一个流行的开源web服务器,也可以作为web服务器反向代...

如何构建企业级Docker Registry Server

很多人问我,虚拟机镜像和docker镜像的区别是什么?其实区别非常明显,我们可以通过阅读Dockerfile文件就可以知道这个镜像都做了哪些操作,能提供什么服务;但通过虚拟机镜像,你能一眼看出来虚拟机...

如何解决局域网SSL证书问题?使用mkcert证书生成工具轻松搞定

“局域网里弹出‘不安全’红锁,老板就在身后盯着演示,那一刻只想原地消失。”别笑,九成前端都经历过。自签证书被Chrome标红,客户以为网站被黑,其实只是缺一张被信任的证。mkcert把这事从半小时缩到...

Docker 安全与权限控制:别让你的容器变成“漏洞盒子”

在享受容器带来的轻量与灵活的同时,我们也必须面对一个现实问题:安全隐患。容器并不是天然安全,错误配置甚至可能让攻击者“越狱”入侵主机!本篇将带你从多个层面强化Docker的安全防护,构建真正可放心...

Kubernetes生产级管理指南(2025版)

在云原生技术持续演进的2025年,Kubernetes已成为企业数字化转型的核心引擎。然而,生产环境中的集群管理仍面临基础设施配置、安全漏洞、运维复杂度攀升等挑战。本文将结合最新行业实践,从基础设施即...

云原生工程师日常使用最多的工具和100条高频命令

在云原生时代,工程师不仅要熟悉容器化、编排和服务网格,还要掌握大量工具和命令来进行日常运维与开发。本文将从工具篇和命令篇两个角度,详细介绍云原生工程师每天都会用到的核心技能。一、云原生工程师常...

用 Jenkins 实现自动化 CI/CD_jenkins api自动执行

场景设定(可替换为你的技术栈)语言:Node.js(示例简单,任何语言思路一致)制品:Docker镜像(推送到DockerHub/Harbor)运行环境:Kubernetes(staging...

5款好用开源云笔记虚拟主机部署项目推荐

在个人数据管理与协同办公场景中,开源云笔记项目凭借可自主部署、数据可控的优势,成为众多用户的首选。以下推荐5款适配虚拟主机部署、功能完善的开源项目,附核心特性与部署要点,助力快速搭建专属云笔记系统。...

取消回复欢迎 发表评论: