精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

從零到精通:Python 裝飾器的完整指南與實戰應用

開發
本文將從基礎原理出發,逐步深入裝飾器的各種應用場景,幫助你真正掌握這項強大的工具。

裝飾器是Python中最優雅卻最容易被誤解的特性之一。許多初學者對"裝飾"這個概念感到困惑,高級開發者則可能陷入過度使用裝飾器的陷阱。本文將從基礎原理出發,逐步深入裝飾器的各種應用場景,幫助你真正掌握這項強大的工具。

一、裝飾器的本質原理

1. 什么是裝飾器

裝飾器本質上是一個函數,它接收另一個函數作為參數,并返回一個新函數。這個新函數通常會在原函數執行前后進行某些操作。

# 最簡單的裝飾器
defmy_decorator(func):
    defwrapper():
        print("執行前")
        func()
        print("執行后")
    return wrapper

@my_decorator
defsay_hello():
    print("Hello!")

# 等同于:say_hello = my_decorator(say_hello)

say_hello()
# 輸出:
# 執行前
# Hello!
# 執行后

2. 保留原函數的元數據

使用裝飾器后,原函數的元數據(如函數名、文檔字符串)會丟失。使用functools.wraps可以解決這個問題。

from functools import wraps

defmy_decorator(func):
    @wraps(func)
    defwrapper(*args, **kwargs):
        """這是wrapper函數"""
        print("執行前")
        result = func(*args, **kwargs)
        print("執行后")
        return result
    return wrapper

@my_decorator
defadd(a, b):
    """將兩個數相加"""
    return a + b

print(add.__name__)  # 'add',而不是'wrapper'
print(add.__doc__)  # '將兩個數相加'

二、裝飾器的常見應用場景

1. 性能監測裝飾器

import time
from functools import wraps

deftimeit(func):
    @wraps(func)
    defwrapper(*args, **kwargs):
        start = time.time()
        result = func(*args, **kwargs)
        end = time.time()
        print(f"{func.__name__} 耗時:{end - start:.4f}秒")
        return result
    return wrapper

@timeit
defslow_function():
    time.sleep(1)
    return"完成"

result = slow_function()

2. 日志記錄裝飾器

import logging
from functools import wraps

deflog_calls(level=logging.INFO):
    defdecorator(func):
        @wraps(func)
        defwrapper(*args, **kwargs):
            logging.log(level, f"調用 {func.__name__} 參數:{args}, {kwargs}")
            result = func(*args, **kwargs)
            logging.log(level, f"{func.__name__} 返回值:{result}")
            return result
        return wrapper
    return decorator

@log_calls(level=logging.DEBUG)
defprocess_data(data):
    return data.upper()

process_data("hello")

3. 函數參數驗證裝飾器

from functools import wraps

defvalidate_types(**type_checks):
    defdecorator(func):
        @wraps(func)
        defwrapper(*args, **kwargs):
            for arg_name, expected_type in type_checks.items():
                if arg_name in kwargs:
                    ifnot isinstance(kwargs[arg_name], expected_type):
                        raise TypeError(f"{arg_name} 必須是 {expected_type}")
            return func(*args, **kwargs)
        return wrapper
    return decorator

@validate_types(name=str, age=int)
defcreate_user(name, age):
    returnf"創建用戶:{name}, 年齡:{age}"

create_user(name="Alice", age=25)  # 正常
# create_user(name="Alice", age="25")  # 會拋出TypeError

4. 緩存裝飾器(Memoization)

from functools import wraps, lru_cache

# 簡單的緩存實現
defcache(func):
    cached_data = {}
    
    @wraps(func)
    defwrapper(*args):
        if args notin cached_data:
            cached_data[args] = func(*args)
        return cached_data[args]
    
    wrapper.cache = cached_data
    return wrapper

@cache
deffibonacci(n):
    if n < 2:
        return n
    return fibonacci(n-1) + fibonacci(n-2)

# 使用內置的lru_cache
@lru_cache(maxsize=128)
deffibonacci_builtin(n):
    if n < 2:
        return n
    return fibonacci_builtin(n-1) + fibonacci_builtin(n-2)

print(fibonacci(30))  # 快速計算
print(fibonacci.cache)  # 查看緩存

5. 重試裝飾器

from functools import wraps
import time
import random

defretry(max_attempts=3, delay=1, backoff=2):
    defdecorator(func):
        @wraps(func)
        defwrapper(*args, **kwargs):
            current_delay = delay
            last_exception = None
            
            for attempt in range(max_attempts):
                try:
                    return func(*args, **kwargs)
                except Exception as e:
                    last_exception = e
                    if attempt < max_attempts - 1:
                        print(f"嘗試 {attempt + 1} 失敗,{current_delay}秒后重試...")
                        time.sleep(current_delay)
                        current_delay *= backoff
            
            raise last_exception
        
        return wrapper
    return decorator

