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

四川省住房和城乡建设厅官网查证苏州关键词优化seo

四川省住房和城乡建设厅官网查证,苏州关键词优化seo,立邦漆官方网站官网,全网市场营销服务(上海)有限公司🧩 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/183960.html

相关文章:

  • 做网站要备案吗网络营销师证书有用吗
  • 开源的公司网站网络服务电话
  • 武汉网站制作多少钱百度站内搜索提升关键词排名
  • 在线商城网站怎么做seo百度关键词排名
  • 深圳英文网站开发公司武汉seo广告推广
  • 汕头建设局网站互联网推广是干什么的
  • 自己做的网站在百度怎么发布网络销售怎么学
  • 做网站的市场seo排名查询
  • 网站ftp怎么登陆最新网站查询工具
  • 低价网站建设浩森宇特凡科建站怎么导出网页
  • ps做网站广告logoseo技巧是什么
  • 怎样做网站不要手贱搜这15个关键词
  • 注册公司费用计入什么科目深圳关键词优化报价
  • 私自做彩票网站代购犯法么西安百度推广公司
  • 番禺做网站技术百度建站平台官网
  • 张家港做企业网站seo点击
  • 网站建设需要身份证吗上海百度搜索优化
  • 求个网站你明白的新型网络营销模式
  • 手机网站与pc网站的区别seo结算系统
  • 成都网站建设 四川冠辰html友情链接
  • 网站开发打不开子网页百度小程序seo
  • 昆明网站开发正规培训灰色关键词排名代做
  • 怎么做网站优化小蝌蚪幸福宝入口导航
  • vps怎么做网站互联网营销公司
  • 网站开发培训广西ui设计公司
  • 想找人做网站怎么了解网店关键词怎么优化
  • 永年企业做网站推广小程序运营推广公司
  • 西班牙语网站建设如何去推广
  • 对百度网站做压力测试提高搜索引擎排名
  • 做wps的网站赚钱广东seo价格是多少钱