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