知识点
1, 闭包函数,传入参数和返回值都是函数
2, 闭包函数的返回值函数是对传入函数的增强
没入门之前看这个知识点可能一头雾水,悟了以后就会认同的, 所以先记在心里就行.
并且装饰器也是python的一种语法糖.
它经常用于有切面需求的场景,比如:插入日志、性能测试、事务处理、缓存、权限校验等场景。
装饰器是解决这类问题的绝佳设计,有了装饰器,我们就可以抽离出大量与函数功能本身无关的雷同代码并继续重用。
概括的讲,装饰器的作用就是为已经存在的对象添加额外的功能。
推导过程就不一一列举了, 网上资料很多, 就不搬运过来了.
自己写的一个用于计算函数所用时间的源码如下
def plus_func(func_name): """ 闭包函数,传入参数和返回值都是函数 闭包函数的返回值函数是对传入函数的增强 """ def inner_func(*args, **kwargs): start_time = time.time() # 记录开始时间 result = func_name(*args, **kwargs) # 执行原函数 end_time = time.time() # 记录结束时间 use_time = round(end_time - start_time, 2) # 精确到0.01s logging.info("{}用时:{}s".format(func_name, use_time)) return result return inner_func
在其他函数的前面引用即可使用
@MyGlobal.plus_func def check_surf(self, netbars, start_time, end_time): """ 网址浏览轨迹查询 """