[Python] @NotNull装饰器如何写比较好?
问题描述
实际现象Java中的 @NotNull, @Nullable (by jetbrains): https://www.jetbrains.com/hel...
Python中可以用装饰器实现, 但是目前没找到细粒度控制的: https://www.google.com/search...
预期现象希望提供一种细粒度控制的, 即: 具体到每一个参数的控制
只希望检查空指针即可, 类型限定不做
相关代码手动的, 繁琐的写法
def func(param1, param2, param3): # 明确表示, 不接受空指针(这里写法很繁琐, 是否有简化方法?) if not ((param1 is not None) and (param2 is not None) and (param3 is not None)):raise TypeError(’%s or %s or %s is None’ % (param1, param2, param3)) # 正常函数逻辑
装饰器的写法(未实现)
@not_null(param1, param2)def func(param1, param2, param3, *args, **kw):上下文环境
Python 3.5
问题解答
回答1:from functools import wrapsdef allow_jsonp(fun): @wraps(fun) def wrapper_fun(*args, **kwargs):for a in args: if not a:return ’args is null’return fun(*args, **kwargs) return wrapper_fun@allow_jsonpdef a(a): print (111111111)print (a(0))回答2:
from functools import wrapsdef not_none(func): @wraps(func) def wrapper(*args, **kwargs):if (None in args) or (None in kwargs.values()): raise ValueError(’Arguments must be not None’)else: return func(*args, **kwargs) return wrapper
相关文章:
1. mysql - 分库分表、分区、读写分离 这些都是用在什么场景下 ,会带来哪些效率或者其他方面的好处2. 图片链接的地址怎么获得的3. python - oslo_config4. mysql - 如何减少使用或者不用LEFT JOIN查询?5. mysql - jdbc的问题6. mysql - eclispe无法打开数据库连接7. mysql 5个left关键 然后再用搜索条件 几千条数据就会卡,如何解决呢8. 视频文件不能播放,怎么办?9. mysql - 千万级数据的表,添加unique约束,insert会不会很慢?10. html5 - H5 audio 微信端 在IOS上不能播放音乐
