Python 两种装饰器

本文介绍了Python中的装饰器,包括带参数的装饰器和类装饰器的实现方式。通过实例展示了如何使用装饰器进行日志记录,并探讨了类装饰器的灵活性和优势。装饰器在保持代码简洁的同时,提供了增强函数功能的能力。
摘要由CSDN通过智能技术生成

目录

带参数的装饰器(函数)

类装饰器


装饰器(Decorators)是 Python 的一个重要部分。简单地说:他们是修改其他函数的功能的函数。他们有助于让我们的代码更简短,也更Pythonic(Python范儿)。

带参数的装饰器(函数)

===========

来想想这个问题,难道@wraps不也是个装饰器吗?但是,它接收一个参数,就像任何普通的函数能做的那样。那么,为什么我们不也那样做呢? 这是因为,当你使用@my_decorator语法时,你是在应用一个以单个函数作为参数的一个包裹函数。记住,Python里每个东西都是一个对象,而且这包括函数!记住了这些,我们可以编写一下能返回一个包裹函数的函数。

在函数中嵌入装饰器

我们回到日志的例子,并创建一个包裹函数,能让我们指定一个用于输出的日志文件。

注意:@wraps接受一个函数来进行装饰,并加入了复制函数名称、注释文档、参数列表等等的功能。这可以让我们在装饰器里面访问在装饰之前的函数的属性。

from functools import wraps

def logit(logfile=‘out.log’):

def logging_decorator(func):

@wraps(func)

def wrapped_function(*args, **kwargs):

log_string = func.name + " was called"

print(log_string)

打开logfile,并写入内容

with open(logfile, ‘a’) as opened_file:

现在将日志打到指定的logfile

opened_file.write(log_string + ‘\n’)

return func(*args, **kwargs)

return wrapped_function

return logging_decorator

@logit()

def myfunc1():

pass

myfunc1()

Output: myfunc1 was called

现在一个叫做 out.log 的文件出现了,里面的内容就是上面的字符串

@logit(logfile=‘func2.log’)

def myfunc2():

pass

myfunc2()

Output: myfunc2 was called

现在一个叫做 func2.log 的文件出现了,里面的内容就是上面的字符串

类装饰器

========

没错,装饰器不仅可以是函数,还可以是类,相比函数装饰器,类装饰器具有灵活度大、高内聚、封装性等优点。使用类装饰器主要依靠类的__call__方法,当使用 @ 形式将装饰器附加到函数上时,就会调用此方法。

class Foo(object):

def init(self, func):

self._func = func

def call(self):

print (‘class decorator runing’)

self._func()

print (‘class decorator ending’)

@Foo
def bar():
print (‘bar’)
bar()
functools.wraps

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值