Python中的Decorator装饰器的使用示例

 更新时间:2022年12月01日 10:41:22   作者:漂泊的小森  
装饰器(decorator)在Python框架中扮演着重要角色,是Python中实现切面编程(AOP)的重要手段,本文将通过简单的示例和大家介绍下具体的使用方法,希望对大家有所帮助

#最近在网上看代码时,出现了@???的代码,看了好久也不知道是什么意思,经过了解原来是装饰器,我给大家举个例子讲解一下,帮助大家快速理解:

##大家在写函数的时候,可能会想测试这个函数的运行时间,如果每个函数都加一个类似于:

start=time.time()
函数主体
over=time.time()
Time=over-start
print(Time)
def haha():
    start=time.time()
    for i in range(1200):
        if i%2==0:
            print('这是个偶数:',i)
    over=time.time()
    print("总共花费的时间:",over-start)
haha()

这样函数的可读性也不高,如果要测试好几个函数还会大量浪费时间。

下面引入装饰器:

1简单的装饰器操作:

(先定义一个函数1(里面传递一个参数),然后在函数1里面再定义一个函数2负责计算时间,并在时间中间调用定义函数1的参数,然后返回这个函数2):

!!!当我们想调用装饰器时,只需@函数1的名字,放在想要使用的函数前面即可。

import time
def decorator(fun):
    def wrapper():
        t1=time.time()
        fun()
        t2=time.time()
        print('总共花费的时间:',t2-t1)
    return wrapper
@decorator
def haha():
    #start=time.time()
    for i in range(1200):
        if i%2==0:
            print('这是个偶数:',i)
    #over=time.time()
    #print("总共花费的时间:",over-start)
haha()

2,装饰器升级版(如果我们想套用的函数中,具有返回对应的值这个功能共时使用):

例如这个函数:

def haha():
    a=0
    #start=time.time()
    for i in range(1200):
        if i%2==0:
            print('这是个偶数:',i)
            a=a+i
    return a

#我们如果还用1中的装饰器就不能返回对应的值,这就需要改动装饰器:

(在装饰器中也要把函数中定义参数的返回值给表示出来,并且利用return 给返回值,输出出来)

import time
def decorator1(fun):
    def wrapper2():
        t1=time.time()
        result=fun()
        t2=time.time()
        print('总共花费的时间:',t2-t1)
        return result
    return wrapper2
@decorator1
def haha():
    a=0
    #start=time.time()
    for i in range(1200):
        if i%2==0:
            print('这是个偶数:',i)
            a=a+i
    return a
    #over=time.time()
    #print("总共花费的时间:",over-start)
aaa=haha()
print(aaa)

可能有同学会问,为什么后面要用到aaa=haha(),

这是因为我们要接受返回值result,并将其用print()打印出来。

3,装饰器的升级升级版(当我们需要使用的函数haha中,不但有返回值,还有传入的参数时使用。)

(只需要在我们的函数2和调用的函数1中的参数()里面加上关键字传参*args,即可)

import time
def decorator1(fun):
    def wrapper2(*args):
        t1=time.time()
        result=fun(*args)
        t2=time.time()
        print('总共花费的时间:',t2-t1)
        return result
    return wrapper2
@decorator1
def haha(key):
    a=0
    #start=time.time()
    for i in range(key):
        if i%2==0:
            print('这是个偶数:',i)
            a=a+i
    return a
    #over=time.time()
    #print("总共花费的时间:",over-start)
aaa=haha(1200)
print(aaa)

可不要忘了,调用函数haha时要传入参数哦。

到此这篇关于Python中的Decorator装饰器的使用示例的文章就介绍到这了,更多相关Python Decorator内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python基础教程之循环语句(for、while和嵌套循环)

    Python基础教程之循环语句(for、while和嵌套循环)

    这篇文章主要给大家介绍了关于Python基础教程之循环语句(for、while和嵌套循环)的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • Sphinx生成python文档示例图文解析

    Sphinx生成python文档示例图文解析

    这篇文章主要介为大家绍了Sphinx生成python文档示例图文解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪
    2022-04-04
  • python实现的希尔排序算法实例

    python实现的希尔排序算法实例

    这篇文章主要介绍了python实现的希尔排序算法,实例分析了基于Python实现希尔排序的相关技巧,需要的朋友可以参考下
    2015-07-07
  • Python中的pprint折腾记

    Python中的pprint折腾记

    这篇文章主要介绍了Python中的pprint折腾记,本文着重讲解pprint的使用,并给出使用实例,需要的朋友可以参考下
    2015-01-01
  • Python执行遗传编程gplearn库使用实例探究

    Python执行遗传编程gplearn库使用实例探究

    这篇文章主要为大家介绍了Python执行遗传编程gplearn库使用实例探究,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2024-01-01
  • 使用wxpy实现自动发送微信消息功能

    使用wxpy实现自动发送微信消息功能

    这篇文章主要介绍了使用wxpy实现自动发送微信消息功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-02-02
  • Python Traceback(most recent call last)报错信息:示例解读

    Python Traceback(most recent call last)报错信息:示例解读

    这篇文章主要介绍了Python Traceback(most recent call last)报错信息:示例解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • 浅谈Python pygame绘制机制

    浅谈Python pygame绘制机制

    今天给大家带来的是关于Python的相关知识,文章围绕着Python pygame绘制机制展开,文中有非常详细的介绍及图文示例,需要的朋友可以参考下
    2021-06-06
  • 基于Python编写windows电脑用户操作记录查看器

    基于Python编写windows电脑用户操作记录查看器

    这篇文章主要为大家详细介绍了如何基于Python编写一个windows电脑用户操作记录查看器,可以读取系统现有的日志记录用户,感兴趣的小伙伴可以了解下
    2025-02-02
  • Python 函数装饰器应用教程

    Python 函数装饰器应用教程

    函数装饰器是Python提供的一种增强函数功能的标记函数,本文将带大家深入学习一下Python 函数装饰器,感兴趣的同学跟随小编一起学习吧
    2021-12-12

最新评论