函数装饰器——python

# 装饰器的结构
def decorator():
    def inner():
        pass
    return inner

Python函数装饰器
代码1:

import time


def cal_time(fn):  # 计算代码运行时间
    # def start():
    start_time = time.time()  # 记录代码开始执行时间戳
    return_value1 = fn()  # 执行目标函数
    end_time = time.time()  # 记录代码结束时间戳
    print('运行时间是', round(end_time - start_time, 4), '秒')  # 输出代码执行时间
    return return_value1


@cal_time  # 函数装饰器
def test11():
    time.sleep(1)
    print('sludge')
    return 100


test11 += 1#test11直接变成变量了么?
print(test11)

代码2:

import time


def cal_time(fn):  # 计算代码运行时间
    def start():
        start_time = time.time()  # 记录代码开始执行时间戳
        return_value1 = fn()  # 执行目标函数
        end_time = time.time()  # 记录代码结束时间戳
        print('运行时间是', round(end_time - start_time, 4), '秒')  # 输出代码执行时间
        return return_value1

    return start


@cal_time  # 函数装饰器
def test11():
    time.sleep(1)
    print('sludge')
    return 100


x = test11()
print(x)

经过函数装饰器以后,是否函数名直接变成一个变量名??

import time


def cal_time(fn):  # 计算代码运行时间
    # def start():
        start_time = time.time()  # 记录代码开始执行时间戳
        return_value1 = fn()  # 执行目标函数
        end_time = time.time()  # 记录代码结束时间戳
        print('运行时间是', round(end_time - start_time, 4), '秒')  # 输出代码执行时间
        return return_value1

    # return start
#

@cal_time  # 函数装饰器
def test11():
    time.sleep(3)
    print('sludge')
    return 100


# x = test11()
# print(x)
# 执行过函数转世器,接下来运行的函数会变成一个变量的么?

为什么这里没有执行 test11中的 print(‘sludge’)呢?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值