Python 装饰器笔记

简介: 一、装饰器无参数 1.原函数无参数 def wrap_in_tag_b(fn): # wrap_in_tag_b 是真正的装饰器 def wrapped(): return "" + fn() + "" return wrapped def wra...

一、装饰器无参数

1.原函数无参数

def wrap_in_tag_b(fn): # wrap_in_tag_b 是真正的装饰器
    def wrapped():
        return "<b>" + fn() + "</b>"
    return wrapped

def wrap_in_tag_i(fn):
    def wrapped():
        return "<i>" + fn() + "</i>"
    return wrapped

@wrap_in_tag_b
@wrap_in_tag_i
def hello():
    return "hello"

print(hello()) # returns "<b><i>hello world</i></b>"

 

2.原函数带参数

def wrap_in_tag_b(fn):
    def wrapped(arg): # arg 是原函数参数
        return "<b>" + fn(arg) + "</b>"
    return wrapped

def wrap_in_tag_i(fn):
    def wrapped(arg): # arg 是原函数参数
        return "<i>" + fn(arg) + "</i>"
    return wrapped

@wrap_in_tag_b
@wrap_in_tag_i
def hello(name):
    return "hello {}".formar(name)

print(hello('Jack')) 

 

二、装饰器带参数

1.原函数无参数

def wrap_in_tag(deco_arg):
    # 装饰器参数:deco_arg
    # 可以在任意位置使用
    def real_decorator(func):  # real_decorator才是即将返回的真正的装饰器
    # 原函数参数:func_arg 
    # 只可以在此位置使用

    def wrapped() : return "<{0}>{1}</{0}>".format(deco_arg, func()) return wrapped return real_decorator @wrap_in_tag('b') @wrap_in_tag('i') def hello(): return "hello" print(hello())

 

2.原函数带参数

def wrap_in_tag(deco_arg):
    # 装饰器参数:deco_arg
    # 可以在任意位置使用
    def real_decorator(func):  # real_decorator才是即将返回的真正的装饰器
        def wrapped(func_arg):
            # 原函数参数:func_arg
            # 只可以在此位置使用
            return "<{0}>{1}</{0}>".format(deco_arg, func(func_arg))
        return wrapped
    return real_decorator
    
@wrap_in_tag('b')
@wrap_in_tag('i')
def hello(name):
    return "hello {}".format(name)
    
print(hello('Jack'))

 


三、装饰器类

1.原函数无参数

class wrap_in_tag(object):
    def __init__(self, deco_arg):
        self.tag = deco_arg  # 装饰器参数:deco_arg

    def __call__(self, func):
        def newf(): # 原函数无参数
            return "<{0}>{1}</{0}>".format(self.tag, func())
        return newf

@wrap_in_tag('b')
@wrap_in_tag('i')
def hello():
    return 'hello'
 
print(hello())


2.原函数带参数

class wrap_in_tag(object):
    def __init__(self, deco_arg):
        self.tag = deco_arg # 装饰器参数:deco_arg
        
    def __call__(self, func):
        def newf(func_arg): # 原函数参数: func_arg
            return "<{0}>{1}</{0}>".format(self.tag, func(func_arg))
        return newf

@wrap_in_tag('b')
@wrap_in_tag('i')
def hello(name):
    return "hello {}".format(name)
 
print(hello('Jack'))

 

四、用装饰器装饰类

1.用函数作为装饰器

def wrap_in_tag(deco_arg):
    def real_decorator(func):
        def wrapped(self, func_arg): # 类方法接收第一个参数都是self,这个必须有,而无论func_arg是否有!!!
            return "<{0}>{1}</{0}>".format(deco_arg, func(func_arg))
        return wrapped
    return real_decorator

class foo(object):
    
    @wrap_in_tag('b')
    @wrap_in_tag('i')
    def hello(self, name):
        return 'hello {}".format(name)
    
    @wrap_in_tag('b')
    @wrap_in_tag('i')
    def byebye(self, name):
        return 'byebye {}".format(name)
    
