当前位置: 首页 > wzjs >正文

免费个人简历优化seo报价

免费个人简历,优化seo报价,wordpress弹幕插件,深圳设计人才网🧩 Python小练习系列 Vol.13:用装饰器记录函数执行时间 本节是 Python 小练习系列的一个子题,带你理解并动手写出一个能实用、可拓展的装饰器。 🎯 练习目标 理解 Python 装饰器(Decorator)的工作原理&…

🧩 Python小练习系列 Vol.13:用装饰器记录函数执行时间

本节是 Python 小练习系列的一个子题,带你理解并动手写出一个能实用、可拓展的装饰器。


🎯 练习目标

  • 理解 Python 装饰器(Decorator)的工作原理;
  • 学会使用 @ 装饰器语法糖;
  • 编写一个记录函数运行时间的装饰器;
  • 掌握 functools.wraps 的正确使用方式;
  • 探索装饰器进阶应用场景。

🧠 一分钟理解什么是装饰器

“不改原函数的代码,就能给它增加功能?”

是的!装饰器是 Python 中的一种语法糖,它其实是一个返回函数的函数。装饰器常用于日志记录、权限验证、性能统计、缓存等场景。

举个例子:

def greet():print("Hello!")# 给 greet 函数加个装饰器:
def shout_decorator(func):def wrapper():print("Before call!")func()print("After call!")return wrappergreet = shout_decorator(greet)
greet()

输出:

Before call!
Hello!
After call!

换成语法糖的写法就是:

@shout_decorator
def greet():print("Hello!")

💡 我们的练习:计时装饰器 @timeit

目标功能:

  • @timeit 装饰任意函数;
  • 执行前记录函数名;
  • 执行后打印运行时间(精确到毫秒);
  • 返回原函数的执行结果。

🔧 步骤 1:基础版装饰器

import timedef timeit(func):def wrapper(*args, **kwargs):print(f"⏱ 正在执行函数: {func.__name__}")start = time.time()result = func(*args, **kwargs)end = time.time()print(f"✅ 函数 {func.__name__} 执行完成,用时 {end - start:.4f} 秒")return resultreturn wrapper

用法示例:

@timeit
def add(a, b):time.sleep(0.5)return a + bprint(add(10, 20))

输出:

⏱ 正在执行函数: add
✅ 函数 add 执行完成,用时 0.5003 秒
30

⚠️ 步骤 2:加入 functools.wraps 避免元信息丢失

import functoolsdef timeit(func):@functools.wraps(func)def wrapper(*args, **kwargs):print(f"⏱ 正在执行函数: {func.__name__}")start = time.time()result = func(*args, **kwargs)end = time.time()print(f"✅ 函数 {func.__name__} 执行完成,用时 {end - start:.4f} 秒")return resultreturn wrapper

🧪 步骤 3:再测几个函数

@timeit
def multiply(a, b):time.sleep(0.8)return a * b@timeit
def say_hello(name):print(f"Hello, {name}!")multiply(3, 4)
say_hello("Python")

🚀 进阶挑战(可选)

1. 参数化装饰器(带参数的装饰器)

def timeit(verbose=True):def decorator(func):@functools.wraps(func)def wrapper(*args, **kwargs):if verbose:print(f"⏱ 正在执行函数: {func.__name__}")start = time.time()result = func(*args, **kwargs)end = time.time()if verbose:print(f"✅ 函数 {func.__name__} 执行完成,用时 {end - start:.4f} 秒")return resultreturn wrapperreturn decorator@timeit(verbose=False)
def fast_add(a, b):return a + b

2. 装饰异步函数(使用 asyncio

import asynciodef async_timeit(func):@functools.wraps(func)async def wrapper(*args, **kwargs):start = time.time()result = await func(*args, **kwargs)end = time.time()print(f"✅ 异步函数 {func.__name__} 执行完成,用时 {end - start:.4f} 秒")return resultreturn wrapper@async_timeit
async def async_task():await asyncio.sleep(1)asyncio.run(async_task())

📌 总结

技能点说明
@装饰器增强函数功能的利器
*args, **kwargs保证适配各种函数参数
functools.wraps保持原函数元信息
参数化装饰器更加灵活的扩展方式
异步函数装饰器用于 async def 函数的异步装饰器

📚 推荐练习拓展

  • 写一个权限检查装饰器(只允许 admin 用户执行函数);
  • 写一个函数缓存装饰器(简单 LRU 缓存);
  • 写一个失败自动重试的装饰器(异常自动重试 N 次);
  • 把多个装饰器组合使用,看函数执行顺序。

如果这篇内容对你有帮助,
欢迎 点赞 👍 | 收藏 ⭐ | 关注 ❤️
如果你有更好的想法,欢迎评论区留言分享~

http://www.dtcms.com/wzjs/281876.html

相关文章:

  • 永康网站建设专业公司做广告推广哪个平台好
  • 网站建设的财务分析小程序排名优化
  • 个人网站免费做互联网培训
  • 网站开发一个多少钱啊怎么优化一个网站关键词
  • 傻瓜式在线做网站互联网推广引流
  • 网站建设美化中期报告seo服务商排名
  • 网站建设人员任职要求培训课程有哪些
  • 网站建设与维护管理办法全面网络推广营销策划
  • 海外浏览器搜索引擎优化seo公司
  • 乌鲁木齐可以做网站的公司seo的理解
  • 微信网站响应式网站顶尖文案网站
  • 电商商城系统免费海淀区seo全面优化
  • web网站开发使用直播源重庆企业seo
  • 做网站的属于什么岗位长沙网络推广哪家
  • 做网站申请多少类商标兰州网络seo
  • 导购类wordpress cms外汇seo公司
  • 做网站用什么工具好app推广接单发布平台
  • 网站的建设费计入什么费用视频外链工具
  • 怎么做废品网站推广app赚佣金
  • 泉州服装网站建设进入百度app查看
  • 长沙仿站定制模板建站360搜索网址是多少
  • 定制网站制作平台网站的宣传与推广
  • 做学校后台网站用什么浏览器打广告
  • 珠海网站建设 科速产品推广软件有哪些
  • 真分析对比他们的功能及特点_提出自己对政府门户网站建设的见解.seo资讯网
  • 文化集团网站模板最近时事热点
  • 做企业网站服务器在国外营销策划公司靠谱吗
  • 17网站一起做网店普宁网络公司推广方案
  • 宝鸡专门做网站的公司河源seo
  • 网站权重是什么最热门的短期培训课程