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

[oeasy]python066_如何捕获多个异常_try_否则_else_exception

ztj100 2025-03-01 16:10 7 浏览 0 评论

如何捕获多个异常_try_否则_else_exception

回忆上次内容

  • 上次学习了
    • try
    • except
  • try着 尝试着 运行
    • 一旦发现了 错误
      • 就 终止 try中的执行
    • 直接跳转到
      • except块
  • 注意要点
  • 半角冒号
  • 缩进
  • 错误信息输出
  • 有错 就报
    • 不要 忽略、隐瞒
    • 否则 找不到 出错位置
  • 究竟 应该如何理解
    • try...except...呢?

查询帮助

help("try")
  • 细节
  • try...
    • except...
  • 之后 还可以跟一个
    • else...

先回忆try

  • 如果try中
    • 发现了异常
    • 就立刻 从发现错误的 位置
      • 跳出来
    • 执行except 部分

后else

  • else 是一个可选(optional)子句
  • 如果try中
    • 从始至终没有发现异常
    • 在执行完try中的所有内容 之后
    • 运行 else 部分

举个例子

  • 这里的参数"abc"
    • 是无法转化为整型数字的
      • 会抛出ValueError
      • 跳出try子句
try:
    i = int("abc")
except ValueError:
    print("Exception is found!")
else:
    print("Nothing Wrong")
  • 会进入except子句
    • 输出 发现异常
  • 然后跳过else子句
    • 那什么时候
    • 进入else子句呢?

例子更新

  • 将int函数的参数
    • 从abc修改为123
try:
    i = int("123")
except ValueError:
    print("Exception is found!")
else:
    print("Nothing Wrong")
  • 字符串"123"
    • 是 可以转化为整型数字的
    • 整个try部分
    • 都执行完毕
    • 没有抛出任何异常
  • 跳过
    • except子句
  • 直接进入
    • else子句
    • 执行输出 Nothing Wrong!
  • else的意思是否则
    • 是没发现异常时 才执行的
  • 具体都有 什么类型的 异常呢?

不同类型的error

  • 比如 下图
    • 就是 除数不能为零的 错误
    • ZeroDivisionError
    • 命名惯例 为 帕斯卡(大驼峰)
    • PascalCase Naming Convention
  • 如果不try
    • 会抛出ZeroDivisionError
  • 如果try了
    • 但没有捕捉这个错误呢?

没捉到

try:
    i = int("123")
    j = i / 0
except ValueError:
    print("Exception is found!")
else:
    print("Nothing Wrong")
  • 有错误
    • 但是 抓的方法不对
  • 怎么 捕获这个错误?

尝试捕获

  • except 不同的 Error
    • 会 捕获到 不同类型的 错误
    • 进行 不同 方式的 处理
try:
    i = int("123")
    j = i / 0
    print("this line never excute! ")
except ValueError:
    print(ValueError)
except ZeroDivisionError:
    print(ZeroDivisionError)
else:
    print("Nothing Wrong")
  • 尝试捕获 前两种类型的Error
    • ValueError
    • ZeroDivisionError
  • 各报各的错

尝试调试

  • 调试当前文件
:w|!pdb3 %
  • 第2行 运行没有毛病
  • 执行第3句的时候
    • 抛出除数不能为零错误
    • 进行 错误排查

错误判断

  • 根据 错误类型 排查
  • j = i / 0
    • 错误类型为 除数不能为零
    • ZeroDivisionError
  • 第4行 except ValueError
    • 类型不对
    • 跳过

继续错误判断

  • 第6行 except ZeroDivisionError
    • 类型正确
    • 进入子句

短路作用

  • 前面的异常处理
    • 会短路后面的异常处理
    • 只处理一次就行了
  • 为什么 要弄这么多
    • 错误排查 呢?
    • 是 没事找事 吗??

异常处理

  • 异常 随时 可能发生

想要

结果

打开 文件

文件不存在

访问 网址

服务器断网

读写 数据库

服务器关闭

  • 预测 可能出现的异常
    • 并且 有预案 进行处理
    • 运行时 才能 安稳放心
  • 如果 没有相应的 预案
    • 会如何呢?

没有捕获到指定的错误

  • 上来就找不到a
    • 抛出NameError
try:
    a
    i = int("123")
    j = i / 0
except ValueError:
    print(ValueError)
except ZeroDivisionError:
    print(ZeroDivisionError)
