给妹子讲python-S01E23初识异常

简介:

【妹子问】从字面上来看,异常是程序运行时出现的错误吧。

没错,每当在运行时检测到程序错误时,python就会引发异常。对待异常有两种方法:一是可以在程序中捕捉和响应错误;或者忽略已发生的异常。

如果是忽略已发生的异常,python默认的异常处理行为将启动:停止程序,打印出错消息。如果不想启动这种默认行为,就要写try语句来捕捉异常并从异常中恢复,当程序运行检测到错误时,python会跳到try处理器,而程序在try之后会重新继续执行。

首先来看看python自带的默认异常处理器

 

def fetcher(obj, index):
return obj[index]

x = 'spam'

print(fetcher(x,3))
print(fetcher(x,9))

m
Traceback (most recent call last ):
File "E:/12homework/12homework.py" , line 7 , in < module >
print(fetcher(x, 9 ))
File "E:/12homework/12homework.py" , line 2 , in fetcher
return obj[ index ]
IndexError: string index out of range

从这个例子可以看到,我们试图对字符串末尾以后的位置做索引运算,当函数尝试执行obj[9]时,就会触发异常。Python会替序列检测到超出边界的索引运算,并通过抛出(触发)内置的IndexError异常进行报告。

在这个例子中,我们的代码没有刻意去捕捉这个异常,所以他会一直向上返回到程序顶层,并启用默认的异常处理器:就是打印标准出错信息,即异常发生时激活的程序行和函数清单。

那么,如果我们想自己去捕获异常呢?

因为在有些情况下,这并不是我们想要的。例如,服务器程序一般需要在内部发生错误时依然保持继续工作。如果你不想要默认的异常行为,就需要把调用封装在try语句内,自行捕捉异常。

 

def fetcher (obj, index) :
return obj[index]

x = 'spam'

try :
fetcher(x, 9 )
except IndexError:
print( 'got exception' )

got exception

现在,当try代码块内程序执行触发异常时,python会自动跳至处理器(即except分句下面的代码块)去运行。

 

def fetcher (obj, index) :
return obj[index]

x = 'spam'

try :
fetcher(x, 9 )
except IndexError:
print( 'got exception' )
print( 'continue...' )

got exception
continue ...

在这个例子中,我们在异常捕捉和处理后,程序在捕捉了整个try语句后继续执行;这就是我们之所以得到continue消息的原因。我们没有看见标准出错信息,而程序也将正常执行下去。

除了python自身会产生异常以外,我们在程序中也可以主动引发异常。想要手动触发异常,可以直接执行raise语句。用户通过raise触发的异常的捕捉方式和python程序自身引发的异常一样:

 

try :
raise IndexError
except IndexError:
print( 'got exception' )

got exception

如果没有去捕捉到异常,用户定义的异常就会向上传递,直到顶层默认的异常处理器,并通过标准出错信息终止该程序,看看,是不是感觉很熟悉。

 

raise IndexError

Traceback (most recent call last ):
File "E:/12homework/12homework.py" , line 1 , in < module >
raise IndexError
IndexError

我们还可以自定义异常

刚才我们利用raise语句触发了python内置作用域中定义的一个内置异常。其实我们也可以自己定义一个新的异常,这里可能需要一点面向对象的知识,所以我们只需要了解即可:自定义的异常能够通过类来编写,它继承自一个内置的异常类:通常这个类的名称叫做Exception

 

class Bad (Exception) :
pass

def doomed () :
raise Bad()

try :
doomed()
except Bad:
print( 'got Bad' )

got Bad

最后说说终止行为finally代码块

try语句可以包含finally代码块。可以定义一定会在最后执行时的收尾行为。这里的“一定“指的是无论try代码块中是否发生了异常都会执行。

 

try :
raise IndexError
finally :
print( 'in finally' )
print( 'after finally' )

in finally
Traceback (most recent call last):
File "E:/12homework/12homework.py" , line 2 , in <module>
raise IndexError
IndexError


try :
print( 'ok' )
finally :
print( 'in finally' )
print( 'after finally' )

ok
in finally
after finally

可以看出,上述try/finally语句组合,无论try代码块是否发生异常,程序都将会执行finally代码块中的语句。但是当有异常发生时,python会跳过去执行finally中的行为,执行完finally中的语句后,再将try中的异常传递给顶层的默认处理器,因此finally后面的语句就不会执行了。但是如果try中的代码不触发异常,则finally后面的代码块就会正常的继续执行。

我们总结一下:

在实际应用中,try/except的组合可用于捕捉异常并从中恢复,而try/finally的组合则很方便,可以确保无论try代码块内的代码是否发生了异常,终止行为都一定会运行。

一个例子是:比如无论是否出现异常,无论异常是否被捕获,都一定会确保关闭文件。

最终我们是可以把try/except/finally三者连用的,try内为主体功能代码,except用来捕获异常,而无论异常是否出现,是否被except捕获,都将执行finally内的语句。


原文发布时间为:2018-09-18

本文作者:给妹子讲python

本文来自云栖社区合作伙伴“Python爱好者社区”,了解相关信息可以关注“Python爱好者社区”。

相关文章
|
3月前
|
Python
Python学习 -- 异常堆栈追踪技术
Python学习 -- 异常堆栈追踪技术
28 0
|
3月前
|
Python
Python学习 -- 异常捕获技巧
Python学习 -- 异常捕获技巧
20 0
|
1月前
|
开发者 UED Python
怎么理解python中的错误和异常
怎么理解python中的错误和异常
25 0
|
9天前
|
Python
python面型对象编程进阶(继承、多态、私有化、异常捕获、类属性和类方法)(上)
python面型对象编程进阶(继承、多态、私有化、异常捕获、类属性和类方法)(上)
51 0
|
16天前
|
开发者 Python
使用python打印异常
Python的try-except用于异常处理,尝试执行try块中的代码,若出现异常,则由except捕获并处理。示例展示了当尝试除以零引发`ZeroDivisionError`时,如何打印异常信息。使用`traceback`模块可获取更详尽的异常堆栈信息。在实际应用中,异常信息应根据需求写入日志或发送给开发者,避免向用户暴露敏感信息。
11 0
|
22天前
|
Python
Python中异常的抛出与捕获
4月更文挑战第3天,Python中的异常是处理错误的方式,当错误发生时,异常被触发,未被捕获则导致程序终止。通过`raise`可手动抛出异常,例如`raise ValueError("Invalid value provided")`或自定义异常。使用`try-except`捕获异常,避免程序意外结束。`try`块包含可能出错的代码,`except`块处理特定异常,`else`子句在无异常时执行,`finally`子句确保清理代码始终执行。
17 2
Python中异常的抛出与捕获
|
1月前
|
Python
在Python中文件异常
在Python中文件异常
13 1

热门文章

最新文章