[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. Navicat for mysql 中以json格式储存的数据存在大量反斜杠,如何去除?2. mysql建表报错,查手册看不懂,求解?3. mysql - 查询数据库某个字段不重复的值,按时间排序,如何写呢?4. mysql - 在PHPMyadmin上乱捣鼓后出现 了 - #2002 - — 服务器没有响应(或本地服务器的套接字没有正确设置)。5. 数组排序,并把排序后的值存入到新数组中6. mysql - 数据库多表联合查询插入其他库7. php多任务倒计时求助8. javascript - 用了koa mysql2 一直出现一个error9. vue打包和PHP后台怎样同域名部署配置10. phpStudy怎么把mysql升级到7.x
