当您执行类似'0' or '4'
的操作时,or
操作员将验证第一个参数('0'
)是否为false-ish,如果不是false,则返回第一个值。由于'0'
是不是假的(它是一个非空字符串,如布尔使用时产生True
),它将返回的第一个值和下面的一个甚至不会考虑:如果您重复它
>>> '0' or '4'
'0'
,你会得到相同的结果:
>>> '0' or '4' or '6' or '8'
'0'
此外,in
运营商具有更大的优先级,所以它会每次or
前执行:
在 '88' '0' 或 '4' 或 '6' 或 '8' '0'
你想在你的病情做的是验证任何值是结果:
>>> '0' in str(i) or '4' in str(i) or '6' in str(i) or '8' in str(i)
True
>>> i = 17
>>> '0' in str(i) or '4' in str(i) or '6' in str(i) or '8' in str(i)
False
这还不是最完美的解决方案,但它是你的意图的最好的翻译。
那么,什么是优雅的解决方案?作为sugested通过@sven,您可以创建寻求字符的集合(more about it):
>>> sought = set("0468")
>>> sought
set(['0', '8', '4', '6'])
,然后创建了一套在你的电话号码位数:
>>> i = 16
>>> set(str(i))
set(['1', '6'])
现在,只是看看they are disjoint:
>>> i = 16
>>> sought.isdisjoint(set(str(i)))
False
>>> i = 17
>>> sought.isdisjoint(set(str(i)))
True
在这种情况下,如果设定是不脱节,那么要保留它:
>>> found = []
>>> for i in range(100):
... if sought.isdisjoint(set(str(i))):
... found.append(i)
...
>>> found
[1, 2, 3, 5, 7, 9, 11, 12, 13, 15, 17, 19, 21, 22, 23, 25, 27, 29, 31, 32, 33, 35, 37, 39, 51, 52, 53, 55, 57, 59, 71, 72, 73, 75, 77, 79, 91, 92, 93, 95, 97, 99]
大多数时候,每次你让自己创造一个for
环路滤波迭代器的时候,你真正需要的是一个list comprehension:
>>> [i for i in range(100) if sought.isdisjoint(set(str(i)))]
[1, 2, 3, 5, 7, 9, 11, 12, 13, 15, 17, 19, 21, 22, 23, 25, 27, 29, 31, 32, 33, 35, 37, 39, 51, 52, 53, 55, 57, 59, 71, 72, 73, 75, 77, 79, 91, 92, 93, 95, 97, 99]
或者,用笨拙,但更多的新手友好构建:
>>> [i for i in range(100) if not ('0' in str(i) or '4' in str(i) or '6' in str(i) or '8' in str(i))]
[1, 2, 3, 5, 7, 9, 11, 12, 13, 15, 17, 19, 21, 22, 23, 25, 27, 29, 31, 32, 33, 35, 37, 39, 51, 52, 53, 55, 57, 59, 71, 72, 73, 75, 77, 79, 91, 92, 93, 95, 97, 99]
你还在修改'test'在遍历它。 –
你是对的,我只是试图接近这个问题。我会修复我的答案 –
谢谢,但即使你愿意,这也会是公平的:) –