首页 > 开发 > Python > 正文

python装饰器使用实例详解

2024-09-09 19:03:17
字体:
来源:转载
供稿:网友

这篇文章主要介绍了python装饰器使用实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

python装饰器的作用就是在不想改变原函数代码的情况下,增加新的功能.主要应用了python闭包的概念,现在用1个小例子说明

import timedef foo():  time.sleep(1)  def bar():  time.sleep(2)  def show_time(f):  def inner():    start_time = time.time()    f()    end_time = time.time()    print(end_time-start_time)  return inner#show_time(f) is a decoration functionfoo = show_time(foo)bar = show_time(bar)foo()bar()

上面的代码定义了两个函数foo()和bar(). 通过装饰器函数show_time(f),在其内部定义了另一个闭包函数inner(),再通过foo=show_time(foo),bar=show_time(bar)语句将foo()和bar()函数同装饰器函数关联起来,从而实现了不改变foo()和bar()函数代码,增加打印程序执行时间的功能.程序的执行结果如下:

1.00113701822.00142788887

显然,程序在没有改变原函数的情况下,实现了调用原函数显示程序运行时间的功能.

上面的小程序可以将调用装饰器的语句改成@decoration的形式,效果是造价的,改变后的程序如下,其功能和上面的程序完全相同.

import time@show_time #foo = show_time(foo)def foo():  time.sleep(1) @show_time #bar = show_time(bar)def bar():  time.sleep(2)    def show_time(f):  def inner():    start_time = time.time()    f()    end_time = time.time()    print(end_time-start_time)  return inner#show_time(f) is a decoration functionfoo()bar()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网之家。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表