f = foo()
print(f.hello('Jack')


    2.用类作为装饰器

class wrap_in_tag(object):
    def __init__(self, deco_arg):
        self.tag = deco_arg
        
    def __call__(self, func):
        def newf(slf, func_arg): # slf必须!self被占用了,那就给第一个参数另一个名字slf(随便)
            return "<{0}>{1}</{0}>".format(self.tag, func(func_arg))
        return newf
        
        
        
class foo(object):
    
    @wrap_in_tag('b')
    @wrap_in_tag('i')
    def hello(self, name):
        return 'hello {}".format(name)
    
    @wrap_in_tag('b')
    @wrap_in_tag('i')
    def byebye(self, name):
        return 'byebye {}".format(name)

f = foo()
print(f.hello('Jack'))
 

 

目录
相关文章
|
8天前
|
监控 Python
Python中的装饰器:提升代码灵活性与可读性
在Python编程中,装饰器是一种强大的工具,能够提升代码的灵活性和可读性。本文将介绍装饰器的基本概念、使用方法以及实际应用场景,帮助读者更好地理解和利用这一功能。
|
11天前
|
缓存 监控 Python
解密Python中的装饰器:优雅而强大的编程利器
Python中的装饰器是一种强大而又优雅的编程工具,它能够在不改变原有代码结构的情况下,为函数或类添加新的功能和行为。本文将深入解析Python装饰器的原理、用法和实际应用,帮助读者更好地理解和利用这一技术,提升代码的可维护性和可扩展性。
|
29天前
|
缓存 算法 测试技术
Python中的装饰器:原理与实践
【2月更文挑战第29天】 在Python编程领域,装饰器是一种强大的工具,它允许我们在不修改原始函数代码的情况下,增加或修改函数的行为。本文将深入探讨Python装饰器的概念、实现原理以及实际应用,帮助读者掌握这一技术并在实际项目中灵活运用。
|
1天前
|
数据安全/隐私保护 Python
Python中的装饰器:提升代码可读性与灵活性
Python中的装饰器是一种强大的工具,可以在不改变函数原有逻辑的情况下,为函数添加额外的功能。本文将介绍装饰器的基本概念和用法,并通过实例演示如何利用装饰器提升代码的可读性和灵活性,使代码更加简洁、易于维护。
|
3天前
|
程序员 Python
Python中的装饰器:提升代码可读性与灵活性
在Python编程中,装饰器是一种强大的工具,可以在不修改原始代码的情况下,动态地添加功能。本文将深入探讨Python中装饰器的原理、用法和实际应用,以及如何利用装饰器提升代码的可读性和灵活性。
|
5天前
|
缓存 开发者 Python
深入探讨Python中的装饰器:提升代码可读性与灵活性
在Python编程中,装饰器是一种强大的工具,可以在不修改原始函数代码的情况下,对其行为进行扩展或修改。本文将深入探讨装饰器的原理和用法,以及如何利用装饰器提升代码的可读性和灵活性,为Python开发者提供更加优雅和高效的编程方式。
|
6天前
|
测试技术 开发者 Python
Python中的装饰器:优雅而强大的函数修饰工具
在Python编程中,装饰器是一种强大的工具,用于修改函数或方法的行为。本文将深入探讨Python中装饰器的概念、用法和实际应用,以及如何利用装饰器实现代码的优雅和高效。
|
16天前
|
缓存 数据安全/隐私保护 Python
Python中的装饰器:提升代码灵活性和可维护性
Python中的装饰器是一种强大的工具,能够在不修改原始函数代码的情况下,为函数添加额外的功能。本文将深入探讨装饰器的原理、用法以及实际应用场景,帮助读者更好地理解和利用Python中的装饰器提升代码的灵活性和可维护性。
|
22天前
|
缓存 程序员 Python
深入理解Python装饰器:从概念到应用
Python装饰器是函数,用于在不修改原代码的情况下为函数添加新功能。它们基于Python的函数一阶对象特性,通过`@decorator`语法应用。装饰器工作原理是接收函数作为参数,创建新函数对象并在调用时执行额外操作。常见应用场景包括日志记录、性能分析、权限校验和缓存。装饰器增强了代码的可读性和可维护性。
|
24天前
|
测试技术 Python
Python中的装饰器:提升代码可读性和灵活性
在Python编程中,装饰器(Decorator)是一种强大的工具,它可以在不修改原有代码的情况下,为函数或方法添加额外的功能。本文将深入探讨Python中装饰器的使用方法和实际应用,帮助读者更好地理解和运用这一重要的编程概念。

热门文章

最新文章