装饰器的应用场景

  • 应用一:装饰器实现一个函数计时器,可以计算出函数的运行时间
问题一:被装饰的函数有返回值
问题二:如何保留被装饰函数的函数名和帮助信息文档

装饰器的应用场景_第1张图片
装饰器的应用场景_第2张图片
装饰器的应用场景_第3张图片
装饰器的应用场景_第4张图片
装饰器的应用场景_第5张图片
装饰器的应用场景_第6张图片
装饰器的应用场景_第7张图片
装饰器的应用场景_第8张图片
装饰器的应用场景_第9张图片
装饰器的应用场景_第10张图片

  • 应用二:创建装饰器, 要求如下:
创建add_log装饰器, 被装饰的函数打印日志信息;装饰器的功能是打印函数的日志信息
日志格式为: [字符串时间] 函数名: xxx, 运行时间:xxx, 运行返回值结果:xxx

装饰器的应用场景_第11张图片
装饰器的应用场景_第12张图片

  • 应用三:判断用户是不是root用户,root用户可以添加和删除
判断是否为管理员root登陆,如果为root登陆,则显示相应的信息
inspect.getcallargs返回一个字典,key值:形参 value值:对应的实参

装饰器的应用场景_第13张图片
装饰器的应用场景_第14张图片
在这里插入图片描述
装饰器的应用场景_第15张图片
在这里插入图片描述

你可能感兴趣的:(python,装饰器的应用场景)