python的assert和raise的用法

一、raise用法

在程序运行的过程当中,除了python自动触发的异常外,python也允许我们在程序中手动设置异常,使用 raise 语句即可,

为什么还要手动设置异常呢?首先要分清楚程序发生异常和程序执行错误,它们完全是两码事,程序由于错误导致的运行异常,是自动触发的,需要程序员想办法解决的;但还有一些异常,是程序正常运行的结果,比如用 raise 手动引发的异常。

raise的基本格式

raise [exceptionName [(reason)]]

其中,用 [] 括起来的为可选参数,其作用是指定抛出的异常名称,以及异常信息的相关描述。如果可选参数全部省略,则 raise 会把当前错误原样抛出;如果仅省略 (reason),则在抛出异常时,将不附带任何的异常描述信息。

raise 语句有如下三种常用的用法:

1. raise:单独一个 raise。该语句引发当前上下文中捕获的异常(比如在 except 块中),或默认引发 RuntimeError 异常。

a = 'a'
if not a.isdigit():
    raise
print(a)

# 上面的代码中,如果a=1,就可以正常运行,并且会打印1,但是值为'a',所以会走if判断,直接抛异常

运行结果如下:

2. raise 异常类名称:raise 后带一个异常类名称,表示引发执行类型的异常。

a = 'a'
if not a.isdigit():
    raise ValueError
print(a)

运行结果:

3. raise 异常类名称(描述信息):在引发指定类型的异常的同时,附带异常的描述信息。

a = 'a'
if not a.isdigit():
    raise ValueError("a 必须是数字")
print(a)

异常捕获:

当然我们也可以通过try去捕获我们手动触发的异常,如下:

try:
    a = 'a'
    #判断用户输入的是否为数字
    if not a.isdigit():
        raise ValueError("a 必须是数字")  # 这里的异常会被捕获并打印
except Exception as e:
    print("引发异常:", repr(e))
    raise  # 这里再次手动去触发异常

二、assert用法

assert(断言):断定此处是对的,如果错了,就报错

通常在测试程序时不知道哪里会出错,只有执行到最后才能看到错误信息。assert可以在条件不满足程序运行的情况下直接返回错误,而不必等待程序运行后出现崩溃的情况。

assert的语法格式:

assert expression  # 如果expression是错的,就会报错

等价于:

if not expression:
    raise AssertionError

示例如下:

a = 1
assert a > 2  # 断言a大于2,如果为真,程序继续向下执行,如果a不大于2,直接抛AssertionError的异常
b = 2


# 运行结果:报错
Traceback (most recent call last):
  File "C:\workspace\test.py", line 2, in <module>
    assert a > 2
AssertionError

为assert断言语句添加异常参数:

assert expression [, arguments]  
# arguments这个参数是可选的,就是在expression后添加字符串信息,用来解释断言并更好知道哪里出了问题

示例如下:

a = 1
assert a > 2, 'a值小于2'
# 上面逗号后面跟一个字符串,添加报错说明

# 运行结果:
Traceback (most recent call last):
  File "C:\workspace\test.py", line 2, in <module>
    assert a > 2, 'a值小于2'
AssertionError: a值小于2

 

posted @ 2023-01-18 15:31  _yessir  阅读(764)  评论(0编辑  收藏  举报