python 装饰器

复制代码
#函数返回值+1
def make(func):
    def wrapper(*args,**kwds):
        return func(*args,**kwds) + 1
    return wrapper

@make
def add():
    return 4

print add()  #输出5
复制代码
复制代码
#函数返回值+N
def makearg(num):
    def make(func):
        def wrapper(*args,**kwds):
            return func(*args,**kwds) + num
        return wrapper
    return make

@makearg(num=1)
def add(n):
    return n + 4
    
print add(4) # 输出9

装饰器传参 参考 https://www.cnblogs.com/serpent/p/9445592.html
复制代码
复制代码
#检测函数执行时间
import time
import sys
def timer(func):
    def wrapper(*args,**kwds):
        start=time.time()
        func(*args,**kwds)
        end=time.time()
        print "exe function %s take %s time" %(func.__name__,str(end - start))
    return wrapper

@timer
def add():
    print "start"
    time.sleep(5)
    print "ending"

add()
复制代码

 

posted on   思此狂  阅读(149)  评论(0编辑  收藏  举报

编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· Vue3状态管理终极指南:Pinia保姆级教程

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示