Python @装饰器

目录

目录

一 介绍

1 简单实现装饰器

普通调用

糖语法

2 进阶

普通调用

糖语法

3 装饰类

二 内置修饰器


一 介绍

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

        装饰器的本质:在不改变被装饰对象原有的“调用方式”和“内部代码”的情况下给被装饰对象添加新的功能。原则就是对扩展开放,对修改封闭

使用场景

  • AOP切面

  • 日志

  • 权限拦截

  • HTTP请求

  • 数据处理

1 简单实现装饰器

def my_decorator(func): 

    def wrapper(*args, **kwargs):
        print("before the function is called.")
        func(*args, **kwargs)
        print("after the function is called.")
        return 'wrapper msg'

    return wrapper # 目标函数需要接收参数
  • *args, **kwargs   获取所有参数进行赋值

  •  目标返回值是wrapper函数中return

普通调用

def say_whee():
    print("Whee!")


say_whee = my_decorator(say_whee) # 定义一个装饰方法
say_whee('李',c='18',b='20')      # 'wrapper msg'

糖语法

在python中使用@符号可以定义一个修饰后的函数

@my_decorator
def say_whee():
    print("Whee!")


say_whee('李',c='18',b='20')  # 'wrapper msg'

2 进阶

简单版的目标函数可以接收参数,但装饰器需要接收参数,解决办法是在最外层再加一个匿名函数

# logParam 装饰器实现,如果装饰多层,函数名与会变

def logParam(level):  # 最外层函数,可以接收参数给装饰器使用

    def outer(func):

        @functools.wraps(func)  # 该方法解决返回的方法是wrapper,而不是目标方法
        def wrapper(*args, **kwargs):
            funName = func.__name__  # 如果不加@functools.wraps(func),该函数名第二次会是wrapper
            match level:
                case 'info':
                    print(f'[INFO] 方法名:{funName},参数{args} - {kwargs}')

                case 'error':
                    print(f'[ERROR] 方法名:{funName},参数{args} - {kwargs}')

                case 'debug':
                    print(f'[DEBUG] 方法名:{funName},参数{args} - {kwargs}')

            func(*args, **kwargs)

        return wrapper # 目标函数需要接收参数

    return outer       # 需要装饰的目标

普通调用

# 普通调用
def my(name, age):
    print(f'名字:{name},年纪:{age}')


# 装饰1层

iwap = logParam('info')
themy = iwap(my)

# 装饰2层

ewap = logParam('error')
thewap = ewap(themy)

# 调用
thewap('李零山',18)

糖语法

@logParam('debug')
@logParam('error')
@logParam('info')
def my(name, age):
    print(f'名字:{name},年纪:{age}')



my('李零山',age = 18)
# 执行顺序 debug -> error -> info -> my

3 装饰类

python可以类中进行装饰,以下是单例模式示例:

import functools

def singleton(cls):

    @functools.wraps(cls)
    def wrapper_singleton(*args, **kwargs):

        if not wrapper_singleton.instance:
            wrapper_singleton.instance = cls(*args, **kwargs)

        return wrapper_singleton.instance

    wrapper_singleton.instance = None

    return wrapper_singleton


@singleton
class TheOne:
    pass



to = TheOne()

二 内置修饰器

1 类装饰器

  • @abstractmethod    定义一个抽象方法,子类实现了该抽象方法才能被实例化。

  • @classmethod          声明方法为类方法,同过类名.方法()可以直接调用

  • @staticmethoed       声明方法为静态方法,同过类名.方法()可以直接调用

  • @property                把类的方法伪装成属性

    • 只读不可修改的属性

    • 输入对setter进行判断

    • 需要实时地计算属性值

  • @price.setter            属性设定,可以用来限制属性的范围等等。

  • @price.deleter          定义属性的删除,在del house.price时被执行

2 其他修饰器,可以参考官网文档

回答: 在Python中,装饰器是一种用来修改其他函数功能的函数。它们通过在被修饰函数的定义前加上@符号来实现。常见的装饰器语法糖包括@classmethod、@staticmethod、@property、@xxx.setter和@wraps()等。装饰器可以让我们的代码更简短和更Pythonic。举个例子,我们可以使用装饰器来修改一个函数的行为,如在函数执行前后添加一些额外的功能。例如,下面的代码通过一个装饰器来修改say_whee函数的行为: @my_decorator def say_whee(): print("Whee!") say_whee('李', c='18', b='20') 这里,@my_decorator是一个装饰器,它修饰了say_whee函数。当我们调用say_whee函数时,实际上调用的是被装饰后的函数。装饰器可以在函数执行前后执行一些额外的代码,从而实现对函数功能的修改。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [python装饰器详解](https://blog.csdn.net/weixin_44992737/article/details/125868592)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Python @装饰器](https://blog.csdn.net/qq_43710438/article/details/125678643)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值