python学习-装饰器(可变参装饰器、完善装饰器)

可变参装饰器

*args表示任何多个无名参数,它是一个tuple;**kwargs表示关键字参数,它是一个dict。
并且同时使用*args和**kwargs时,必须*args参数列要在**kwargs前。

下列代码中用到的一些知识点,如:
import functools
@functools.wraps(a_func)等,在本文后续会有说明。


import functools


def a_new_decorator(a_func):
    @functools.wraps(a_func)
    def wrapTheFunction(*args, **kwargs):
        print(a_func.__name__)

        print("I am doing some boring work before executing a_func()")
        a_func(*args, **kwargs)
        print("I am doing some boring work after executing a_func()")

    return wrapTheFunction


@a_new_decorator
def a_function_requiring_decoration3(a1, a2, a3):
    print("a1 = {}\na2 = {}\na3 = {}".format(a1, a2, a3))


@a_new_decorator
def a_function_requiring_decoration2(a1, a2):
    print("a1 = {}\na2 = {}".format(a1, a2))


@a_new_decorator
def a_function_requiring_decoration1(a1):
    print("a1 = {}".format(a1))


a_function_requiring_decoration1('123')
a_function_requiring_decoration2('123', '456')
a_function_requiring_decoration3('123', '456', '789')

这部分代码主要是为了介绍装饰器可变参的情形。适配多种情况。
运行结果:
在这里插入图片描述

完善装饰器

上一篇博文里面讲到了装饰器,由于时间原因,我自己理解得并不透彻。
所以今天对于这部分内容进行了深入了解。

	函数注释   """回车"""	在PyCharm中输入三个双引号"""然后回车,注释就出来了
	类似这样:
	"""
    a_new_decorator
    :param a_func:
    :return: wrapTheFunction
    """

写注释的好处在于,我们调用 print(a_func.doc) 即可打印出函数注释,这样就能知道调用到那个函数,并且函数注释的内容都清楚了。也方便我们理解装饰器,因为引入了装饰器,通过打印__name__和__doc__,我们就能很清楚的知道调用了哪个函数。

在python里面,可以通过引入内置模块,快速的赋值函数的属性。
我这里用一些代码来演示:


def a_new_decorator(a_func):
    def wrapTheFunction(*args, **kwargs):
        """
        a_new_decorator
        :param a_func:
        :return: wrapTheFunction
        """

        print(a_func.__name__)

        print("I am doing some boring work before executing a_func()")
        a_func(*args, **kwargs)
        print("I am doing some boring work after executing a_func()")

    return wrapTheFunction


@a_new_decorator
def a_function_requiring_decoration():
    """
    a_function_requiring_decoration
    :return: None
    """
    print("I am the function which needs some decoration to "
          "remove my foul smell")


print("__name__ = ", a_function_requiring_decoration.__name__)
print("__doc__ = ", a_function_requiring_decoration.__doc__)

以上代码中,我添加了注释,用于区分调用的函数。
查看运行结果:
在这里插入图片描述

这里打印的是装饰器里面定义的函数(wrapTheFunction)的信息。如果我们想要知道传入的函数的一些属性信息,需要引入内置模块 functools。
引入的两种方式:


from functools import wraps
import functools

对应的使用方式:


def a_new_decorator(a_func):
    @functools.wraps(a_func)
    @wraps(a_func)
    def wrapTheFunction(*args, **kwargs):
        """
        a_new_decorator
        :param a_func:
        :return: wrapTheFunction
        """

        print(a_func.__name__)

        print("I am doing some boring work before executing a_func()")
        a_func(*args, **kwargs)
        print("I am doing some boring work after executing a_func()")

    return wrapTheFunction

@functools.wraps(a_func)和@wraps(a_func)是相同的,引入一个即可。
运行结果:
在这里插入图片描述

在a_new_decorator函数中打印的就是我们传入的方法的属性了。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
学习Python装饰器可以通过以下步骤进行: 1. 了解装饰器的概念和作用:装饰器是一种用于修改函数或类行为的函数,它可以在不修改原始函数代码的情况下添加额外的功能。装饰器可以用于日志记录、性能分析、权限校验等场景。 2. 学习装饰器的语法:装饰器是一个函数,它接受一个函数作为参数,并返回一个新的函数。装饰器通常使用`@`符号将其应用于目标函数。 3. 理解装饰器的执行顺序:装饰器是从上到下依次执行的,最后返回的函数将替换原始函数。 4. 掌握装饰器的常见应用场景:包括引入日志、函数执行时间统计、执行函数前预备处理、执行函数后清理功能、权限校验和缓存等。 5. 阅读相关的学习资料和示例代码:可以考《深入浅出学习Python装饰器》和《Python装饰器学习总结》等文章,其中提供了详细的解释和示例代码,有助于更好地理解和掌握装饰器的使用。 以下是一个示例代码,演示了如何使用装饰器来统计函数的执行时间[^2]: ```python import time def timeit(func): def wrapper(*args, **kwargs): start_time = time.time() result = func(*args, **kwargs) end_time = time.time() execution_time = end_time - start_time print(f"函数 {func.__name__} 的执行时间为 {execution_time} 秒") return result return wrapper @timeit def my_function(): # 函数的具体实现 time.sleep(2) my_function() ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值