python函数修饰符@的使用

参考文档:
https://www.cnblogs.com/gdjlc/p/11182441.html

情况1
def log(func):
    def wrapper():
        print('log开始 ...')
        func()
        print('log结束 ...')

    return wrapper

def log_abc(func):
    def wrapper():
        print('log开始 abc...')
        func()
        print('log结束 abc...')

    return wrapper

@log_abc
@log
def test():
    print('test ..')

if __name__ == "__main__":
    test()

运行结果:

C:\Python37\python.exe E:/python/work/python3_test/flag_test.py
log开始 abc...
log开始 ...
test ..
log结束 ...
log结束 abc...

Process finished with exit code 0

情况2

其他资料参考
Python修饰器的函数式编程
http://www.open-open.com/lib/view/open1395285030019.html

Python进阶
http://www.wklken.me/category/pythonru-men-ji-jin-jie-bi-ji.html

Python装饰器学习(九步入门)

http://www.cnblogs.com/rhcad/archive/2011/12/21/2295507.html

Python深入05 装饰器
http://www.cnblogs.com/vamei/archive/2013/02/16/2820212.html

Python functools.wraps装饰器模块
嵌套修饰符

情况3
from functools import wraps

a = 0
def my_decorator(func):
    @wraps(func)
    def wrapper(*args, **kwargs):
        '''decorator'''
        print('Calling decorated function...')
        return func(*args, **kwargs)

    return wrapper

def my_log(func):
    @wraps(func)
    def wrapper(*args, **kwargs):
        '''decorator'''
        print('Calling my_log function...')
        return func(*args, **kwargs)

    return wrapper

@my_log
@my_decorator
def example():
    """Docstring"""
    global a
    print('Called example function')
    a = a +1
    print(a)
    return a


if __name__ == "__main__":
    print(example.__name__, example.__doc__)

    b = example()

    print('b=', b)

    b = example()

    print('b=', b)

运行结果

C:\Python37\python.exe E:/python/work/python3_test/flag_test.py
example Docstring
Calling my_log function...
Calling decorated function...
Called example function
1
b= 1
Calling my_log function...
Calling decorated function...
Called example function
2
b= 2

Process finished with exit code 0

修饰符(decorators)是Python中的一种特殊语法,用于修改函数或类的行为。它们是通过在函数或类定义之前使用@符号,后跟修饰符函数或类的方式来实现的。 修饰符函数接受被修饰的函数作为参数,并返回一个新的函数或修改原始函数。这样,当调用被修饰的函数时,实际上会执行修饰后的函数修饰符主要用于以下几个方面: 1. 扩展函数的功能:可以在不修改原始函数代码的情况下,通过添加修饰符来增加额外的功能。 2. 函数注册:可以使用修饰符函数注册到某个中心,以便在其他地方使用。 3. 访问控制:可以使用修饰符来限制对某些函数或类的访问权限。 下面是一个简单的示例,演示如何使用修饰符来记录函数的执行时间: ```python import time def timeit(func): def wrapper(*args, **kwargs): start_time = time.time() result = func(*args, **kwargs) end_time = time.time() execution_time = end_time - start_time print(f"函数 {func.__name__} 的执行时间为 {execution_time} 秒") return result return wrapper @timeit def my_function(): # 函数的具体实现 time.sleep(1) my_function() ``` 在上面的例子中,`timeit` 是一个修饰符函数,它接受被修饰的函数作为参数,并返回一个新的函数 `wrapper`。`wrapper` 函数记录了被修饰函数的执行时间,并在执行结束后打印出来。通过在 `my_function` 函数定义之前使用 `@timeit` 修饰符,`my_function` 函数就会被修饰并添加了计时功能。 希望这个例子能帮助你理解修饰符的概念和用法。如果还有其他问题,请随时提问!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值