Python 装饰器详解:从入门到实战

Python 装饰器详解:从入门到实战

什么是装饰器?

装饰器(Decorator)是 Python 中的一种高级特性,它允许我们在不修改原函数代码的情况下,为函数添加新的功能。简单来说,装饰器就是一个"包装器",它可以在函数执行前后添加额外的逻辑。

装饰器的基本语法

装饰器使用 `@` 符号来表示,放在函数定义的上方:

```python

def my_decorator(func):

def wrapper():

print("函数执行前")

func()

print("函数执行后")

return wrapper

@my_decorator

def say_hello():

print("Hello!")

say_hello()

输出:

函数执行前

Hello!

函数执行后

```

带参数的装饰器

实际开发中,我们经常需要处理带参数的函数:

```python

def my_decorator(func):

def wrapper(*args, **kwargs):

print("函数执行前")

result = func(*args, **kwargs)

print("函数执行后")

return result

return wrapper

@my_decorator

def greet(name, age):

print(f"姓名:{name}, 年龄:{age}")

return "完成"

result = greet("张三", 25)

print(result)

```

实用的装饰器示例

1. 日志装饰器

```python

import functools

from datetime import datetime

def log_decorator(func):

@functools.wraps(func)

def wrapper(*args, **kwargs):

timestamp = datetime.now().strftime("%Y-%m-%d %H:%M:%S")

print(f"{timestamp} 调用函数:{func.name}")

result = func(*args, **kwargs)

print(f"{timestamp} 函数执行完成")

return result

return wrapper

@log_decorator

def calculate_sum(a, b):

return a + b

calculate_sum(10, 20)

```

2. 性能计时装饰器

```python

import time

import functools

def timing_decorator(func):

@functools.wraps(func)

def wrapper(*args, **kwargs):

start = time.time()

result = func(*args, **kwargs)

end = time.time()

print(f"{func.name} 执行时间:{end - start:.4f}秒")

return result

return wrapper

@timing_decorator

def slow_function():

time.sleep(1)

return "完成"

slow_function()

```

3. 重试装饰器

```python

import functools

import time

def retry_decorator(max_retries=3, delay=1):

def decorator(func):

@functools.wraps(func)

def wrapper(*args, **kwargs):

for i in range(max_retries):

try:

return func(*args, **kwargs)

except Exception as e:

if i == max_retries - 1:

raise

print(f"重试 {i + 1}/{max_retries}: {e}")

time.sleep(delay)

return wrapper

return decorator

@retry_decorator(max_retries=3, delay=2)

def risky_operation():

可能失败的操作

pass

```

类装饰器

装饰器不仅可以装饰函数,还可以装饰类:

```python

def singleton(cls):

instances = {}

def get_instance(*args, **kwargs):

if cls not in instances:

instancescls = cls(*args, **kwargs)

return instancescls

return get_instance

@singleton

class Database:

def init(self):

print("数据库连接已建立")

db1 = Database()

db2 = Database()

print(db1 is db2) # True

```

总结

装饰器是 Python 中非常强大的工具,合理使用可以让代码更加简洁、优雅。常见的应用场景包括:

  • 日志记录

  • 性能监控

  • 权限验证

  • 缓存机制

  • 事务处理

掌握装饰器,让你的 Python 代码更上一层楼!

相关推荐
用户83562907805111 小时前
Python 实现 PDF 文件加密与解密方法
后端·python
用户83562907805111 小时前
使用 Python 冻结与拆分 Excel 窗格教程
后端·python
你好潘先生19 小时前
别再记命令了,用 yeero do 说句人话就能跑脚本,而且不烧 token
服务器·python·命令行
Agent_大师20 小时前
WebSocket 行情重连成功,K线缺口不会自动消失
python
荣码20 小时前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python
copyer_xyf20 小时前
FastAPI 如何连接 MySQL
后端·python
apocelipes1 天前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
用户8356290780511 天前
使用 Python 在 PDF 中创建与管理书签
后端·python
MeixianAgent2 天前
Python 回测数据入口怎么验?历史 K 线入库前先做 5 个检查
后端·python
咕白m6252 天前
用 Python 实现一键批量查找与替换 Excel 数据
后端·python