【简明】彻底搞清楚Python的装饰器 | Python 主题月

简介: 【简明】彻底搞清楚Python的装饰器 | Python 主题月

什么是装饰器


“闭包”是什么?,我们可以认为装饰器就是一个闭包函数,同时它也返回了一个函数。


你也可以认为装饰器就是将函数作为参数传递到方法中,进行加工,再返回出来。


装饰器的使用场景


1、附加功能(统一日志格式,定时器)

2、数据的清理和添加(注入类似动态token的数据,修改清理内部数据)

3、函数注册等


装饰器的demo


1、实现函数在执行前后所花费的时间

装饰器的使用格式:@decorator


# 定义装饰器
import time
def execTime(func):
    def inner(*args,**kwargs):    # 接收参数
        time1 = time.time()
        res = func(*args,**kwargs)
        time2 = time.time()
        print(func.__name__,'执行花费',time2-time1,'s')
        return res    # 返回func的返回值
    return inner  # 返回inner方法对象
# 在execAdd方法上使用execTime装饰器
@execTime
def execAdd(a,b):
    time.sleep(1)
    return a+b
# 调用execAdd
res = execAdd(1,2)
print(res)
复制代码


运行结果:


python3 test.py
execAdd 执行花费 1.0000572204589844 s
3
复制代码


2、实现日志的统一打印


import time,logging
def execTime(func):
    def inner(*args,**kwargs):
        time1 = time.time()
        # 添加方法开始的日志
        logging.warning('now func {} start...'.format(func.__name__))
        res = func(*args,**kwargs)
        # 添加方法结束的日志
        logging.warning('now func {} finished...'.format(func.__name__))
        time2 = time.time()
        print(func.__name__,'执行花费',time2-time1,'s','\n')
        return res
    return inner
@execTime
def execAdd(a,b):
    time.sleep(1)
    return a+b
@execTime
def sayHi(name):
    print('hello,{}.'.format(name))
sayHi('phyger')
res = execAdd(1,2)
print(res)
复制代码


输出


python3 test.py
WARNING:root:now func sayHi start...
hello,phyger.
WARNING:root:now func sayHi finished...
sayHi 执行花费 0.00700068473815918 s
WARNING:root:now func execAdd start...
WARNING:root:now func execAdd finished...
execAdd 执行花费 1.0020573139190674 s
3
复制代码


你会看到上面的两个方法在执行前后都会被增加开始和结束的告警日志,而且会统计方法的执行时间,通过这种方式我们可以方便快捷的对方法进行封装。


注意


当我们执行以下代码时:


@execTime
def sayHi(name):
    print('hello,{}.'.format(name))
复制代码


输出


python3 test.py
WARNING:root:now func sayHi start...
hello,phyger.
WARNING:root:now func sayHi finished...
sayHi 执行花费 0.018001317977905273 s
inner
复制代码


sayHi方法的name竟然是装饰器的内函数的方法,这不是我们的期望结果啊。我们方法的name和注释被装饰器内函数重写了,我们怎么解决这个问题呢?


Python帮我提供了一个函数来解决这个问题,他就是functools.wraps。


我们重写装饰器来看看效果:


from functools import wraps
import time,logging
def execTime(func):
    @wraps(func)
    def inner(*args,**kwargs):
        time1 = time.time()
        logging.warning('now func {} start...'.format(func.__name__))
        res = func(*args,**kwargs)
        logging.warning('now func {} finished...'.format(func.__name__))
        time2 = time.time()
        print(func.__name__,'执行花费',time2-time1,'s','\n')
        return res
    return inner
# 调用
sayHi('phyger')
print(sayHi.__name__)
复制代码


输出


test.py
WARNING:root:now func sayHi start...
hello,phyger.
WARNING:root:now func sayHi finished...
sayHi 执行花费 0.003000020980834961 s
sayHi
复制代码


你能看到,使用了装饰器的sayHi方法的__name__值已经是它自身的值了。


