bash 抓捕异常_五种异常处理机制:try...except与try...finally

本文详细介绍了Python的异常处理机制,包括try/except语句用于捕获和处理异常,以及try/finally语句用于确保执行清理任务。通过示例解释了如何使用try/except捕获不同类型的异常,以及try/finally在异常发生或正常执行后执行finally块的必要性。此外,还讨论了finally块在资源管理中的重要性,特别是在处理文件、数据库连接等资源时。
摘要由CSDN通过智能技术生成

(try finally)

Python try except异常处理详解

python标准异常

异常名称描述

BaseException

所有异常的基类

SystemExit

解释器请求退出

KeyboardInterrupt

用户中断执行(通常是输入^C)

Exception

常规错误的基类

StopIteration

迭代器没有更多的值

GeneratorExit

生成器(generator)发生异常来通知退出

SystemExit

Python 解释器请求退出

StandardError

所有的内建标准异常的基类

ArithmeticError

所有数值计算错误的基类

FloatingPointError

浮点计算错误

OverflowError

数值运算超出最大限制

ZeroDivisionError

除(或取模)零 (所有数据类型)

AssertionError

断言语句失败

AttributeError

对象没有这个属性

EOFError

没有内建输入,到达EOF 标记

EnvironmentError

操作系统错误的基类

IOError

输入/输出操作失败

OSError

操作系统错误

WindowsError

系统调用失败

ImportError

导入模块/对象失败

KeyboardInterrupt

用户中断执行(通常是输入^C)

LookupError

无效数据查询的基类

IndexError

序列中没有没有此索引(index)

KeyError

映射中没有这个键

MemoryError

内存溢出错误(对于Python 解释器不是致命的)

NameError

未声明/初始化对象 (没有属性)

UnboundLocalError

访问未初始化的本地变量

ReferenceError

弱引用(Weak reference)试图访问已经垃圾回收了的对象

RuntimeError

一般的运行时错误

NotImplementedError

尚未实现的方法

SyntaxError

Python 语法错误

IndentationError

缩进错误

TabError

Tab 和空格混用

SystemError

一般的解释器系统错误

TypeError

对类型无效的操作

ValueError

传入无效的参数

UnicodeError

Unicode 相关的错误

UnicodeDecodeError

Unicode 解码时的错误

UnicodeEncodeError

Unicode 编码时错误

UnicodeTranslateError

Unicode 转换时错误

Warning

警告的基类

DeprecationWarning

关于被弃用的特征的警告

FutureWarning

关于构造将来语义会有改变的警告

OverflowWarning

旧的关于自动提升为长整型(long)的警告

PendingDeprecationWarning

关于特性将会被废弃的警告

RuntimeWarning

可疑的运行时行为(runtime behavior)的警告

SyntaxWarning

可疑的语法的警告

UserWarning

用户代码生成的警告

什么是异常?

异常即是一个事件,该事件会在程序执行过程中发生,影响了程序的正常执行。

一般情况下,在Python无法正常处理程序时就会发生一个异常。

异常是Python对象,表示一个错误。

当Python脚本发生异常时我们需要捕获处理它&#x

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用命令行进行操作时遇到-bash: mysql: command not found的问题,这个问题可能是由于以下两个原因导致的。首先,你需要检查.bash_profile文件中是否正确设置了MySQL的路径。你可以通过编辑.bash_profile文件,添加以下行来设置路径: export PATH=$PATH:/usr/local/mysql/bin 保存文件后,使用source命令使得修改立即生效,即source ~/.bash_profile。 另外,你也可以直接使用MySQL的完整路径执行命令,比如: /usr/local/mysql/bin/mysql 这样就可以绕过找不到mysql命令的问题了。 如果以上方法都无效,还可以尝试以下解决办法: 1. 确保MySQL服务已经启动,可以使用systemctl status mysql命令来查看MySQL服务的状态。 2. 检查系统的环境变量PATH,可以使用echo $PATH命令查看所有服务的位置。 3. 暂停MySQL服务,可以使用service mysql stop命令来停止MySQL服务。 4. 在/etc/profile文件中配置系统环境变量,将MySQL的bin目录添加到PATH变量中,可以使用export PATH=$PATH:/usr/local/mysql/bin命令来添加。 5. 让profile文件立即生效,可以使用source /etc/profile或./etc/profile命令来使修改生效。 希望以上解决办法能够帮助你解决bash: mysql: 未找到命令的问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [-bash: mysql: command not found的问题与解决](https://download.csdn.net/download/weixin_38622777/14059863)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [-bash: mysql: command not found](https://blog.csdn.net/wufaqidong1/article/details/128641451)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [解决Linux:-bash: mysql: 未找到命令 问题](https://blog.csdn.net/qq_61407171/article/details/129418117)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值