@retry(max_attempts=3, delay=1, backoff=2)
defunstable_api_call():
    if random.random() < 0.7:
        raise Exception("API調用失敗")
    return"成功"

result = unstable_api_call()

6. 權限驗證裝飾器

from functools import wraps

defrequire_permission(*required_perms):
    defdecorator(func):
        @wraps(func)
        defwrapper(user, *args, **kwargs):
            ifnot hasattr(user, 'permissions'):
                raise PermissionError("用戶無權限屬性")
            
            user_perms = set(user.permissions)
            required = set(required_perms)
            
            ifnot required.issubset(user_perms):
                raise PermissionError(f"用戶缺少權限:{required - user_perms}")
            
            return func(user, *args, **kwargs)
        
        return wrapper
    return decorator

classUser:
    def__init__(self, name, permissions):
        self.name = name
        self.permissions = permissions

@require_permission('admin', 'delete')
defdelete_user(user, user_id):
    returnf"{user.name} 刪除了用戶 {user_id}"

admin_user = User("Admin", ['admin', 'delete', 'read', 'write'])
delete_user(admin_user, 123)  # 成功

7. 速率限制裝飾器

from functools import wraps
import time
from collections import defaultdict

defrate_limit(calls_per_second=1):
    min_interval = 1.0 / calls_per_second
    last_called = [0.0]
    
    defdecorator(func):
        @wraps(func)
        defwrapper(*args, **kwargs):
            elapsed = time.time() - last_called[0]
            if elapsed < min_interval:
                time.sleep(min_interval - elapsed)
            
            last_called[0] = time.time()
            return func(*args, **kwargs)
        
        return wrapper
    return decorator

@rate_limit(calls_per_second=2)
defapi_call():
    print(f"API調用時間:{time.time()}")
    return"成功"

for _ in range(5):
    api_call()

8. 方法裝飾器和類裝飾器

from functools import wraps

# 方法裝飾器
defmethod_logger(func):
    @wraps(func)
    defwrapper(self, *args, **kwargs):
        print(f"調用方法 {self.__class__.__name__}.{func.__name__}")
        return func(self, *args, **kwargs)
    return wrapper

# 類裝飾器
defadd_str_repr(cls):
    def__str__(self):
        attrs = ', '.join(f"{k}={v}"for k, v in self.__dict__.items())
        returnf"{cls.__name__}({attrs})"
    
    cls.__str__ = __str__
    return cls

@add_str_repr
classPerson:
    def__init__(self, name, age):
        self.name = name
        self.age = age
    
    @method_logger
    defgreet(self):
        returnf"你好,我是{self.name}"

person = Person("Alice", 25)
print(person)  # Person(name=Alice, age=25)
person.greet()  # 調用方法 Person.greet

三、高級裝飾器模式

9. 可選參數的裝飾器

from functools import wraps

defsmart_decorator(func=None, *, enabled=True):
    defdecorator(f):
        ifnot enabled:
            return f
        
        @wraps(f)
        defwrapper(*args, **kwargs):
            print("裝飾器生效")
            return f(*args, **kwargs)
        return wrapper
    
    if func isNone:
        # 被調用時帶參數:@smart_decorator(enabled=True)
        return decorator
    else:
        # 被調用時不帶參數:@smart_decorator
        return decorator(func)

@smart_decorator
deffunc1():
    return"func1"

@smart_decorator(enabled=False)
deffunc2():
    return"func2"

10. 鏈式裝飾器

defdecorator_a(func):
    @wraps(func)
    defwrapper(*args, **kwargs):
        print("A前")
        result = func(*args, **kwargs)
        print("A后")
        return result
    return wrapper

defdecorator_b(func):
    @wraps(func)
    defwrapper(*args, **kwargs):
        print("B前")
        result = func(*args, **kwargs)
        print("B后")
        return result
    return wrapper

@decorator_a
@decorator_b
defmy_func():
    print("執行函數")
    return"結果"

my_func()
# 輸出:
# A前
# B前
# 執行函數
# B后
# A后

四、結尾

裝飾器是Python中最強大的工具之一,也是代碼復用和關注點分離的最佳實踐。從簡單的日志記錄到復雜的權限驗證,裝飾器都能優雅地解決問題。然而,要記住裝飾器的目的是讓代碼更清晰、更易維護。過度使用裝飾器反而會增加代碼復雜性。

