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 .
装饰者应该看起来像:
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)
我试图使用三元运算符,但它们没有正确评估.
Run Code Online (Sandbox Code Playgroud)def func(inp): return int(inp['value']) + 1 if inp else False抛出一个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)