如果你想在当前装饰器的基础上再增加功能,那么你可能需要使用类装饰器,因为类的继承特性可以很好的解决你这个需求。关于类装饰器我们后面再介绍。

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
9天前
|
监控 Python
Python中的装饰器:提升代码灵活性与可读性
在Python编程中,装饰器是一种强大的工具,能够提升代码的灵活性和可读性。本文将介绍装饰器的基本概念、使用方法以及实际应用场景,帮助读者更好地理解和利用这一功能。
|
12天前
|
缓存 监控 Python
解密Python中的装饰器:优雅而强大的编程利器
Python中的装饰器是一种强大而又优雅的编程工具,它能够在不改变原有代码结构的情况下,为函数或类添加新的功能和行为。本文将深入解析Python装饰器的原理、用法和实际应用,帮助读者更好地理解和利用这一技术,提升代码的可维护性和可扩展性。
|
30天前
|
缓存 算法 测试技术
Python中的装饰器:原理与实践
【2月更文挑战第29天】 在Python编程领域,装饰器是一种强大的工具,它允许我们在不修改原始函数代码的情况下,增加或修改函数的行为。本文将深入探讨Python装饰器的概念、实现原理以及实际应用,帮助读者掌握这一技术并在实际项目中灵活运用。
|
30天前
|
数据采集 自然语言处理 算法
如何使用Python的Gensim库进行自然语言处理和主题建模?
使用Gensim库进行自然语言处理和主题建模,首先通过`pip install gensim`安装库,然后导入`corpora`, `models`等模块。对数据进行预处理,包括分词和去除停用词。接着,创建字典和语料库,使用`Dictionary`和`doc2bow`。之后,应用LDA算法训练模型,设置主题数量并创建`LdaModel`。最后,打印每个主题的主要关键词。可以根据需求调整参数和选择不同算法。
23 0
|
2天前
|
数据安全/隐私保护 Python
Python中的装饰器:提升代码可读性与灵活性
Python中的装饰器是一种强大的工具,可以在不改变函数原有逻辑的情况下,为函数添加额外的功能。本文将介绍装饰器的基本概念和用法,并通过实例演示如何利用装饰器提升代码的可读性和灵活性,使代码更加简洁、易于维护。
|
2天前
|
缓存 大数据 数据处理
Python迭代器、生成器和装饰器探究
【4月更文挑战第2天】 迭代器是遍历集合元素的对象,实现`__iter__()`和`__next__()`方法。示例中自定义迭代器`MyIterator`用于生成整数序列。 - 生成器简化了迭代器实现,利用`yield`关键词实现状态保存,减少内存占用。示例中的`my_generator`函数即为一个生成器。 - 装饰器用于修改函数行为,如日志记录、性能分析。装饰器`my_decorator`在函数调用前后添加额外代码。
4 0
|
4天前
|
程序员 Python
Python中的装饰器:提升代码可读性与灵活性
在Python编程中,装饰器是一种强大的工具,可以在不修改原始代码的情况下,动态地添加功能。本文将深入探讨Python中装饰器的原理、用法和实际应用,以及如何利用装饰器提升代码的可读性和灵活性。
|
6天前
|
缓存 开发者 Python
深入探讨Python中的装饰器:提升代码可读性与灵活性
在Python编程中,装饰器是一种强大的工具,可以在不修改原始函数代码的情况下,对其行为进行扩展或修改。本文将深入探讨装饰器的原理和用法,以及如何利用装饰器提升代码的可读性和灵活性,为Python开发者提供更加优雅和高效的编程方式。
|
7天前
|
测试技术 开发者 Python
Python中的装饰器:优雅而强大的函数修饰工具
在Python编程中,装饰器是一种强大的工具,用于修改函数或方法的行为。本文将深入探讨Python中装饰器的概念、用法和实际应用,以及如何利用装饰器实现代码的优雅和高效。
|
17天前
|
缓存 数据安全/隐私保护 Python
Python中的装饰器:提升代码灵活性和可维护性
Python中的装饰器是一种强大的工具,能够在不修改原始函数代码的情况下,为函数添加额外的功能。本文将深入探讨装饰器的原理、用法以及实际应用场景,帮助读者更好地理解和利用Python中的装饰器提升代码的灵活性和可维护性。