python装饰器

装饰器本质是一个装饰器函数,在不改变一个函数的函数体本身的情况下,实现函数体本身外其他的功能
1.实现一个装饰器
def  logger(fn):                         #装饰器函数必须只能传入一个参数,那就是被装饰函数
    print(‘in’)
    def wrapper(*args,**kwargs):
        print(‘before’)
        ret = fn(*args,**kwargs)
        print(‘after’)
        return ret
    return wrapper
@logger
def foo3(x=3,y=4):       #相当于   foo3=logger(foo3)
    ”’i’m foo3”’
    print(x,y)
 代码在加载时就会打印  ‘in’
执行foo3函数相当于执行下面的函数    执行foo3(参数) ,args 和kwargs会获取实际输入的位置参数和关键字参数,然后传给原函数中调用(它不会获取原函数中的默认参数值,但这不会改变函数执行结果).
def wrapper(*args,**kwargs):
    print(‘before’)
    ret = foo3(*args,**kwargs)
    print(‘after’)
    return ret
2.文档字符串 和 带参数的装饰器
一个函数定义之后就会有对应的文档字符(.__doc__)等属性生成. 装饰器函数包装过后,获取不到原函数的各种属性就变成了wrapper对应的属性
下面使用了一个带有参数的装饰器把wrapper 函数装饰成一个新的wrapper函数,这里使用到了一个带有参数的装饰器
代码2.1:
def copy_properties(src):
    def _copy(dst):
        dst.__name__ = src.__name__
        dst.__doc__ = src.__doc__
        return dst
    return _copy
def logger(fn):
    @copy_properties(fn)          # wrapper = wrapper(fn)(wrapper)
    def wrapper(*args,**kwargs):
         ‘I am wrapper’
        print(‘begin’)
        x = fn(*args,**kwargs)
        print(‘end’)
        return x
     return wrapper
@logger            #add = logger(add)
 def add(x,y):
     ”’This is a function for add”’
         return x + y
 print(“name={}, doc={}”.format(add.__name__, add.__doc__))
代码2.2:
def copy_property(src):
    def _copy(dst):
        print(11)
        dst.__name__ = src.__name__
        dst.__doc__ = src.__doc__
        return dst
    return _copy
def add(x,y):
    ”’i am add”’
    print(x,y)
    return x+y
@copy_property(add)
def wrapper(*args,**kwargs):        #wrapper = cop_property(add) (wrapper)
    ”’i am wrapper”’
    print(22)
    ret = add(*args,**kwargs)
    return ret
print(add.__name__,add.__doc__)
print(wrapper.__name__,wrapper.__doc__)
运行代码2.2  会加载装饰器 运行右边的 wrapper = cop_property(add) (wrapper) 程序  ,add的属性会赋给 wrapper,打印如下.
11                                                                  如果执行wrapper(2,3)  会 先打印 22,然后执行add中的过程
add i am add
add i am add
3.对一个函数使用多个装饰器
def decorator1(func):
    print(11)
    def wrapper1(*args,**kwargs):
        print(‘hello python 之前’)
        ret=func(*args,**kwargs)
        return ret
    return wrapper1
def decorator2(func):
    print(22)
    def wrapper2(*args,**kwargs):
        print(‘hello python 之后’)
        ret=func(*args,**kwargs)
        return ret
    return wrapper2
@decorator1
@decorator2
def test(x,y):
    print(‘hello python!’,x,y)
test(4,5)
22                                         对一个函数执行多个装饰器,执行结果相当于对decorator2装饰test的函数 再使用decorator1装饰它
11
hello python 之前
hello python 之后
hello python! 4 5

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/88032

(0)
daishitongdaishitong
上一篇 2017-10-23 14:47
下一篇 2017-10-23 22:58

相关推荐

  • 搭建个人博客&论坛(LAMP):wordpress、discuz、phpMyAdmin

    搭建个人博客&论坛(LAMP):wordpress、discuz、phpMyAdmin 一、快速部署LAMP架构平台 1.CentOS 6系统部署 所需安装包:httpd, php, mysql-server, php-mysql ]# yum install -y  httpd php&n…

    Linux干货 2016-10-17
  • SElinux

    selinux  配置文件 修改   就要重启 targeted:用来保护常见的网路服务,仅有限进程受到selinux控制,只监控容易被入侵的进程。 targeted  慢慢完善的法律 系统默认使用   targeted     CENTOS6 CENTOS7 ZAI &nbsp…

    Linux干货 2016-09-14
  • NFS服务

    NFS服务:       NFS:Network File System 网络文件系统,基于内核的文件系统。 Sun公司开发,通过使用NFS,用户和程序可以像访 问本地文件一样访问远端系统上的文件,基于RPC(Remote Procedure Call Protocol远程过程调用)实现 。 RPC采用C/S模式。客户机请求程序…

    2017-08-14
  • LVM——如何让你的磁盘空间可大可小

    逻辑卷管理器(LVM) 允许对卷进行方便操作的抽象层,包括重新设定文件系统的大小 允许在多个物理设备间重新组织文件系统          将设备指定为物理卷          用一个或者多个物理卷来创…

    Linux干货 2016-08-29
  • 计算机的发展及组成

    计算机发展 计算机(Computer):俗称电脑,是一种能接收和存储信息,并按照存储在其内部的程序对海量数据进行自动、高速地处理,然后把处理结果输出的现代化智能电子设备。 1946年,世界上诞生了第一台计算机,用于军事,计算弹道。 1946年数学家冯.诺依曼提出冯诺依曼体系结构,即所有计算机由运算器、控制器、存储器、输入设备、输出设备组成,所有遵循冯.诺依曼…

    Linux干货 2017-07-13
  • 马哥教育网络班N22期+第1周课程练习beta2

    马哥教育网络班N22期+第1周课程练习  1.计算机的组成及其功能 1.1 计算机的组成 根据冯·诺依曼体系结构,将计算机分为五个主要的部件: CPU:运算器 CPU:控制器 RAM:存储器 Input:输入设备 Output: 输出设备 其功能分别为: 运算器(Datapath):运算器的功能是对数据进行各种算术运算和逻辑运算,即对数据进行加工处…

    Linux干货 2016-08-15