如果Python 3中的参数为False,则寻找评估为False的惯用方法

Jef*_*wan 14 python python-3.x

我有一系列函数,都在类的其他地方定义:

fus(roh(dah(inp)))
Run Code Online (Sandbox Code Playgroud)

在哪里inp是字典,或bool(False).

所需的结果是,如果inp,或任何功能评估为False,False由函数栈返回.

我试图使用三元运算符,但它们没有正确评估.

def func(inp):
    return int(inp['value']) + 1 if inp else False
Run Code Online (Sandbox Code Playgroud)

抛出一个TypeError,bool不可订阅,如果i == False因为inp['value']在条件之前计算.

我知道我可以明确地做到:

def func(inp):
    if inp == False:
        return False
    else:
        return inp['value'] + 1
Run Code Online (Sandbox Code Playgroud)

但是有很多功能,这几乎会使我的代码长度增加四倍.它也一次又一次地重写完全相同的代码行,这对我来说这是错误的做事方式.

我怀疑带有参数的装饰者就是答案,但是我玩的越多,我就越不确定.

def validate_inp(inp):
    def decorator(func):
        def wrapper(*args):
             return func(inp) if inp else False
        return wrapper
    return decorator

@validate_inp(inp)
def func(inp):
    return int(inp['value']) + 1
Run Code Online (Sandbox Code Playgroud)

不幸的是,装饰器调用抛出一个NameError,'inp'未定义.但我不确定我是否错误地使用了装饰器,或装饰器是错误的解决方案.

寻找评论,批评,建议和/或理智检查.


如果你发现这试图解决你自己的问题......

您可能希望使用空字典而不是布尔值False.道具到@chepner.

在我的应用程序中,使用False是"好的"bur没有提供任何优势,并导致一些庞大的代码块.

我发现使用空字典更简单了.我将使用dict的函数与一个装饰器包装起来,该装饰器通过引用dict['value']哪里dict为空来捕获引发的KeyError .

KAd*_*dot 9

装饰者应该看起来像:

def validate_inp(fun):
    def wrapper(inp):
        return fun(inp) if inp else False
    return wrapper


@validate_inp
def func(inp):
    return int(inp['value']) + 1

print(func(False))
print(func({'value': 1}))
Run Code Online (Sandbox Code Playgroud)

如果要将装饰器与类成员一起使用:

def validate_inp(fun):
    def wrapper(self, inp):
        return fun(self, inp) if inp else False
    return wrapper

class Foo(object):
    @validate_inp
    def func(self, inp):
        return int(inp['value']) + 1 if inp else False

foo = Foo()
print(foo.func(False))
print(foo.func({'value': 1}))
Run Code Online (Sandbox Code Playgroud)


Vee*_*rac 8

我试图使用三元运算符,但它们没有正确评估.

def func(inp):
    return int(inp['value']) + 1 if inp else False
Run Code Online (Sandbox Code Playgroud)

抛出一个TypeError,bool不可订阅,如果i == False因为inp['value']在条件之前计算.

这不是真的 - 代码有效.此外,你可以写

def func(inp):
    return inp and (int(inp['value']) + 1)
Run Code Online (Sandbox Code Playgroud)

要自动换行这样的函数,请创建一个包装函数的函数:

def fallthrough_on_false(function):
    def inner(inp):
        return inp and function(inp)
    return inner
Run Code Online (Sandbox Code Playgroud)

这应该通过使用functools.wraps装饰器和名称来改进,并且它应该采用可变数量的参数来允许可选的扩展:

from functools import wraps

def fallthrough_on_false(function):
    @wraps(function)
    def inner(inp, *args, **kwargs):
        return inp and function(inp, *args, **kwargs)
    return inner
Run Code Online (Sandbox Code Playgroud)