python a or b 输出值为_python-为什么“a==b或c或d”的值总是为True?

小编典典

在许多情况下,Python的外观和行为都像自然的英语,但这是这种抽象失败的一种情况。人们可以使用上下文线索来确定Jon和Inbar是与动词equals连接的对象,但是Python解释器具有更多的字面意义。

if name == "Kevin" or "Jon" or "Inbar":

在逻辑上等效于:

if (name == "Kevin") or ("Jon") or ("Inbar"):

对于用户Bob而言,这等效于:

if (False) or ("Jon") or ("Inbar"):

该or运营商选择以积极的第一个参数真值:

if ("Jon"):

并且由于Jon具有正的真值,因此if执行该块。这就是导致无论给定名称如何都将打印“授予访问权限”的原因。

所有这些推理也适用于表达式if "Kevin" or "Jon" or "Inbar" == name。第一个值,”Kevin”则为true,因此该if块将执行。

有两种常见的方法可以正确地构造此条件。

使用多个==运算符显式检查每个值:

if name == "Kevin" or name == "Jon" or name == "Inbar":

组成一个有效值序列,并使用in运算符测试成员资格:

if name in {"Kevin", "Jon", "Inbar"}:

一般而言,第二个应该是首选,因为它更易于阅读,而且速度更快:

>>> import timeit

>>> timeit.timeit('name == "Kevin" or name == "Jon" or name == "Inbar"', setup="name='Inbar'")

0.4247764749999945

>>> timeit.timeit('name in {"Kevin", "Jon", "Inbar"}', setup="name='Inbar'")

0.18493307199999265

2020-02-04

以下是一个简单的例子,可以输入一个命题公式并输出表: ```python import itertools # 定义命题符号的优先级 precedence = {"~": 3, "and": 2, "or": 1} def evaluate(expression, values): """ 计算命题表达式的 """ stack = [] for token in expression: if token == "True": stack.append(True) elif token == "False": stack.append(False) elif token in values: stack.append(values[token]) elif token == "~": operand = stack.pop() stack.append(not operand) elif token in ["and", "or"]: right = stack.pop() left = stack.pop() if token == "and": stack.append(left and right) else: stack.append(left or right) return stack.pop() def parse(expression): """ 将命题表达式解析为逆波兰表达式 """ output = [] stack = [] for token in expression: if token == "True" or token == "False": output.append(token) elif token in precedence: while stack and stack[-1] in precedence and precedence[token] <= precedence[stack[-1]]: output.append(stack.pop()) stack.append(token) elif token == "(": stack.append(token) elif token == ")": while stack and stack[-1] != "(": output.append(stack.pop()) stack.pop() else: output.append(token) while stack: output.append(stack.pop()) return output def generate_table(expression): """ 生成命题表的真表 """ variables = set([token for token in expression if token.isalpha()]) variables = sorted(list(variables)) header = variables + [expression] rows = [] for assignment in itertools.product([True, False], repeat=len(variables)): row = list(assignment) values = dict(zip(variables, assignment)) row.append(evaluate(parse(expression), values)) rows.append(row) return header, rows if __name__ == "__main__": expression = input("请输入命题公式:") header, rows = generate_table(expression) print("\t".join(header)) for row in rows: print("\t".join([str(value) for value in row])) ``` 这段代码中,我们首先定义了命题符号的优先级,然后定义了三个函数: - `parse`:将命题表达式解析为逆波兰表达式。 - `evaluate`:计算逆波兰表达式的。 - `generate_table`:生成命题表的真表。 在 `generate_table` 函数中,我们首先通过 `itertools.product` 函数生成所有可能的变量赋组合。然后对于每个赋组合,我们计算出命题表达式的,并将变量赋和命题表达式的组成一行。最后,我们将所有行组成一个表格,并输出到标准输出流中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值