标签:app pac nbsp 因此 情况 container **kwargs fun wrap
在不想修改函数的调用方式,但是想给函数添加内容的功能的时候使用
1
2 3 4 5 6 |
# 装饰器的固定模式
def wrapper(func): def inner(*args, **kwargs): ret = func(*args, **kwargs) return ret return inner |
1
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 |
# -*- coding:utf-8 -*-
# 上面为一个正常的函数调用 # 但是假使我在不修改函数内容的前下给函数打印出函数的运行时间这这里就要使用到装饰器 import time def wrapper(func): def inner(*args, **kwargs): start_time = time.time() print(‘nihao‘) ret = func(*args, **kwargs) end_time = time.time() print(end_time-start_time) return ret return inner # 定义一个函数func2 @wrapper # 语法糖,给下面的函数做装饰 等于调用了func2 = wrapper(func2) def func2(a): print("hello") return a+1 ret = func2(2) # 这里的func2其实是指向了inner的地址,函数名称不变 print(ret) # 这里成功的在不改变调用函数的前提下完成了函数的修改 |
装饰器的本质就是在函数嵌套中调用被装饰的函数,用来增加函数的灵活性!
标签:app pac nbsp 因此 情况 container **kwargs fun wrap
原文地址:https://www.cnblogs.com/fandx/p/9346245.html