默默佩佩 发表于 2020-7-10 13:25:27

逻辑运算符相关问题求教

这个为什么不是按 and优先级大于or先进行and运算


1>        def a():
        2>                print 'A'
        3>                return []
        4>        def b():
        5>                print 'B'
        6>                return []
        7>        def c():
        8>                print 'C'
        9>                return 1
        10>        def d():
        11>                print 'D'
        12>                return []
        13>        def e():
        14>                print 'E'
        15>                return 1
        16>        def f():
        17>                print 'F'
        18>                return 1
        19>        def g():
        20>                print 'G'
        21>                return []
        22> def h():
        23>                print 'H'
        24>                return 1
        25>
        26>        if a() and b() andc() and d() or e() and f() or g() and h():
        27>                print 'ok'

Twilight6 发表于 2020-7-10 13:42:02

本帖最后由 Twilight6 于 2020-7-10 13:52 编辑



就是按照 and > or 来判断的

你首先要了解:

在 Python 中只要 0 、空字符串、空列表、空字典等 都可以看作布尔类型的值为 False

只要是 非0 ,非空字符串、列表、字典 等 都可以看作布尔类型的值为 True

然后了解下短路逻辑:

短路逻辑规则如下:

表达式从左至右运算,若 or 的左侧逻辑值为 True ,则短路 or 后所有的表达式(不管是 and 还是 or),直接输出 or 左侧表达式 。

若 or 的左侧逻辑值为 False ,则输出or右侧的表达式,不论其后表达式是真是假,整个表达式结果即为其后表达式的结果

表达式从左至右运算,若 and 的左侧逻辑值为 False ,则短路其后所有 and 表达式,直到有 or 出现,输出 and 左侧表达式到 or 的左侧,参与接下来的逻辑运算。

若 and 的左侧逻辑值为 True,则输出其后的表达式,不论其后表达式是真是假,整个表达式结果即为其后表达式的结果

若 or 的左侧为 False ,或者 and 的左侧为 True 则不能使用短路逻辑。

注意:

1、在Python中and的优先级是大于or的,而且and和or都是会返回值的并且不转换为True和False。当not和and及or在一起运算时,优先级为是not>and>or

2、在Python中,None、任何数值类型中的0、空字符串“”、空元组()、空列表[]、空字典{}都被当作False,还有自定义类型,如果实现了 __ len __ () 方法且方法返回 0 或False,则其实例也被当作False,其他对象均为True。

简单点说就是 or 只要判断到 True 就返回该处的值,and 只要判断到False 就返回 False ,当 and 两边都为 True 时,返回右边的数


嫌上面的字太多,你可以只看红色部分


然后我们来看题目,我们要先为 if 条件划分好判断顺序,划分好后发现实际上只有 三个 or 构成的整体判断,所以我们要从左到右开始:

if ( a() and b() andc() and d() ) or ( e() and f() ) or ( g() and h() ):

那么开始判断,我们先从左到右,判断a() and b() andc() and d() 这部分

因为 and 逻辑运算符只要有一个为 False 就短路后面的判断所以这里 a() 函数返回的是 [] 空列表

则 bool 值为 False ,则短路后面的判断 ,也就是这里蓝色部分,所以都没有调用除 a() 函数以外的函数,所以只打印了 A

然后判断第二个括号的: e() and f()

因为 e() 函数返回值是 1 ,则可以看作 bool 类型的 True ,则 and 左边条件成立 判断 右边 f() 也返回 True ,所以两个函数都调用了,打印 了 E 和 F

而又因为 e() and f() or g() and h() 中的e() and f() 两边都为 True ,则e() and f() 返回的是 True

而 or 逻辑运算符 如果一遇到 True 就返回 True ,短路后面的判断,所以这里的红色部分全部被短路,所以没有调用这些函数

所以最后打印结果是 A --> E --> F --> ok

另外你应该是网上找的代码吧?还是2.x的,如果是 3.x 的 print 要记得带括号哈~



生物必学编程 发表于 2020-7-10 20:33:39

逻辑里面是not>and>or

默默佩佩 发表于 2020-7-10 20:50:25

是在网上找的,别以为语句很长就很难,我们好好分析一下,从左至右,首先a() 的逻辑值为 False,其后到 or 语句为止有三个 and 语句: a() and b() and c() and d(),均被短路。只输出 a(), 得到 a() or e() 为True,输出 e() ,得 e() and F() 为 True ,输出 f(), 其后接 or 语句,则短路其后所有。最终只打印了A E F ok 。(结合我总结的短路逻辑的三点好好理解,应该没问题。这是它上面说的,是不是不对?他这个意思不是and优先于or了

默默佩佩 发表于 2020-7-10 20:53:53

生物必学编程 发表于 2020-7-10 20:33
逻辑里面是not>and>or

恩恩

czzhbq 发表于 2021-1-4 14:25:15

Twilight6 发表于 2020-7-10 13:42
就是按照 and > or 来判断的

你首先要了解:


{:9_228:}
页: [1]
查看完整版本: 逻辑运算符相关问题求教