这个看起来可以工作,并且应该能处理任何可迭代对象,不仅限于list
。它会尽可能地短路以最大化效率。在Python 2和3中都可以使用。
def only1(iterable):
for i, x in enumerate(iterable):
if x: break
else:
return False
for x in iterable[i+1:]:
if x: return False
return True
testcases = [
[[ ], False],
[[False, False, False, False], False],
[[True, False, False, False], True],
[[False, True, False, False], True],
[[False, False, False, True], True],
[[True, False, True, False], False],
[[True, True, True, True], False],
]
for i, testcase in enumerate(testcases):
correct = only1(testcase[0]) == testcase[1]
print('only1(testcase[{}]): {}{}'.format(i, only1(testcase[0]),
'' if correct else
', error given '+str(testcase[0])))
输出:
only1(testcase[0]): False
only1(testcase[1]): False
only1(testcase[2]): True
only1(testcase[3]): True
only1(testcase[4]): True
only1(testcase[5]): False
only1(testcase[6]): False
(= 1 (count-if #'identity list))
。 - KazTrue
或只有一个 truthy 值吗? - Marcinsum([0.5, 0.5])
- naught101