• 强大而灵活的python装饰器


    装饰器(Decorators)

    一、概述

    在Python中,装饰器是一种特殊类型的函数,它允许我们修改或增强其他函数的功能,而无需修改其源代码。装饰器在函数定义之后立即调用,并以函数对象作为参数。装饰器返回一个新的函数对象,这个新函数对象通常会“包装”或“装饰”原函数,并在调用时执行额外的操作。

    二、基本用法

    装饰器的基本语法是使用@符号,后面紧跟装饰器函数的名称。装饰器函数通常接收一个函数作为参数,并返回一个新的函数。

    1. @decorator_function
    2. def my_function():
    3. pass

    在上面的代码中,decorator_function是一个装饰器,它接收my_function作为参数,并返回一个新的函数对象。这个新的函数对象在调用时会执行decorator_function中定义的代码,并在适当的时候调用my_function

    三、装饰器函数

    装饰器函数通常接收一个函数作为参数,并返回一个新的函数。装饰器函数内部的新函数通常会调用原函数,并在调用前后执行额外的操作。

    1. def decorator_function(func):
    2. def wrapper(*args, **kwargs):
    3. # 在原函数执行前执行的代码
    4. print("Before function call")
    5. # 调用原函数
    6. result = func(*args, **kwargs)
    7. # 在原函数执行后执行的代码
    8. print("After function call")
    9. return result
    10. return wrapper

    四、使用装饰器

    使用装饰器非常简单,只需在函数定义之前加上@符号和装饰器函数的名称即可。

    1. @decorator_function
    2. def my_function():
    3. print("Inside function")
    4. # 调用被装饰的函数
    5. my_function()

    五、使用装饰器的测试示例

    下面是一个使用装饰器来实现基准测试的示例:

    1. import time
    2. from functools import wraps
    3. def benchmark(func):
    4. """
    5. 基准测试装饰器,用于测量函数的执行时间。
    6. 参数:
    7. func (callable): 要测试的函数。
    8. 返回:
    9. callable: 装饰后的函数,它会打印原始函数的执行时间。
    10. """
    11. @wraps(func)
    12. def wrapper(*args, **kwargs):
    13. start_time = time.time()
    14. result = func(*args, **kwargs)
    15. end_time = time.time()
    16. elapsed_time = end_time - start_time
    17. print(f"执行 {func.__name__} 花费了 {elapsed_time:.6f} 秒")
    18. return result
    19. return wrapper
    20. # 示例函数,我们将对其应用基准测试装饰器
    21. @benchmark
    22. def example_function(n):
    23. sum = 0
    24. for i in range(n):
    25. sum += i
    26. return sum
    27. # 调用示例函数,装饰器会自动打印执行时间
    28. print(example_function(1000000))

    在这个例子中,benchmark 是一个装饰器函数,它接受一个函数作为参数,并返回一个新的函数 wrapperwrapper 函数会记录开始和结束时间,然后调用原始函数并打印出执行时间。@wraps(func) 是一个内置装饰器,用于保留原始函数的元信息(如函数名、文档字符串等)。

    通过在 example_function 定义之前使用 @benchmark 装饰器,我们告诉Python在调用 example_function 时实际上要调用的是 wrapper 函数,而 wrapper 函数会记录并打印出 example_function 的执行时间。

    使用装饰器的好处是你可以在不修改原始函数的情况下轻松添加新功能,例如基准测试。这使得代码更加模块化且易于维护。

    六、装饰器的高级用法

    1、多个装饰器

    一个函数可以同时使用多个装饰器,只需在函数定义前依次列出它们即可。

    1. @decorator1
    2. @decorator2
    3. def my_function():
    4. pass

    2、带参数的装饰器

    装饰器本身也可以接收参数,并在内部定义装饰器函数。

    1. def outer_decorator(param):
    2. def decorator_function(func):
    3. def wrapper(*args, **kwargs):
    4. print(f"Before function call with param: {param}")
    5. result = func(*args, **kwargs)
    6. print(f"After function call with param: {param}")
    7. return result
    8. return wrapper
    9. return decorator_function
    10. @outer_decorator("hello")
    11. def my_function():
    12. print("Inside function")
    13. my_function()

    七、注意事项

    • 装饰器会改变函数的名称和文档字符串,除非使用@wraps装饰器来保留这些信息。
    • 装饰器会改变函数的签名,这可能会影响依赖于函数签名的工具或库。
    • 装饰器可能会增加函数的调用开销,因为每次调用被装饰的函数时,都会执行额外的代码。

    八、总结

    装饰器是Python中一种强大而灵活的工具,它允许我们在不修改函数源代码的情况下,为函数添加额外的功能。通过正确使用装饰器,我们可以提高代码的可读性、可维护性和可扩展性。

    文心大模型3.5生成

  • 相关阅读:
    服务器的外网IP查阅方式
    Linux三剑客awk数组、判断、循环
    4 种策略让 MySQL 和 Redis 数据保持一致
    数据分析必备原理思路(二)
    广州穗雅医院【口腔健康揭秘】影响口腔白斑的4大因素
    【Python自学笔记】Flask调教方法Internel Server Error
    Node+koa之目录优化和sequelize的使用(五)
    C++学习笔记--函数重载(2)
    详解KubeEdge EdgeMesh v1.15 边缘CNI特性
    【无标题】
  • 原文地址:https://blog.csdn.net/skywalk8163/article/details/136407198