2022.04.14-python学习之装饰器
1 # File : learning_012_decorators.py.py 2 # Datetime : 2022/4/14 0014 3:27 3 4 import time 5 6 7 # 装饰器 8 # 本质上,装饰器是一个函数,用来处理其他函数, 9 # 可以让其他函数在不需要修改代码的前提下增加额外的功能,装饰器返回的对象也是一个函数. 10 11 # 常用的装饰器需求场景有:插入日志、性能检测、事务处理、缓存、权限校验等 12 13 # 代码演练装饰器场景示例: 代码性能检测,可以选择性的插入日志 14 def insert_log(flag=False): 15 def show_time(function_name): 16 def wrapper(): 17 start_date = time.time() 18 function_name() 19 time.sleep(1) # 设置程序停留时长 20 end_date = time.time() 21 if flag: 22 print("日志插入成功!") 23 print("程序执行时间为", end_date - start_date) 24 25 return wrapper 26 27 return show_time 28 29 30 # @show_time # 相当于my_function=show_time(my_function) 31 @insert_log(True) # 相当于insert_log=show_time(my_function) 32 def my_function(): 33 print("我的测试代码") 34 35 36 my_function()
分类:
python学习笔记
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示