0

0

Python 带参数装饰器的实现方式

冷炫風刃

冷炫風刃

发布时间:2026-01-27 19:32:31

|

933人浏览过

|

来源于php中文网

原创

带参数装饰器必须是三层函数,因为@decorator(arg)先调用decorator(arg)返回真正的装饰器;第一层收装饰器参数,第二层收被装饰函数,第三层收原函数参数并执行逻辑;需用@functools.wraps(func)保留元信息。

python 带参数装饰器的实现方式

带参数装饰器为什么必须是三层函数

因为 Python 解释器在遇到 @decorator(arg) 时,会先执行 decorator(arg),期望它返回一个真正的装饰器(即接收函数并返回包装后函数的可调用对象)。所以最外层函数负责接收装饰器参数,中间层接收被装饰函数,最内层负责实际逻辑。

常见错误是只写两层,导致 TypeError: 'function' object is not callable 或装饰器完全不生效。

  • 第一层:接收装饰器参数(如 log_level),返回第二层函数
  • 第二层:接收被装饰的函数 func,返回第三层函数
  • 第三层:接收原函数的参数(*args, **kwargs),执行前后逻辑,调用 func

如何正确保留原函数的元信息

不加处理时,被装饰后的函数 __name____doc__ 都会变成内层包装函数的,这对调试、文档生成(如 Sphinx)、反射(inspect.signature)都会造成干扰。

必须使用 @functools.wraps(func) 修饰第三层函数:

立即学习Python免费学习笔记(深入)”;

from functools import wraps

def with_retry(max_attempts=3): def decorator(func): @wraps(func) # ← 关键:把 func 的元信息复制给 wrapper def wrapper(*args, *kwargs): for i in range(max_attempts): try: return func(args, **kwargs) except Exception: if i == max_attempts - 1: raise return None return wrapper return decorator

带参数装饰器的常见误用场景

最容易出错的是混淆「装饰器参数」和「被装饰函数参数」,尤其在动态构造装饰器时。

极限网络办公Office Automation
极限网络办公Office Automation

专为中小型企业定制的网络办公软件,富有竞争力的十大特性: 1、独创 web服务器、数据库和应用程序全部自动傻瓜安装,建立企业信息中枢 只需3分钟。 2、客户机无需安装专用软件,使用浏览器即可实现全球办公。 3、集成Internet邮件管理组件,提供web方式的远程邮件服务。 4、集成语音会议组件,节省长途话费开支。 5、集成手机短信组件,重要信息可直接发送到员工手机。 6、集成网络硬

下载
  • @my_dec(a=1)(b=2) 当作多级参数——实际不合法,Python 只支持一层括号调用
  • 在第二层(接收 func 的函数)里直接访问装饰器参数,却忘了它属于闭包外层,需确保作用域链完整
  • 用类实现带参装饰器时,忘记在 __call__ 中区分:第一次调用传的是 func 还是参数?典型做法是检查第一个参数是否为函数类型
  • 参数类型校验缺失,比如传入 None 或负数给 max_retries,应在第一层就抛出 ValueError

装饰器参数支持延迟求值吗

可以,但必须把求值逻辑移到第三层(wrapper 内),否则参数会在装饰定义时(模块加载期)就被计算,而非每次调用时。

例如日志中想记录当前时间戳,如果写成:

def log_time(label=time.time()):  # ❌ 错误:模块导入时就固定了
    ...

应改为:

def log_time(label="run"):
    def decorator(func):
        @wraps(func)
        def wrapper(*args, **kwargs):
            start = time.time()  # ✅ 正确:每次调用才计算
            result = func(*args, **kwargs)
            print(f"[{label}] took {time.time() - start:.2f}s")
            return result
        return wrapper
    return decorator

闭包变量的生命周期和求值时机,是带参装饰器里最易被忽略的复杂点。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
go语言闭包相关教程大全
go语言闭包相关教程大全

本专题整合了go语言闭包相关数据,阅读专题下面的文章了解更多相关内容。

137

2025.07.29

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

482

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

163

2023.10.07

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

109

2026.01.26

edge浏览器怎样设置主页 edge浏览器自定义设置教程
edge浏览器怎样设置主页 edge浏览器自定义设置教程

在Edge浏览器中设置主页,请依次点击右上角“...”图标 > 设置 > 开始、主页和新建标签页。在“Microsoft Edge 启动时”选择“打开以下页面”,点击“添加新页面”并输入网址。若要使用主页按钮,需在“外观”设置中开启“显示主页按钮”并设定网址。

16

2026.01.26

苹果官方查询网站 苹果手机正品激活查询入口
苹果官方查询网站 苹果手机正品激活查询入口

苹果官方查询网站主要通过 checkcoverage.apple.com/cn/zh/ 进行,可用于查询序列号(SN)对应的保修状态、激活日期及技术支持服务。此外,查找丢失设备请使用 iCloud.com/find,购买信息与物流可访问 Apple (中国大陆) 订单状态页面。

138

2026.01.26

npd人格什么意思 npd人格有什么特征
npd人格什么意思 npd人格有什么特征

NPD(Narcissistic Personality Disorder)即自恋型人格障碍,是一种心理健康问题,特点是极度夸大自我重要性、需要过度赞美与关注,同时极度缺乏共情能力,背后常掩藏着低自尊和不安全感,影响人际关系、工作和生活,通常在青少年时期开始显现,需由专业人士诊断。

7

2026.01.26

windows安全中心怎么关闭 windows安全中心怎么执行操作
windows安全中心怎么关闭 windows安全中心怎么执行操作

关闭Windows安全中心(Windows Defender)可通过系统设置暂时关闭,或使用组策略/注册表永久关闭。最简单的方法是:进入设置 > 隐私和安全性 > Windows安全中心 > 病毒和威胁防护 > 管理设置,将实时保护等选项关闭。

6

2026.01.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.3万人学习

Django 教程
Django 教程

共28课时 | 3.6万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号