【每天1分钟】PYTHON基础之异常处理(捕获异常)

【每天1分钟】PYTHON基础之异常处理(捕获异常)

1. 基本语法

try:                        # 尝试执行的代码
    ...
except ErrorType as e:      # 针对"该错误" 的处理代码, 可有多个except
    ...
else:                       # 没出现异常时,才需要运行
    ...
finally:                   # 无论是否有异常,最后都要执行
    ...


2. 例子

2.1 捕获所有异常

包括键盘中断和程序退出请求(用sys.exit()就无法退出程序了,因为异常被捕获了),因此慎用。

try:
    <语句>
 except:
    print('异常说明')

2.2 捕获指定异常

try:
    <语句> 
except <异常名>: 
    print('异常说明')

万能异常:

try:
    <语句> 
except Exception: 
    print('异常说明')

2.3 捕获多个异常

捕获多个异常有两种方式,第一种是一个except同时处理多个异常,不区分优先级:

try:
    <语句> 
except (<异常名1>, <异常名2>, ...): 
    print('异常说明')

第二种是区分优先级的:

try:
    <语句> 
except <异常名1>: 
    print('异常说明1') 
except <异常名2>: 
    print('异常说明2') 
except <异常名3>: 
    print('异常说明3')

该种异常处理语法的规则是:

  • 执行try下的语句,如果引发异常,则执行过程会跳到第一个except语句。
  • 如果第一个except中定义的异常与引发的异常匹配,则执行该except中的语句。
  • 如果引发的异常不匹配第一个except,则会搜索第二个except,允许编写的except数量没有限制。
  • 如果所有的except都不匹配,则异常会传递到下一个调用本代码的最高层try代码中。

2.4 异常中的else

如果判断完没有某些异常之后还想做其他事,就可以使用下面这样的else语句。

try:
    <语句> 
except <异常名1>: 
    print('异常说明1') 
except <异常名2>: 
    print('异常说明2') 
else: 
    <语句>  # try语句中没有异常则执行此段代码

2.5 异常中的finally

try…finally…语句无论是否发生异常都将会执行最后的代码。

str1 = 'hello world'
try:
    int(str1)
except IndexError as e:
    print(e)
except KeyError as e:
    print(e)
except ValueError as e:
    print(e)
else:
    print('try内没有异常')
finally:
    print('无论异常与否,都会执行我')

2.6 raise主动触发异常

可以使用raise语句自己触发异常,raise语法格式如下:

raise [Exception [, args [, traceback]]]

语句中Exception是异常的类型(例如ValueError),参数是一个异常参数值。该参数是可选的,如果不提供,异常的参数是"None"。最后一个参数是跟踪异常对象,也是可选的(在实践中很少使用)。

def not_zero(num):
    try:
        if num == 0:
            raise ValueError('参数错误')
        return num
    except Exception as e:
        print(e)
 
 
not_zero(0)
 

2.7 采用traceback模块查看异常

发生异常时,Python能“记住”引发的异常以及程序的当前状态。Python还维护着traceback(跟踪)对象,其中含有异常发生时与函数调用堆栈有关的信息。记住,异常可能在一系列嵌套较深的函数调用中引发。程序调用每个函数时,Python会在“函数调用堆栈”的起始处插入函数名。一旦异常被引发,Python会搜索一个相应的异常处理程序。如果当前函数中没有异常处理程序,当前函数会终止执行,Python会搜索当前函数的调用函数,并以此类推,直到发现匹配的异常处理程序,或者Python抵达主程序为止。这一查找合适的异常处理程序的过程就称为“堆栈辗转开解”(StackUnwinding)。解释器一方面维护着与放置堆栈中的函数有关的信息,另一方面也维护着与已从堆栈中“辗转开解”的函数有关的信息。

>>> import traceback
>>> 
>>> try:
	1/0
except Exception as e:
	traceback.print_exc()

	
Traceback (most recent call last):
  File "<pyshell#27>", line 2, in <module>
ZeroDivisionError: division by zero
>>> 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值