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
下一篇 2017-10-23

相关推荐

  • 马哥网络班21期,第三周作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。     who | cut -d " " -f1 | sort -u     who:查看当前系统所有用户的会话     cut:剪切命令       cut…

    Linux干货 2016-07-26
  • 马哥教育网络班21期-第6周课程练习

    第6周课程练习 请详细总结vim编辑器的使用并完成以下练习题   1、         复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#; # cp /etc/rc.d/rc.s…

    Linux干货 2016-08-30
  • 系统基础之shell脚本编程详解3(函数)

    shell脚本编程详解3:    在前两节我们分别介绍了shell脚本编程的基础和循环,判断的知识,今天我们分享脚本的另一种用法,函数. 概论:     函数function是由若干条shell命令组成的语句块,实现代码重用和模块化编程。    它与shell…

    Linux干货 2016-08-22
  • lvs的基本概念及基础配置

    一、知识整理 1、Session:在计算机中,尤其是在网络应用中,称为“会话控制、时域”。Session 对象存储特定用户会话所需的属性及配置信息。这样,当用户在应用程序的 Web 页之间跳转时,存储在 Session 对象中的变量将不会丢失,而是在整个用户会话中一直存在下去。当用户请求来自应用程序的 Web 页时,如果该用户还没有会话,则 Web 服务器将…

    Linux干货 2016-11-11
  • 马哥教育网络班19期+第七周课程练习

    1、创建一个10G分区,并格式为ext4文件系统;   (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;         mke2fs -b 2048 -m 2 -L 'MYDATA' -o defau…

    Linux干货 2016-06-21
  • Linux下装载软Raid

    步骤1.创建磁盘,并转换为fd #fdisk /dev/sdb //这里使用新的磁盘sdb 然后输入n ,创建分区 使用默认的起始点 输入大小为+100M 然后重复刚才的操作4次,创建4个分区,创建完4个分区后 我们还要改变分区的ID 在分区的主菜单输入T 然后输入要改变ID的分区号,也就是最后4个分区 然后输入分区的ID:fd 四个分区都改成FD 完成后,…

    Linux干货 2017-08-12