使用assert断言是学习python一个非常好的习惯,python assert 断言句语格式及用法很简单。在没完善一个程序之前,我们不知道程序在哪里会出错,与其让它在运行最崩溃,不如在出现错误条件时就崩溃,这时候就需要assert断言的帮助。本文主要是讲assert断言的基础知识。
python assert断言的作用
python assert断言是声明其布尔值必须为真的判定,如果发生异常就说明表达示为假。可以理解assert断言语句为raise-if-not,用来测试表示式,其返回值为
下面通过实例代码介绍下python assert 作用,具体内容如下所示:
python assert 句语格式及用法很简单。通常程序在运行完之后抛出异常,使用assert可以在出现有异常的代码处直接终止运行。 而不用等到程序执行完毕之后抛出异常。
python assert的作用
python assert如果发生异常就说明表达示为假。可以理解表示式返回 值为假 时就会触发异常。
assert语句的语法格式
assert expression [, arguments]
assert 表达式 [, 参数]
附加说明:assert也可以用于多个表达式的: assert expression1, expression2。
注意:表达式=false 时,则执行其后面的异常。
我们看几个示例
1:单个表达式:
a = 1
assert a < 0, '出错了,a大于0 啊'
print('这里不会输出')
输出:
Traceback (most recent call last):
File "main.py", line 3, in <module>
assert a < 0, '出错了,a大于0 啊'
AssertionError: 出错了,a大于0 啊
2:多个表达式:
a = 1
b = -1
assert a > 0, b < 0
print('正常输出,表达式返回真了') # 输出:正常输出,表达式返回真了
3:尝试捕获 assert 异常:
import traceback
try:
assert a < 0
except AssertionError as aeeor: # 明确抛出此异常
# 抛出 AssertionError 不含任何信息,所以无法通过 aeeor.__str__()获取异常描述
print('AssertionError', aeeor, aeeor.__str__())
# 通过 traceback 打印详细异常信息
print('traceback 打印异常')
traceback.print_exc()
except: # 不会命中其他异常
print('assert except')
try:
raise AssertionError('测试 raise AssertionError')
except AssertionError as aeeor:
print('raise AssertionError 异常', aeeor.__str__())
输出:
AssertionError
traceback 打印异常
Traceback (most recent call last):
File "main.py", line 7, in <module>
aAssertionError
raise AssertionError 异常 测试 raise AssertionErrorssert a < 0
4:函数调用抛出异常:
# 除法运算
def foo(value, divide):
assert divide != 0
return value / divide
print('4除以2 =', foo(4, 2)) # 执行成功
print('4除以0 =', foo(4, 0)) # 抛出异常
输出:
4除以2 = 2.0
Traceback (most recent call last):
File "main.py", line 8, in <module>
print('4除以0 =', foo(4, 0)) # 抛出异常
File "main.py", line 3, in foo
assert divide != 0
AssertionError
通过上面几个示例,相信大家也深刻理解aseert的用处了
python中Assert是较为常用的调试工具,利用好assert可以有效的提升编程效率,
但是也有很多同学用法不规范。
这篇短文主要包括的内容有:
Assert与raise exception语句使用的正确场景;
python中.pyc与.pyo;
python 的__debug__语句;
1. 正如《程序员保命指南 Google Style Guide》中所述:
Do not use assert statements for validating argument values of a public API. assert is used to ensure internal correctness, not to enforce correct usage nor to indicate that some unexpected event occurred.
styleguide
google.github.io/styleguide/pyguide.html
Assert是程序员用于保证程序的正确性,不是用于检查使用者输入参数是否合法,
换言之,Assert可以简单的理解为程序员的debug工具,正式的代码中应该使用raise来检查用户输入是否正确,
如下:
# assert
assert port >= minimum, 'Unexpected port %d when minimum was %d.' % (port, minimum)
# raise
if minimum < 1024:
raise ValueError('Minimum port must be at least 1024, not %d.' % (minimum,))
2. 另外不用assert 作为检查输入参数合法性的原因还在于,对于.pyo格式的版本中是不对assert进行编译的。
python文件的格式除了.py 还有.pyc/.pyo,后两者需要经过编译在运行,
其中.pyo是经过优化后编译的二进制文件,可以增加程序的稳定性,隐藏源码。编译方法:
python -O -m py_complie yourPythonFile.py
3. 另外在不进行优化编译的时候 __debug__命令也默认为True,与assert相似,
使用if __debug__作为判断可以提高编程效率。
=================
语法格式:
assert expression
等价于:
if not expression:
raise AssertionError
assert后可跟参数:
assert expression[,assert_error_msg]
等价于:
if not expression:
raise AssertionError(assert_error_msg)
assert True 举例:
assert True, '断言失败,返回错误'
print('断言成功,执行接下来的代码')
assert False, '断言失败,返回错误'
print('断言成功,执行接下来的代码')
执行结果:
断言成功,执行接下来的代码
Traceback (most recent call last):
File "<stdin>", line 4, in <module>
assert False, '断言失败,返回错误'
AssertionError: 断言失败,返回错误
其它栗子:
# assert True 的栗子
assert 1 == 1
assert '123'.isdigit()
assert 123
assert 'Hello World!'
assert [1, 2, 3]
assert (1, 2, 3)
assert {'a': 1}
# assert False 的栗子
assert 1 == 2
assert ''
assert []
assert {}
assert ()