自定义异常 raise
# 链接资料
- https://docs.python.org/zh-cn/3/tutorial/errors.html
- http://c.biancheng.net/python/try_except/
- https://python3-cookbook.readthedocs.io/zh_CN/latest/chapters/p14_test_debug_and_exceptions.html
# raise
raise 语句的基本语法格式为:
raise [exceptionName [(reason)]]
1
其中,用 [] 括起来的为可选参数,其作用是指定抛出的异常名称,以及异常信息的相关描述。如果可选参数全部省略,则 raise 会把当前错误原样抛出;如果仅省略 (reason),则在抛出异常时,将不附带任何的异常描述信息。
也就是说,raise 语句有如下三种常用的用法:
- raise:单独一个 raise。该语句引发当前上下文中捕获的异常(比如在 except 块中),或默认引发 RuntimeError 异常。
- raise 异常类名称:raise 后带一个异常类名称,表示引发执行类型的异常。
- raise 异常类名称(描述信息):在引发指定类型的异常的同时,附带异常的描述信息。
想了解一下常用的异常类名称,可以阅读《Python常见异常类型》 (opens new window)一节。
# 示例
try:
a = input("输入一个数:")
# 判断用户输入的是否为数字
if (not a.isdigit()):
raise ValueError("a 必须是数字")
except ValueError as e:
print("引发异常:", repr(e))
raise # 可以不用定义参数
"""
输入一个数:aa1
引发异常: ValueError('a 必须是数字')
Traceback (most recent call last):
raise ValueError("a 必须是数字")
ValueError: a 必须是数字
"""
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# raise 不需要参数
try:
a = input("输入一个数:")
if(not a.isdigit()):
raise ValueError("a 必须是数字")
except ValueError as e:
print("引发异常:",repr(e))
raise
1
2
3
4
5
6
7
2
3
4
5
6
7
1
编辑 (opens new window)
上次更新: 2023/05/17, 23:08:21