装饰器主要作用个人认为主要就是用来扩展一个函数的功能,在不改变原来函数的主逻辑的情况下 。
一般装饰器的格式为
装饰器的基本格式(利用闭包的特性)
说明*会把接收到的参数形成一个元组,而**则会把接收到的参数存入一个字典( 函数参数(必选参数、默认参数、可选参数、关键字参数))
def fun1(fun_name):#这里的fun_name为传入的是被装饰函数的名字
def wrapper(*args,**kwargs)#这里传入的参数是被装饰函数需要的参数
pass
return wrapper#返回wrapper的引用即引用也就是指针
例如web开发中,要防止xss注入的时候就可以用装饰器来检测用户的的输入是否合法
def checkxss(func):
def contain_special_characters(v):
special_characters_list = [r'<', r'>', ]
for character in special_characters_list:
if character in v:
return True
return False
@functools.wraps(fun)
def check_special_characters(*args, **kwargs):
request = args[0]
post_data = request.POST
get_data = request.GET
for v in post_data.values():
if contain_special_characters(v):
return HttpResponse(json.dumps({'r': 11, 'e': '请输入合法字符'}, ensure_ascii=False))
for v in get_data.values():
if contain_special_characters(v):
return HttpResponse(json.dumps({'r': 11, 'e': '请输入合法字符'}, ensure_ascii=False))
return func(*args, **kwargs)
return check_special_characters
@checkxss
def rename(request):
ident = request.POST.get('id', 'none')
name = request.POST.get('name', 'none')
统计函数运行的时间
import datetime
def count_time(func):
def int_time(*args, **kwargs):
start_time = datetime.datetime.now() # 程序开始时间
func()
over_time = datetime.datetime.now() # 程序结束时间
total_time = (over_time-start_time).total_seconds()
print('程序共计%s秒' % total_time)
return int_time
@count_time
def main():
print('>>>>开始计算函数运行时间')
for i in range(1, 1000): # 可以是任意函数 , 这里故意模拟函数的运行时间
for j in range(i):
print(j)
if __name__ == '__main__':
main()
补充
#闭包函数的实例
def func(c, d):
a = 7
def fun(j, k):
b = 9
print(b + a + c + d + j + k)
# 外函数的返回值是内函数的引用
return fun
func(1, 3)(6, 5)