python3.x - Python not 运算符的问题
问题描述
>>> a = False + 55
>>> a = not(1) + 5False
如上,将 False 直接进行运算时会作为 0 来计算。使用逻辑运算符 not 时,not(1) 的值为 False 或 0。
但为什么直接将 not(1) 放进算术运算后再次计算的结果为 False?这和 Python 的算法逻辑有关么?
问题解答
回答1:因为not不是一个函数, 是一个表达式, 不管你not(1)+5 还是 not (1+5), 它的作用也只是将后面的结果取反而已.例如:
>>> not 1 + 2False>>> not (1 + 2)False>>> not (1 + 2) + 1False>>> (not (1 + 2)) + 11回答2:
Python 中 not 运算符的用法Boolean Operations:
not x
if x is false, then True, else False
此外,+运算符的优先级(precedence)高于not运算符,所以not(1) + 5中先计算(1) + 5, 后面的(1)+5作为not运算符的操作数. 举个例子可以看到:
not(-1) # Falsenot(-1) + 1 # True回答3:
正如上面所说,因为 not operator 的优先级小于 + 所以 not(1)+6 会被翻译为 not (1)+5关于这些情况,你完全可以通过 dis模块 来查看具体的过程。>>> import dis>>> dis.dis('a = False + 5') 1 0 LOAD_CONST 3 (5) 3 STORE_NAME 0 (a) 6 LOAD_CONST 2 (None) 9 RETURN_VALUE>>> dis.dis('a = not(1) + 5') 1 0 LOAD_CONST 3 (6) 3 UNARY_NOT 4 STORE_NAME 0 (a) 7 LOAD_CONST 2 (None) 10 RETURN_VALUE
相关文章:
1. python - 求一个在def中可以实现调用本def满足特定条件continue效果的方法(标题说不太清楚,请见题内描述)2. $fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题3. USE关键字4. javascript - mysql插入数据时怎样避免与库中的数据重复?5. MySQL 如何 SELECT 除去某一列的所有列?6. 导入phpmyadmin的时候报错了7. MySQL能否给某个字段的值设置有效期?8. 求一个mySQL安装包9. mysql数据库做关联一般用id还是用户名10. MySQL 这句 创建表结构语句的错误在哪?
