python try expect raise_python 异常: try, expect, finally | 学步园

稍微总结一下,否则总是忘。

1.x = 'abc'

2.def fetcher(obj, index):

3.    return obj[index]

4.

5.fetcher(x, 4)

输出:

1.  File "test.py", line 6, in 

2.    fetcher(x, 4)

3.  File "test.py", line 4, in fetcher

4.    return obj[index]

5.IndexError: string index out of range

捕获列表列出的异常,进行处理。若except后无任何参数,则捕获所有异常。

1.def catcher():

2.    try:

3.        fetcher(x, 4)

4.    except:

5.        print "got exception"

第一: try不仅捕获异常,而且会恢复执行

1.def catcher():

2.    try:

3.        fetcher(x, 4)

4.    except:

5.        print "got exception"

6.    print "continuing"

输出:

1.got exception

2.continuing

第二:无论try是否发生异常,finally总会执行

1.def catcher():

2.    try:

3.        fetcher(x, 4)

4.    finally:

5.        print 'after fecth'

输出:

1.after fecth

2.Traceback (most recent call last):

3.  File "test.py", line 55, in 

4.    catcher()

5.  File "test.py", line 12, in catcher

6.    fetcher(x, 4)

7.  File "test.py", line 4, in fetcher

8.    return obj[index]

9.IndexError: string index out of range

第三:try无异常,才会执行else

1.def catcher():

2.    try:

3.        fetcher(x, 4)

4.    except:

5.        print "got exception"

6.    else:

7.        print "not exception"

输出:

1.got exception

1.def catcher():

2.    try:

3.        fetcher(x, 2)

4.    except:

5.        print "got exception"

6.    else:

7.        print "not exception"

输出:

1.not exception

else作用:没有else语句,当执行完try语句后,无法知道是没有发生异常,还是发生了异常并被处理过了。通过else可以清楚的区分开。

第四:利用raise传递异常

1.def catcher():

2.    try:

3.        fetcher(x, 4)

4.    except:

5.        print "got exception"

6.        raise

输出:

1.got exception

2.Traceback (most recent call last):

3.  File "test.py", line 37, in 

4.    catcher()

5.  File "test.py", line 22, in catcher

6.    fetcher(x, 4)

7.  File "test.py", line 4, in fetcher

8.    return obj[index]

9.IndexError: string index out of range

raise语句不包括异常名称或额外资料时,会重新引发当前异常。如果希望捕获处理一个异常,而又不希望

异常在程序代码中消失,可以通过raise重新引发该异常。

第五:except(name1, name2)

1.def catcher():

2.    try:

3.        fetcher(x, 4)

4.    except(TypeError, IndexError):

5.        print "got exception"

6.    else:

7.        print "not exception"

捕获列表列出的异常,进行处理。若except后无任何参数,则捕获所有异常。

1.def catcher():

2.    try:

3.        fetcher(x, 4)

4.    except:

5.        print "got exception"

第六:异常和sys模块

另一种获取异常信息的途径是通过sys模块中的exc_info()函数。该函数回返回一个三元组异常类,异常类的实例,跟中记录对象)

1.>>> try:

2....     1/0

3.... except:

4....     import sys

5....     tuple = sys.exc_info()

6....

7.>>> print tuple

8.(, ZeroDivisionError('integer division or modulo by zero',), )

9.>>> for i in tuple:

10....     print i

11....

12. #异常类

13.integer division or modulo by zero #异常类的实例

14. #跟踪记录对象

Python中,try-except是一种异常处理机制。它允许我们在代码中捕获并处理可能出现的异常。在try块中,我们编写可能引发异常的代码,然后在except块中处理异常情况。 在引用中,给出了几个try-except的示例。第一个示例展示了处理ZeroDivisionError和ValueError异常的方式。如果用户输入的除数为0,则会抛出ZeroDivisionError异常;如果用户输入的不是数字,则会抛出ValueError异常。我们可以使用except来捕获并处理这些异常,并在except块中打印相应的错误信息。 第二个示例展示了带有else子句的try-except。如果try块中的代码没有引发任何异常,那么else块中的代码将被执行。 第三个示例展示了带有finally子句的try-except。不论try块中的代码是否引发异常finally块中的代码都会被执行。通常在finally块中进行一些清理工作。 引用给出了一个更复杂的try-except的示例。它展示了多个except块的用法,每个块处理不同类型的异常。如果try块中的代码引发了任何一个except块中指定的异常类型,对应的except块中的代码将被执行。如果没有引发任何异常,则else块中的代码将被执行。而无论异常与否,finally块中的代码都会被执行。 引用展示了如何自定义异常类,并在try块中使用raise语句主动触发异常。在except块中捕获并处理自定义的异常。 最后,assert语句是一种用于断言条件是否为真的机制。如果条件为假,则会引发AssertionError异常。它通常用于进行调试和测试。 总结起来,try-except是一种用于捕获和处理异常的机制。我们可以使用try块中的代码尝试执行可能引发异常的操作,然后在except块中处理异常情况。同时,我们也可以使用else和finally子句来在不同情况下执行相应的代码。通过自定义异常类和raise语句,我们还可以主动触发和处理异常。assert语句则用于检查条件是否为真。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [pythontryexpect](https://blog.csdn.net/Garin_lu/article/details/117702343)[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_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [python基础:try...except...的详细用法](https://blog.csdn.net/chengxuyuanlaow/article/details/127594968)[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_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值