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

Python装饰器开发实践

Python装饰器开发实践:从语法糖到设计利器



装饰器的本质:语法糖背后的魔法



在Python的世界里,装饰器(Decorator)常被描述为“语法糖”,但这简单的比喻往往掩盖了其真正的威力。装饰器本质上是一个高阶函数,它接受一个函数作为参数,并返回一个新的函数。这种“函数包装函数”的模式,为代码的扩展和维护提供了优雅的解决方案。



让我们从一个最简单的装饰器开始:



```python
def simple_decorator(func):
def wrapper():
print("函数执行前")
result = func()
print("函数执行后")
return result
return wrapper



@simple_decorator
def greet():
print("Hello, World!")



greet()
输出:
函数执行前
Hello, World!
函数执行后
```



装饰器的进阶应用



1. 带参数的装饰器



实际开发中,我们经常需要装饰器能够接受参数,以实现更灵活的配置:



```python
def repeat(n):
"""重复执行函数的装饰器"""
def decorator(func):
def wrapper(args, kwargs):
results = []
for _ in range(n):
results.append(func(args, kwargs))
return results
return wrapper
return decorator



@repeat(3)
def say_hello(name):
print(f"Hello, {name}!")
return f"Greeted {name}"



say_hello("Alice")
```



2. 保留函数元信息



装饰器会覆盖原始函数的元信息(如函数名、文档字符串等),使用`functools.wraps`可以解决这个问题:



```python
from functools import wraps



def timing_decorator(func):
@wraps(func)
def wrapper(args, kwargs):
import time
start = time.time()
result = func(args, kwargs)
end = time.time()
print(f"{func.__name__}执行时间: {end - start:.4f}秒")
return result
return wrapper
```



装饰器在Web开发中的实践



在Web框架如Flask或FastAPI中,装饰器扮演着至关重要的角色:



```python
Flask路由装饰器示例
from flask import Flask, request, jsonify



app = Flask(__name__)



def require_auth(func):
@wraps(func)
def wrapper(args, kwargs):
token = request.headers.get('Authorization')
if not token or not validate_token(token):
return jsonify({"error": "未授权\

http://www.jsqmd.com/news/1106222/

相关文章:

  • step1. 调用摄像头
  • 给阿嬤一封来自云端的信(上)
  • NestJS框架教程
  • STM32与MAX9744实现高效音频放大系统设计
  • 量子计算中的基态制备与经典储层方法解析
  • 终极Win11系统优化指南:免费工具让你的Windows 11运行如飞
  • 游戏编程十年总结(下)
  • AI应用GEO排名优化指南:提升搜索可见性
  • 如何提取 Word 文档中的表格并导出为 Excel(Python 教程)
  • 第5章 Function Call 与工具调用框架《AI Agent 开发平台资深技术专家 AI Agent 应用架构师 CTO 面试题库详解》
  • 微架构安全:MDAV问题与防御机制集成挑战
  • JSON数据格式解析与应用
  • 【安全】Sql注入漏洞的危害和防御
  • Medisca在创始人Antonio Dos Santos的引领下开启发展新篇章
  • GPU监控与进程管理:科研必备的nvidia-smi详解
  • 6DoF运动跟踪技术:从IMU到姿态解算的实践指南
  • 【C++并发系列】第十二章:CPU cache line 和 false sharing
  • 打包带在高温环境下会变形吗?
  • Python代码重构最佳实践
  • Zephyr RTOS入门:设备树(DTS)与Kconfig配置体系——设备树、配置系统
  • 实测 Claude Sonnet 5 vs Claude Sonnet 4.6:别只看发布公告,API 跑起来才知道差距
  • Python集合使用技巧解析
  • 《代码随想录》刷题打卡day28:动态规划part01
  • 纯HTML离线项目零部署优化方案|单文件离线运行、无环境依赖 前言
  • 从0开始为Vue3+TS+Vite项目配置ESLint+Prettier
  • LTC6904与PIC18F86J11实现高精度时钟同步方案
  • 客服工单表怎么关联订单和玩家记录
  • 即时通信服务器架构的一些思考
  • 我把《易经》做成了AI,发现了沟通的底层规律
  • Go网络开发教程