else:
    print("Nothing Wrong")
  • 给定的两种 Error类型
    • 都处理不了 NameError
  • 遍历了 所有处理方式之后
    • Error 依然 无法处理

兜底

  • 最后 都处理不了
    • 相当于 没处理
    • 把 NameError 上交
    • 抛给系统
    • 告知用户
  • 有 通用错误类型 吗?
    • 兜住 所有错误 那种?

总结

  • 我们了解了 try 的细节
    • try
      • 尝试运行
    • except
      • 发现异常时运行的代码块
    • else
      • 没有发现异常时运行的代码块
  • 注意!
    • 都要有英文半角的冒号
    • 子句都要通过 4 个字符的缩进控制范围
  • 错误类型太多了
    • 有 通用错误类型 吗?
    • 能兜住 所有错误 那种?
  • 我们下次再说!
  • 蓝桥->https://www.lanqiao.cn/courses/3584
  • github->https://github.com/overmind1980/oeasy-python-tutorial
  • gitee->https://gitee.com/overmind1980/oeasypython

相关推荐

告别手动操作:一键多工作表合并的实用方法

通常情况下,我们需要将同一工作簿内不同工作表中的数据进行合并处理。如何快速有效地完成这些数据的整合呢?这主要取决于需要合并的源数据的结构。...

【MySQL技术专题】「优化技术系列」常用SQL的优化方案和技术思路

概述前面我们介绍了MySQL中怎么样通过索引来优化查询。日常开发中,除了使用查询外,我们还会使用一些其他的常用SQL,比如INSERT、GROUPBY等。对于这些SQL语句,我们该怎么样进行优化呢...

9.7寸视网膜屏原道M9i双系统安装教程

泡泡网平板电脑频道4月17日原道M9i采用Win8安卓双系统,对于喜欢折腾的朋友来说,刷机成了一件难事,那么原道M9i如何刷机呢?下面通过详细地图文,介绍原道M9i的刷机操作过程,在刷机的过程中,要...

如何做好分布式任务调度——Scheduler 的一些探索

作者:张宇轩,章逸,曾丹初识Scheduler找准定位:分布式任务调度平台...

mysqldump备份操作大全及相关参数详解

mysqldump简介mysqldump是用于转储MySQL数据库的实用程序,通常我们用来迁移和备份数据库;它自带的功能参数非常多,文中列举出几乎所有常用的导出操作方法,在文章末尾将所有的参数详细说明...

大厂面试冲刺,Java“实战”问题三连,你碰到了哪个?

推荐学习...

亿级分库分表,如何丝滑扩容、如何双写灰度

以下是基于亿级分库分表丝滑扩容与双写灰度设计方案,结合架构图与核心流程说明:一、总体设计目标...

MYSQL表设计规范(mysql表设计原则)

日常工作总结,不是通用规范一、表设计库名、表名、字段名必须使用小写字母,“_”分割。...

怎么解决MySQL中的Duplicate entry错误?

在使用MySQL数据库时,我们经常会遇到Duplicateentry错误,这是由于插入或更新数据时出现了重复的唯一键值。这种错误可能会导致数据的不一致性和完整性问题。为了解决这个问题,我们可以采取以...

高并发下如何防重?(高并发如何防止重复)

前言最近测试给我提了一个bug,说我之前提供的一个批量复制商品的接口,产生了重复的商品数据。...

性能压测数据告诉你MySQL和MariaDB该怎么选

1.压测环境为了尽可能的客观公正,本次选择同一物理机上的两台虚拟机,一台用作数据库服务器,一台用作运行压测工具mysqlslap,操作系统均为UbuntuServer22.04LTS。...

屠龙之技 --sql注入 不值得浪费超过十天 实战中sqlmap--lv 3通杀全国

MySQL小结发表于2020-09-21分类于知识整理阅读次数:本文字数:67k阅读时长≈1:01...

破防了,谁懂啊家人们:记一次 mysql 问题排查

作者:温粥一、前言谁懂啊家人们,作为一名java开发,原来以为mysql这东西,写写CRUD,不是有手就行吗;你说DDL啊,不就是设计个表结构,搞几个索引吗。...

SpringBoot系列Mybatis之批量插入的几种姿势

...

MySQL 之 Performance Schema(mysql安装及配置超详细教程)

MySQL之PerformanceSchema介绍PerformanceSchema提供了在数据库运行时实时检查MySQL服务器的内部执行情况的方法,通过监视MySQL服务器的事件来实现监视内...

取消回复欢迎 发表评论: