python 装饰器使用总结

简介: python 装饰器使用总结

python 装饰器使用总结


测试环境

win10

python 3.5

例1:一个简单的例子

#!/usr/bin/env python

# -*- coding:utf-8 -*-

 

__author__ = 'shouke'

 

def wrapper_method1(func):# func用于接收被装饰的函数地址

   def wrapper():

       print("执行wrapper_method1")

       func()#调用被装饰的函数

   return wrapper#返回方法地址,供执行被装饰函数前调用

 

@wrapper_method1#等同于wrapper_method1(myfunction)

def myfuntion():

   print("执行myfunction")

 

myfuntion()

 

运行结果:

执行wrapper_method1

执行myfunction

 

例2:装饰带参数函数

#!/usr/bin/env python

# -*- coding:utf-8 -*-

 

__author__ = 'shouke'

 

def wrapper_method1(func):

   def wrapper(name, age):#这里的参数列表和myfuntion参数列表保持一致

       print("执行wrapper_method1 name:%s age:%s" % (name, age))

       func(name, age)#记得给要调用的函数传递参数

   return wrapper

 

@wrapper_method1

def myfuntion(name, age):

    print("执行myfunction name:%s age:%s" % (name, age))

 

myfuntion('shouke', 'unknow')

 

运行结果:

执行wrapper_method1 name:shouke age:unknow

执行myfunction name:shouke age:unknow

 

#!/usr/bin/env python

# -*- coding:utf-8 -*-

 

__author__ = 'shouke'

 

def wrapper_method1(func):

   def wrapper(*args, **kwargs):

       print("执行wrapper_method1 args:", args)

       func(*args, **kwargs)

   return wrapper

 

@wrapper_method1

def myfuntion(*args,**kwargs):

   print("执行myfunction args:", args)

 

myfuntion('shouke', 'unknow')

 

运行结果:

执行wrapper_method1 args: ('shouke', 'unknow')

执行myfunction args: ('shouke', 'unknow')

例3:函数被多给装饰器方法装饰

#!/usr/bin/env python

# -*- coding:utf-8 -*-

 

__author__ = 'shouke'

 

def wrapper_method1(func):

   def wrapper(*args, **kwargs):

       print("执行wrapper_method1")

       func(*args, **kwargs)

   return wrapper

 

def wrapper_method2(func):

   def wrapper():

       print("执行wrapper_method2")

       func()

   return wrapper

 

@wrapper_method1

@wrapper_method2

def myfuntion():

   print("执行myfunction")

 

myfuntion()

 

运行结果:

执行wrapper_method1

执行wrapper_method2

执行myfunction

 

说明:装饰器方法执行顺序为从远到近,从上到下。

 

例4:在类中使用装饰器

#!/usr/bin/env python

# -*- coding:utf-8 -*-

 

__author__ = 'shouke'

 

def wrapper_method1(func):

   def wrapper(*args, **kwargs):

       print("执行wrapper_method1")

       func(*args, **kwargs)

   return wrapper

 

class MyClass:

   def __init__(self):

   pass

 

 

   @staticmethod

   @wrapper_method1

   def myfuntion():

       print("执行myfunction")

 

MyClass.myfuntion()

 

运行结果:

执行wrapper_method1

执行myfunction

 

例5:装饰器方法也可以是类函数

#!/usr/bin/env python

# -*- coding:utf-8 -*-

 

__author__ = 'shouke'

 

class MyClass2:

   @staticmethod

       def wrapper_method1(func):

       def wrapper(*args, **kwargs):

           print("执行wrapper_method1")

           func(*args, **kwargs)

   return wrapper

 

 

 

class MyClass:

   def __init__(self):

       pass

 

   @staticmethod

   @MyClass2.wrapper_method1

   def myfuntion():

       print("执行myfunction")

 

MyClass.myfuntion()

 

运行结果:

执行wrapper_method1

执行myfunction

需要注意的点

1、 即便被装饰函数拥有默认值也要显示传递参数,否则报错,如下:

 

#!/usr/bin/env python

# -*- coding:utf-8 -*-

 

__author__ = 'shouke'

 

def wrapper_method1(func):

   def wrapper(name, age):

       print("执行wrapper_method1 name:%s age:%s" % (name, age))

       func(name, age)

   return wrapper

 

@wrapper_method1

def myfuntion(name='shouke', age='unknow'):

   print("执行myfunction name:%s age:%s" % (name, age))

 

myfuntion()

 

运行结果:

TypeError: wrapper() missing 2 required positional arguments: 'name' and 'age'

 

2、 如果被装饰函数为类的静态函数时,@staticmethod必须位于最上方,否则报错,如下:

 

#!/usr/bin/env python

# -*- coding:utf-8 -*-

 

__author__ = 'shouke'

 

def wrapper_method1(func):

   def wrapper(*args, **kwargs):

       print("执行wrapper_method1")

       func(*args, **kwargs)

   return wrapper

 

 

class MyClass:

   def __init__(self):

       pass

 

   @wrapper_method1

   @staticmethod

   def myfuntion():

       print("执行myfunction")

 

MyClass.myfuntion()

 

运行结果:

Traceback (most recent call last):

执行wrapper_method1

 File "E:/PrivateReops/CassTestManage/TMP/backend/mytest.py", line 34, in <module>

   MyClass.myfuntion()

 File "E:/PrivateReops/CassTestManage/TMP/backend/mytest.py", line 9, in wrapper

   func(*args, **kwargs)

TypeError: 'staticmethod' object is not callable

目录
相关文章
|
23天前
|
程序员 测试技术 开发者
Python装饰器:简化代码的强大工具
Python装饰器:简化代码的强大工具
148 92
|
3月前
|
Python
掌握Python装饰器:轻松统计函数执行时间
掌握Python装饰器:轻松统计函数执行时间
247 76
|
4月前
|
人工智能 API Python
掌握 Python 文件处理、并行处理和装饰器
本文介绍了 Python 在文件处理、并行处理以及高级功能(如装饰器、Lambda 函数和推导式)的应用。第一部分讲解了文件的基本操作、读写方法及处理大型文件的技巧,并演示了使用 Pandas 处理结构化数据的方式。第二部分探讨了多线程与多进程的并行处理,以及 `concurrent.futures` 模块的简化用法,适合不同类型的任务需求。第三部分则深入装饰器的实现与应用,包括简单装饰器、带参数的装饰器及 `functools.wraps` 的使用,同时简要介绍了 Lambda 函数和推导式的语法与场景。内容实用且全面,帮助读者掌握 Python 高效编程的核心技能。
|
9月前
|
测试技术 数据安全/隐私保护 开发者
探索Python中的装饰器:从基础到高级应用
装饰器在Python中是一个强大且令人兴奋的功能,它允许开发者在不修改原有函数代码的前提下增加额外的功能。本文将通过具体代码示例,带领读者从装饰器的基础概念入手,逐步深入到高级用法,如带参数的装饰器和装饰器嵌套等。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的见解和技巧。
105 6
|
9月前
|
开发框架 数据建模 中间件
Python中的装饰器:简化代码,增强功能
在Python的世界里,装饰器是那些静悄悄的幕后英雄。它们不张扬,却能默默地为函数或类增添强大的功能。本文将带你了解装饰器的魅力所在,从基础概念到实际应用,我们一步步揭开装饰器的神秘面纱。准备好了吗?让我们开始这段简洁而富有启发性的旅程吧!
125 6
|
9月前
|
开发者 Python
探索Python中的装饰器:从基础到高级应用
本文将带你深入了解Python中的装饰器,这一强大而灵活的工具。我们将一起探讨装饰器的基本概念,它们如何工作,以及如何使用它们来增强函数和类的功能,同时不改变其核心逻辑。通过具体代码示例,我们将展示装饰器的创建和使用,并探索一些高级应用,比如装饰器堆栈和装饰带参数的装饰器。无论你是初学者还是有经验的开发者,这篇文章都将为你提供新的视角,帮助你更有效地使用装饰器来简化和优化你的代码。
|
8月前
|
测试技术 数据库 Python
Python装饰器实战:打造高效性能计时工具
在数据分析中,处理大规模数据时,分析代码性能至关重要。本文介绍如何使用Python装饰器实现性能计时工具,在不改变现有代码的基础上,方便快速地测试函数执行时间。该方法具有侵入性小、复用性强、灵活度高等优点,有助于快速发现性能瓶颈并优化代码。通过设置循环次数参数,可以更准确地评估函数的平均执行时间,提升开发效率。
228 61
Python装饰器实战:打造高效性能计时工具
|
8月前
|
设计模式 前端开发 Shell
Python装饰器是什么?
装饰器是Python中用于动态修改函数、方法或类功能的工具,无需改变原代码。通过将函数作为参数传递并返回新函数,装饰器可以在原函数执行前后添加额外逻辑。例如,使用`@logger`装饰器可以打印函数调用日志,而`@timethis`则可用于计算函数执行时间。为了保持被装饰函数的元信息(如`__name__`和`__doc__`),可使用`functools.wraps`装饰器。此外,带参数的装饰器可通过嵌套函数实现,如`@timeitS(2)`,以根据参数条件输出特定信息。
152 59
|
9月前
|
缓存 Python
深入理解Python中的装饰器
本文旨在通过具体实例和详细解释,帮助读者深入理解Python中装饰器的工作原理及其在实际开发中的应用。我们将从装饰器的基本概念开始,逐步深入到其高级用法,包括自定义装饰器、带参数的装饰器以及类装饰器等。通过本文的学习,读者将能够掌握装饰器的核心思想,提高代码的可读性和可维护性。

热门文章

最新文章

推荐镜像

更多