責任編輯:趙寧寧 來源: Python數智工坊
相關推薦

2025-10-09 01:33:00

2025-11-11 09:11:57

2024-06-07 08:51:50

OpenPyXLPythonExcel文件

2024-09-06 17:45:55

Linux磁盤

2023-11-08 08:32:16

2025-10-31 00:17:39

2025-06-27 06:30:08

2023-05-09 08:34:51

PythonWith語句

2024-04-11 14:00:28

2025-01-16 10:46:31

2025-07-17 13:52:57

通配符Linux命令行

2025-11-04 07:15:00

LangChain大模型AI

2025-03-26 08:01:18

2025-01-07 14:42:09

2025-08-27 04:15:00

LlamaIndexRAG數據源

2025-10-17 07:05:00

Python數據可視化數據科學

2025-09-29 01:50:00

2025-04-11 02:30:00

2025-08-05 07:26:06

點贊
收藏

51CTO技術棧公眾號

精品少妇av| jyzzz在线观看视频| 狠狠综合久久| 亚洲人成网站777色婷婷| 亚洲免费av一区二区三区| 麻豆免费在线观看| av一区二区三区四区| 国产精品吊钟奶在线| 黑鬼狂亚洲人videos| 精品在线网站观看| 欧美日韩高清影院| 我的公把我弄高潮了视频| av在线免费一区| 成人性生交大片免费| 国产精品成av人在线视午夜片 | 国产国语亲子伦亲子| 久久国产一二区| 欧美丰满少妇xxxxx做受| 欧美丰满美乳xxⅹ高潮www| 欧美区一区二区| 欧美性大战xxxxx久久久| 日韩精品一区在线视频| 在线激情小视频| 91丝袜美腿高跟国产极品老师| 国产欧美va欧美va香蕉在线| 黄色一级片免费在线观看| 自拍偷拍欧美专区| 在线播放亚洲激情| 人妻熟女aⅴ一区二区三区汇编| 国产精品18| 欧美日韩一区高清| 日日橹狠狠爱欧美超碰| 最爽无遮挡行房视频在线| 国产午夜精品一区二区三区视频| 国产日韩在线一区二区三区| 国产绿帽刺激高潮对白| 日韩福利电影在线| 欧美一性一乱一交一视频| 久久精品美女视频| 欧美国产三区| 久久亚洲欧美日韩精品专区| 在线视频这里只有精品| 国产videos久久| 精品小视频在线| 亚洲最大免费视频| 美女福利一区| 亚洲精品电影网在线观看| 日本成人在线免费| 精品国模一区二区三区欧美| 欧美精品免费视频| 污污视频网站在线| 二区三区精品| 欧美日本在线看| 亚洲男人天堂av在线| 男人天堂久久| 91精品国产全国免费观看| 国内国产精品天干天干| 在线播放成人| 欧美一区日韩一区| 亚洲 自拍 另类 欧美 丝袜| 一本一道久久a久久| 欧美电影精品一区二区| 日本一级大毛片a一| 粉嫩的18在线观看极品精品| 日韩电影在线观看中文字幕| 野花社区视频在线观看| 亚洲婷婷伊人| 色偷偷综合社区| 中文字幕在线观看2018| 欧美日本精品| 97婷婷涩涩精品一区| 在线免费黄色av| 欧美aa在线视频| 亚洲一区二区三区成人在线视频精品| 国产福利第一页| 99久久精品情趣| 日韩性感在线| 国产鲁鲁视频在线观看特色| 亚洲国产精品久久久久秋霞影院 | 亚洲国产精品成人av| 女性生殖扒开酷刑vk| 日本欧美三级| 在线播放日韩精品| 久草视频中文在线| 久久亚洲综合| 96pao国产成视频永久免费| 高潮一区二区三区乱码| 久久久国产综合精品女国产盗摄| 亚洲视频在线观看日本a| 亚洲制服国产| 欧美性xxxxx极品| 亚洲另类第一页| 粉嫩精品导航导航| 色久欧美在线视频观看| 国产中文字字幕乱码无限| 久久亚洲精品伦理| 91精品国产一区二区三区动漫| 人妻91麻豆一区二区三区| 久久青草国产手机看片福利盒子| 亚洲最新在线| 日本黄色免费在线| 欧美一区中文字幕| 国产免费看av| 国产主播一区| 国产区亚洲区欧美区| 天堂av在线免费| 中文字幕一区二区三区在线不卡 | 国产99一区视频免费| 欧美日韩在线一区二区三区| 黄色在线观看网站| 色猫猫国产区一区二在线视频| 欧美专区第二页| 精品国产一区二区三区香蕉沈先生| 久操成人在线视频| 制服丝袜在线一区| 久久综合网色—综合色88| 欧美美女黄色网| 色猫猫成人app| 日韩黄色高清视频| 久久久久亚洲AV| 看片的网站亚洲| 少妇精品久久久久久久久久| 91美女主播在线视频| 欧美高清一级片在线| xxxxx在线观看| 亚洲国产专区校园欧美| 亚洲一区二区免费| √天堂资源地址在线官网| 精品久久久久久久大神国产| 亚洲三级在线视频| 91一区二区三区四区| 国产成人av网| 精品电影在线| 欧美性69xxxx肥| 日本一卡二卡在线| 极品av少妇一区二区| 91久久偷偷做嫩草影院| a视频在线免费看| 欧美丰满嫩嫩电影| 少妇人妻丰满做爰xxx| 另类调教123区| 亚洲成色www久久网站| 成人在线网站| 在线观看欧美日韩| 久久久999久久久| 欧美国产一区视频在线观看| 国产性生交xxxxx免费| av伊人久久| 国产精品久久久久久久久男 | 91久久久久久久久久久久| 久久久国际精品| 豆国产97在线| 懂色av一区二区三区四区| 伊人婷婷欧美激情| 少妇性l交大片7724com| 国产精品a久久久久| av免费精品一区二区三区| 波多野结衣在线观看| 亚洲国产精久久久久久| 亚洲国产成人精品激情在线| 北条麻妃国产九九精品视频| 国产a级片网站| 精品自拍偷拍| 国产精品成人久久久久| 美女隐私在线观看| 日韩三级在线观看| 国产做受高潮漫动| 久久婷婷久久一区二区三区| 久久午夜夜伦鲁鲁一区二区| 99热在线成人| 国产无套精品一区二区| 美女福利一区二区三区| 日韩视频永久免费观看| www.日韩高清| 一本到三区不卡视频| 国产精品理论在线| 国产乱理伦片在线观看夜一区| 精品国产av无码一区二区三区| 亚洲自拍电影| 成人免费视频网| 大桥未久在线播放| 亚洲欧美日韩中文在线制服| 一二三区中文字幕| 亚洲夂夂婷婷色拍ww47 | 日韩精选在线| 国产精品亚洲视频在线观看| 日本片在线看| 亚洲石原莉奈一区二区在线观看| 91精东传媒理伦片在线观看| 亚洲高清在线精品| 亚洲高潮女人毛茸茸| 成人性生交大合| 国产又猛又黄的视频| 欧美精品啪啪| 日本免费一区二区三区| 国产成人精品日本亚洲专区61| 久cao在线| 亚洲免费人成在线视频观看| 国产免费高清av| 色综合久久综合中文综合网| 欧美特级一级片| 国产亚洲精品bt天堂精选| 日本黄色一级网站| 免费观看在线色综合| 欧美日韩福利在线| 91精品国产福利在线观看麻豆| 精品国产免费一区二区三区| 91成人在线网站| 国产成人精品久久| av男人的天堂在线观看| 久久精品中文字幕| 国产youjizz在线| 日韩成人av在线播放| 国产精品一级二级| 欧美专区在线观看一区| 久久久国产精品人人片| 亚洲欧洲三级电影| 久久精品—区二区三区舞蹈| 北条麻妃一区二区三区| 日韩欧美中文视频| 久久99精品久久久久婷婷| 欧美在线观看成人| 亚洲二区在线| 99视频精品全部免费看| 久久免费精品视频在这里| 欧美精品成人一区二区在线观看| 88久久精品| 91九色露脸| 国产精品日本一区二区三区在线| 国产精品久久久久久久久借妻| 黄在线观看免费网站ktv| 欧美激情欧美狂野欧美精品| 国产精品剧情| 精品国产视频在线| 免费看a在线观看| 久久精品国产亚洲精品2020| av在线播放av| 亚洲网站在线看| 青青草在线视频免费观看| 日韩av最新在线观看| 成人小说亚洲一区二区三区| 日韩天堂在线观看| 国产精品-色哟哟| 欧美美女黄视频| 国产一区二区三区三州| 欧美另类z0zxhd电影| 亚洲综合五月天婷婷丁香| 欧美天堂亚洲电影院在线播放| 无码aⅴ精品一区二区三区| 色综合久久中文字幕| 久久久精品福利| 色综合天天综合网国产成人综合天| 国产精品xxxx喷水欧美| 天天色综合成人网| 午夜婷婷在线观看| 日本韩国欧美一区| 亚洲天堂网在线视频| 欧美久久免费观看| 精品久久久久久亚洲综合网站| 欧美一区二区三区不卡| 丰满人妻一区二区三区免费| 亚洲第一色在线| 日韩欧美亚洲系列| 中文字幕亚洲综合久久筱田步美| 日本三级视频在线播放| 久久伊人免费视频| 2019中文字幕在线电影免费| 7m第一福利500精品视频| 欧美三级网址| 国产欧美在线视频| 这里视频有精品| 免费日韩av电影| 98精品视频| 日本福利视频一区| 丝袜亚洲另类欧美综合| 极品粉嫩美女露脸啪啪| 国产白丝精品91爽爽久久| 麻豆国产精品一区| 中文字幕av不卡| 精品处破女学生| 在线观看精品一区| av高清一区二区| 亚洲女人天堂视频| 黄视频网站在线| 欧美一级视频免费在线观看| 久久91视频| 波多野结衣久草一区| 自拍亚洲一区| 干日本少妇视频| 老鸭窝亚洲一区二区三区| 国产福利在线免费| av在线播放一区二区三区| 免费黄色国产视频| 欧美性猛xxx| 国内精品久久久久久久久久| 亚洲精品资源美女情侣酒店| 麻豆电影在线播放| 日本aⅴ大伊香蕉精品视频| www.久久久.com| 欧美一区二区在线视频观看| 欧美日韩综合| 中文字幕在线综合| 91亚洲精品久久久蜜桃网站| 久久国产高清视频| 欧美性黄网官网| 狠狠人妻久久久久久综合麻豆| 最新69国产成人精品视频免费| h片在线观看下载| 成人黄色片在线| 精品国产一区二区三区av片| 国产二区视频在线| 国产一区二区三区在线观看精品| 非洲一级黄色片| 欧美日韩国产一区在线| 超碰在线播放97| 日韩中文字幕在线播放| 欧美大胆性生话| 国产伦精品一区二区三区四区免费| 欧美肥老太太性生活| 日本三级免费观看| 波多野结衣中文字幕一区二区三区| 艳妇荡乳欲伦69影片| 欧美亚洲一区三区| 欧美日韩影视| 欧美在线观看一区二区三区| 在线精品视频一区| 浴室偷拍美女洗澡456在线| 麻豆精品精品国产自在97香蕉| 亚洲精品成人无码熟妇在线| 午夜亚洲国产au精品一区二区| 精品国产av 无码一区二区三区| 中文字幕视频一区二区在线有码| av在线最新| 国产日韩欧美精品电影三级在线| 日韩在线观看免费高清完整版| 国产精品嫩草69影院| 黄色在线小视频| 久久福利毛片| 一区二区三区天堂av| 四虎永久在线精品无码视频| 色婷婷av一区二区三区之红樱桃| 亚洲女同一区| 精品国产免费一区二区三区四区 | 不卡精品视频| 蜜桃视频在线观看91| 亚洲专区免费| 老司机福利av| 一本久道中文字幕精品亚洲嫩| 人操人视频在线观看| 欧美中在线观看| 国产一区二区在线| 国产高潮免费视频| 国产精品美女久久久久久久| 一本一道人人妻人人妻αv| 久久精品久久久久久国产 免费| 欧美日韩卡一| 黄色录像特级片| 成人午夜激情片| 久久精品国产成人av| 亚洲色图35p| 热久久久久久| 欧美 亚洲 视频| 成人av网站免费| 亚洲av中文无码乱人伦在线视色| 亚洲色图美腿丝袜| 欧美天堂一区二区| 三级在线免费观看| 成人深夜福利app| 一级片免费在线播放| 色老头一区二区三区| 亚洲精品高潮| 成人免费观看毛片| 国产精品美女久久久久久久久| av老司机久久| 欧美在线性爱视频| 水蜜桃精品av一区二区| 欧美一级片在线免费观看| 精品久久久久久久中文字幕| 北条麻妃在线| 国产精品国产精品| 日韩黄色免费电影| 久艹视频在线观看| 亚洲夜晚福利在线观看| 精品中文字幕一区二区三区四区| 欧美久久在线观看| 国产精品无码永久免费888| www.xxxx国产| 国产成人精品免费久久久久| 亚洲电影影音先锋| 午夜肉伦伦影院| av免费在线观| 色综合咪咪久久| 黄色片网站在线播放| 成人中文视频| 色一区av在线| 搜索黄色一级片| 欧美日韩四区| 国模私拍视频一区| 国产成人亚洲精品自产在线 | 欧美一区二区三区精美影视 |