web-dev-qa-db-ja.com

any()関数の反対

Python組み込み関数any(iterable)は、反復可能な型のbool(element)Trueであるかどうかをすばやく確認するのに役立ちます。

_>>> l = [None, False, 0]
>>> any(l)
False
>>> l = [None, 1, 0]
>>> any(l)
True
_

しかしPythonにany(iterable)の反対の効果を達成できるエレガントな方法または関数はありますか?つまり、bool(element) is FalseがあればTrue、次の例のように:

_>>> l = [True, False, True]
>>> any_false(l)
>>> True
_
63
Ekeyme Mo

all関数もあります。これは、必要なものとは逆の処理を行います。すべてがTrueである場合はTrueを返し、すべてがFalseである場合はFalseを返します。したがって、次のことができます。

not all(l)
112
Jack Aidley

カスタム条件をテストするジェネレーター式を作成します。デフォルトの真偽テストだけに縛られているわけではありません:

any(not i for i in l)
48
deceze

さて、anyの実装は equivalent と:

def any(iterable):
    for element in iterable:
        if element:
            return True
    return False

したがって、条件をif elementからif not elementに切り替えるだけです。

def reverse_any(iterable):
    for element in iterable:
        if not element:
            return True
    return False

はい、もちろんこれは組み込みのanyまたはallの速度を利用しません答えはありますが、それは読みやすいニースです。

できるよ:

_>>> l = [True, False, True]
>>> False in map(bool, l)
True
_

map in Python 3はジェネレータです。Python 2の場合、おそらくimapを使用したいことを思い出してください。


Mea Culpa:これらのタイミングをとった後、私が提供した方法は手がかりで最も遅い

最速のものはnot all(l)またはnot next(filterfalse(bool, it), True)で、これは単なる愚かなitertoolsの変形です。 Jack Aidleys solution を使用します。

タイミングコード:

_from itertools import filterfalse

def af1(it):
    return not all(it)

def af2(it):
    return any(not i for i in it)   

def af3(iterable):
    for element in iterable:
        if not element:
            return True
    return False    

def af4(it):
    return False in map(bool, it)   

def af5(it):
    return not next(filterfalse(bool, it), True)    

if __name__=='__main__':
    import timeit   
    for i, l in enumerate([[True]*1000+[False]+[True]*999, # False in the middle
                           [False]*2000, # all False
                            [True]*2000], # all True
                            start=1): 
        print("case:", i)
        for f in (af1, af2, af3, af4, af5):
            print("   ",f.__name__, timeit.timeit("f(l)", setup="from __main__ import f, l", number=100000), f(l) )
_

結果:

_case: 1
    af1 0.45357259700540453 True
    af2 4.538436588976765 True
    af3 1.2491040650056675 True
    af4 8.935278153978288 True
    af5 0.4685744970047381 True
case: 2
    af1 0.016299808979965746 True
    af2 0.04787631600629538 True
    af3 0.015038023004308343 True
    af4 0.03326922300038859 True
    af5 0.029870904982089996 True
case: 3
    af1 0.8545824179891497 False
    af2 8.786235476000002 False
    af3 2.448748088994762 False
    af4 17.90895140200155 False
    af5 0.9152941330103204 False
_
9
dawg