python中wraps函数如何使用?

冷炫風刃
发布: 2025-11-27 18:48:46
原创
805人浏览过
使用functools.wraps可保留被装饰函数的元信息,避免函数名、文档字符串等丢失。1. 不使用wraps时,装饰器会掩盖原函数的__name__和__doc__;2. 使用@wraps(func)后,wrapper继承原函数的元数据,确保调试和文档正确;3. 适用于日志、计时、权限等通用装饰器,提升代码可维护性。

python中wraps函数如何使用?

functools.wraps 是 Python 中用于装饰器开发的一个实用工具,它的主要作用是保留被装饰函数的元信息(如函数名、文档字符串、参数列表等)。如果不使用 wraps,装饰器会“掩盖”原函数的这些信息,给调试和文档生成带来困扰。

为什么需要 wraps?

考虑一个简单的装饰器:

<pre class="brush:php;toolbar:false;">def my_decorator(func):
    def wrapper(*args, **kwargs):
        print("调用前")
        result = func(*args, **kwargs)
        print("调用后")
        return result
    return wrapper
<p>@my_decorator
def say_hello():
"""打招呼函数"""
print("Hello!")</p><p>print(say_hello.<strong>name</strong>)  # 输出:wrapper
print(say_hello.<strong>doc</strong>)   # 输出:None</p>
登录后复制

可以看到,函数名变成了 wrapper,文档字符串丢失了。这在实际开发中不利于调试和框架识别。

使用 wraps 保留原函数信息

通过 functools.wraps 可以解决这个问题:

<pre class="brush:php;toolbar:false;">from functools import wraps
<p>def my_decorator(func):
@wraps(func)
def wrapper(*args, *<em>kwargs):
print("调用前")
result = func(</em>args, **kwargs)
print("调用后")
return result
return wrapper</p><p>@my_decorator
def say_hello():
"""打招呼函数"""
print("Hello!")</p><p>print(say_hello.<strong>name</strong>)  # 输出:say_hello
print(say_hello.<strong>doc</strong>)   # 输出:打招呼函数</p>
登录后复制

加上 @wraps(func) 后,wrapper 函数会复制 func 的名称、文档字符串、模块名等元数据,使装饰后的函数看起来更“像”原函数。

实际应用场景

wraps 在编写通用装饰器时非常有用,比如:
  • 日志记录装饰器
  • 性能计时装饰器
  • 权限校验装饰器
  • 缓存装饰器
例如一个计时装饰器:

<pre class="brush:php;toolbar:false;">from functools import wraps
import time
<p>def timer(func):
@wraps(func)
def wrapper(*args, *<em>kwargs):
start = time.time()
result = func(</em>args, **kwargs)
end = time.time()
print(f"{func.<strong>name</strong>} 执行耗时: {end - start:.2f}s")
return result
return wrapper</p><p>@timer
def slow_function():
time.sleep(1)</p><p>slow_function()  # 输出函数名和耗时</p>
                    <div class="aritcle_card">
                        <a class="aritcle_card_img" href="/xiazai/learn/2593">
                            <img src="https://img.php.cn/upload/webcode/000/000/000/5a2b9a88e20e5831.png" alt="动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版">
                        </a>
                        <div class="aritcle_card_info">
                            <a href="/xiazai/learn/2593">动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版</a>
                            <p>动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联JavaScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR外挂函数库的强大功能,对常用的、强大的包</p>
                            <div class="">
                                <img src="/static/images/card_xiazai.png" alt="动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版">
                                <span>508</span>
                            </div>
                        </div>
                        <a href="/xiazai/learn/2593" class="aritcle_card_btn">
                            <span>查看详情</span>
                            <img src="/static/images/cardxiayige-3.png" alt="动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版">
                        </a>
                    </div>
                
登录后复制

基本上就这些。只要写装饰器,建议都用 @wraps,避免丢失函数元信息,提升代码可维护性。不复杂但容易忽略。

以上就是python中wraps函数如何使用?的详细内容,更多请关注php中文网其它相关文章!

python速学教程(入门到精通)
python速学教程(入门到精通)

python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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