python 装饰器

本文深入探讨Python装饰器的概念,用于在不修改原有函数代码的情况下增强其功能。装饰器本质上是一个接收函数并返回新函数的函数。介绍了两种常见的装饰器定义方式,一种提供简单的日志功能,另一种允许自定义日志文本。通过实例展示了如何使用装饰器以及为何需要嵌套定义以支持带参数的函数。装饰器在代码动态扩展和维护中扮演重要角色。
摘要由CSDN通过智能技术生成

此文为个人总结的廖雪峰学习笔记,详细知识见廖雪峰。


装饰器用途:
要增强now()函数的功能,又不希望修改now()函数的定义,
这种在代码运行期间动态增加功能的方式,称之为“装饰器”(Decorator)

本质上,装饰器是一个接受函数作为参数的返回函数。

装饰器的常见定义方式(两种):

def decorator(func):
    def wrapper(*arg,**kw):
        print('call %s():' % func.__name__)
        return func(*arg,**kw)
    return wrapper

@log()
def f():
    print(2)

这种定义方式实现的功能较为简单,不需额外自定义log文本,可以在不改变原函数定义前提下,给原函数增加执行前输出日志的功能。
调用方式是,直接输入原函数f()即可。

def log(text):
    def decorator(func):
        def wrapper(*arg,**kw):
            print(text)
            return func()
        return wrapper
    return decorator


@log('abc')
def f():
    print(2)

这种定义方式可以自定义log中的text文本,这时装饰器需要再套一层,见上面代码。调用也是直接敲f()即可。

**上两种都可以看成原函数变成了wrapper(*arg,**kw)。


有人有疑问,下面也可实现自定义log中的text文本功能,为啥还需嵌套一层?

def log(text):
    def wrapper(fun):
        print('%s %s():' % (text, fun.__name__))
        return (fun)
    return wrapper


@log('excute')
def now():
    print('2020-02-04')


now()

虽然也可以输出:

excute now():
2020-02-04

但是,这样定义的now()不能带参数,因为参数传不进wrapper里,所以若要带参数,还得按上面两种常见定义。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值