python中的装饰器

1.装饰器定义

把一个函数当作参数,返回一个替代版的函数
本质上就是一个返回函数的函数
作用:在不改变原函数的基础上,给函数增加功能

2.装饰器的功能

案例一:
装饰器的使用
在这里插入图片描述

案例二:
使用装饰器给函数增添新的功,在已经写好的函数上添加新内容

在这里插入图片描述

案例三:
装饰器传入参数

在这里插入图片描述

案例四:
装饰器设置可变参数

在这里插入图片描述

案例五:
装饰器可以设置关键字参数

在这里插入图片描述

3. 装饰器的实际应用

案例一:

装饰器实现一个函数计时器

import time   时间模块(import time)
import functools   用于高阶函数:指那些作用于函数或者返回其它函数的函数,通常只要是可以被当做函数调用的对象就是这个模块的目标
def timetest(fun):
    """这是一个装饰器"""
    @functools.wraps(fun)
    def wrapper(*args,**kwargs):
        start_time = time.time()
        res = fun(*args,**kwargs)
        end_time = time.time()
        print('运行时间:是%.6f' % (end_time - start_time))
        return res  返回值
    return wrapper
@timetest
def fun_list(n):
    """这是一个fun_list函数"""
    return [2 *i for i in range(n)]  列表生成式
@timetest
def fun_map(n):
    """这是一个fun_map函数"""
    return list(map(lambda x:x*2,range(n)))   匿名函数
print(fun_list(1000))
print(fun_map(1000)

在这里插入图片描述
案例二:

创建装饰器, 要求如下:

1.创建add_log装饰器, 被装饰的函数打印日志信息;
2.日志格式为: [字符串时间] 函数名: xxx, 运行时间:xxx, 运行返回 值结果:xxx

import time 
import functools
def add_log(fun):
    @functools.wraps(fun)
    def wrapper(*args,**kwargs):
        start_time = time.time()
        res = fun(*args,**kwargs)
        end_time = time.time()
        print('[%s]函数名:%s运行时间:%.6f,运行返回值结果:%d'
              % (time.ctime(), fun.__name__, end_time - start_time, res))
        return res
    return wrapper
@add_log
def add(x,y):
    time.sleep(1)    #time.sleep()函数推迟调用线程的运行,可通过参数secs指秒数,表示进程挂起的时间语法格式:time.sleep(t)
    return x + y
add(1,5)

在这里插入图片描述

案例三:

编写装饰器required_types, 条件如下:

  1. 当装饰器为@required_types(int,float)确保函数接收到的每一>个参数都是int或者float类型;
  2. 当装饰器为@required_types(list)确保函数接收到的每一个参数 都是list类型;
  3. 当装饰器为@required_types(str,int)确保函数接收到的每一个>参数都是str或者int类型;
  4. 如果参数不满足条件, 打印 TypeError:参数必须为xxxx类型
 sinstance() 函数来判断一个对象是否是一个已知的类型,类似 type()。
 isinstance()type() 区别:
 type() 不会认为子类是一种父类类型,不考虑继承关系。
 isinstance() 会认为子类是一种父类类型,考虑继承关系。
 如果要判断两个类型是否相同推荐使用 isinstance()。
 isinstance(object, classinfo)

在这里插入图片描述

import  functools
def required_types(*kind):  #最外面定义一个装饰器 *kind表示接受多个元素
    def required(fun):      #里面的装饰器
        @functools.wraps(fun)
        def wrapper(*args,**kwargs):
            for i in args:
                if not isinstance(i,kind):     #sinstance() 函数来判断一个对象是否是一个已知的类型,类似 type()
                    print('TypeError:参数必须为%s,%s类型' %kind)
                    exit()
            else:
                res = fun(*args,**kwargs)
                return res
        return wrapper
    return required
@required_types(float,float)  #调用最外层函数float浮点型,表示有小数点的数值整型
def add(x,y):
    return x+y
print(add(1.2,2.3))
print(add(1,3.5))

在这里插入图片描述

4. 多个装饰器执行顺序

先调用那个装饰器,那个就先运行

def decorator_a(fun):   #第一个装饰器
    def inner_a(*args,**kwargs):
        print('get in inner_a')
        return fun(*args,**kwargs)
    return inner_a
def decortor_b(fun):    #第二个装饰器
    def inner_b(*args,**kwargs):
        print('get in inner_b')
        return fun(*args,**kwargs)
    return inner_b
@decorator_a    #先调用那个装饰器,那个就先运行
@decortor_b
def f(x):
    print('get in f')
    return x*3
f(1)
@decortor_b
@decorator_a
def f(x):
    print('get in f')
    return x*3
f(1)

在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
装饰器Python一种用于修改函数或类的行为的语法结构。它们允许在不修改原始代码的情况下,通过添加额外的功能来装饰函数或类。 装饰器实际上是一个函数,它接受一个函数作为输入,并返回一个新的函数作为输出。这个新的函数通常会在调用原始函数之前或之后执行一些额外的代码。 下面是一个简单的装饰器示例: ```python def decorator_function(original_function): def wrapper_function(): # 在调用原始函数之前执行额外的操作 print("Before the original function is called") # 调用原始函数 original_function() # 在调用原始函数之后执行额外的操作 print("After the original function is called") return wrapper_function @decorator_function def say_hello(): print("Hello!") # 调用经过装饰器修饰过的函数 say_hello() ``` 在上述示例,我们定义了一个名为`decorator_function`的装饰器函数。该装饰器接受一个名为`original_function`的函数作为参数,并返回一个新的函数`wrapper_function`。`wrapper_function`在调用原始函数之前和之后,分别打印了一些额外的信息。 通过在`say_hello`函数定义之前加上`@decorator_function`,我们将`say_hello`函数传递给了装饰器,并将装饰器返回的函数赋值给了`say_hello`。这样,当我们调用`say_hello`函数时,实际上是在调用经过装饰器修饰过的函数`wrapper_function`。 装饰器提供了一种灵活且可重复使用的方式来扩展函数的功能,比如添加日志记录、性能计时、输入验证等。在Python,还有一种更简洁的语法糖形式来使用装饰器,即使用`@`符号将装饰器应用到函数上,如上述示例的`@decorator_function`。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值