首页
读书
网课
《python》目录


正文


使用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 ()





上一篇: 没有了
下一篇: 没有了
圣贤书院