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

[oeasy]python067_如何处理各种可能的异常_try_except_Error

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

如何处理各种可能的异常_try_except_Error

回忆上次内容

  • 我们了解了 try 的细节
    • try
      • 尝试运行
    • except
      • 发现异常时运行的代码块
    • else
      • 没有发现异常时运行的代码块
  • 注意!
    • 都要有英文半角的冒号
    • 子句都要通过 4 个字符的缩进控制范围
  • 错误类型太多了
    • 有 通用错误类型 吗?
    • 能兜住 所有错误 那种?

文档提示

  • 文档说 不带参数就行

各种错误

try:
    a
    i = int("123")
    j = i / 0
except ValueError:
    print(ValueError)
except ZeroDivisionError:
    print(ZeroDivisionError)
except:
    print("Something is Wrong!")
else:
    print("Nothing Wrong")
  • 最后的except
    • 包括 NameError
    • 包含了 所有错误

一网不捞鱼

  • 一网不捞鱼
  • 二网不捞鱼
  • 三网捞个小尾巴尾巴尾巴尾巴尾巴尾巴……鱼
  • 第三网
    • 是通用模式except
    • 可以捕获到 所有的异常
    • 一网打尽
  • 如果这句except排在前面的话
    • 后面 这些异常处理方法
    • 会 被 屏蔽 吗?

尝试调换位置

  • :9,10m4
    • 将从第9句到第10句
    • 移动到第4句后面
  • 尝试运行

运行结果

  • 要 求通用异常处理方式
    • except的 位置
    • 必须 是 最后一个
    • 通用的处理 得保底
  • 可以让这个except的意义
    • 更明确一些吗?
    • 到底是什么错误?

明确含义

try:
    a
    i = int("123")
    j = i / 0
except ValueError:
    print(ValueError)
except ZeroDivisionError:
    print(ZeroDivisionError)
except Exception:
    print(Exception)
else:
    print("Nothing Wrong")
  • 这样
    • 会将 错误信息
    • 输出 吗?

输出结果

  • 输出了 一个通用的错误
    • Exception类
    • 并不知道 错误类型
  • 报错 能再 明确点儿 吗?

修改代码

try:
    a
    i = int("123")
    j = i / 0
except ValueError:
    print(ValueError)
except ZeroDivisionError:
    print(ZeroDivisionError)
except Exception as e:
    print(e)
else:
    print("Nothing Wrong")
  • 尝试将异常作为变量
    • 并输出报错信息

尝试调试

  • 执行第2句 遇到不认识的的a
    • 直接报错
  • 跳过try中 后面的语句
    • 直接找 处理方式

找到通用处理方式

  • 前两个处理方式
    • 都不对
  • 找到第三个
    • 通用的异常处理方式
  • 如果 前面找到了
    • 具体错误类型
  • 还会继续 寻找
    • 最后的 通用异常处理 吗?

捕获异常

try:
    a
    i = int("123")
    j = i / 0
except NameError:
    print(NameError)
except ValueError:
    print(ValueError)
except ZeroDivisionError:
    print(ZeroDivisionError)
except Exception as e:
    print(e)
else:
    print("Nothing Wrong")
  • 在运行过程中
    • 出现了NameError
    • 在 第一个 尝试捕获异常的位置
      • 捕获到了异常
    • 进入except NameError子句
      • 完成 处理过程
      • 输出NameError
    • 跳过后面所有 except
    • 跳过else
  • 执行完毕
  • 异常变量会如何呢?

del

  • 文档说会给删了
  • except 这个词 怎么理解呢?

except

  • except
    • ex 向外
    • cept 拿
    • 向外拿
    • 挑出去
    • 排除
  • 除了...之外

capture

  • capture
    • cept 拿
    • 拿到
    • 抓到
  • 捕获

captive

  • captive
    • cept 拿
    • 被拿到的
  • 俘虏

accept

  • accept
    • ac 向里面
    • cept 拿
    • 往里拿
  • 接受

concept

  • concept
    • con 一起
    • cept 拿
    • 一起拿
    • 把想法放在一起拿起来
    • 整合想法
  • 构思 概念

conceive

  • conceive
    • con 一起
    • cept 拿
    • 一起拿
    • 构思,设想
  • 怀孕

perceive

  • perceive
    • per 完全
    • cept 拿
    • 完全拿捏
  • 理解
  • 认为

deceive

  • deceive
    • de 向下
    • cept 拿
    • 向下拿
    • 借助信息的不对等 去拿
  • 欺骗

receive

  • receive
    • re 再次
    • cept 拿
    • 再次拿回来
  • 收到

cept 总结

总结

  • 我们了解了 try 的细节
    • except 可以 捕获到异常
      • 但报错比较简单
  • 游乐场里面的 报错
    • 更全 更丰富
    • 还告诉哪个文件、第几行
  • 可以跟踪到 最详细 报错信息 吗?
  • 我们下次再说!
  • 蓝桥->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服务器的事件来实现监视内...

取消回复欢迎 发表评论: