我的编程空间,编程开发者的网络收藏夹
学习永远不晚

day11-装饰器

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

day11-装饰器

  这里先导入time模块的概念。

import  time
print(time.time()) # 打印距离1970年到现在的秒数
time.sleep(1) # 停留一秒再执行下一句
'''
测试一段代码执行会经过多长时间
'''
import time
def func(): # 被装饰的函数
    time.sleep(0.01) # 由于一个print语句太少,所以这里故意设置一个时间间隔,以达到预期效果。
    print('今天好热')

def timmer(f): # 装饰器函数
    def inner():
        start = time.time()
        f() # 调用被装饰的函数
        end = time.time()
        print('时间间隔为:',end - start)
    return inner

result = timmer(func)
result()

  上面一段代码就是一个简单的装饰器。

  通常为了是代码更加优美,于是引入语法糖的概念。这里将对上述第二段代码进行改进,他们的作用和结果完全相同。

'''
测试一段代码执行会经过多长时间
'''
import time

def timmer(f): # 装饰器函数
    def inner():
        start = time.time()
        f() # 调用被装饰的函数
        end = time.time()
        print('时间间隔为:',end - start)
    return inner

@timmer #语法糖-@装饰器函数
def func(): # 被装饰的函数
    time.sleep(0.01) # 由于一个print语句太少,所以这里故意设置一个时间间隔,以达到预期效果。
    print('今天好热')

# result = timmer(func) @timeer与此句一个作用相同
func() # 分析一下,此func等价于timmer(func),也就相当于inner。
'''
测试一段代码执行会经过多长时间
'''
# 新增功能-装入带参数函数的装饰器
import time

def timmer(f): # 装饰器函数
    def inner(a):
        start = time.time()
        f(a) # 调用被装饰的函数
        end = time.time()
        print('时间间隔为:',end - start)
    return inner

@timmer #语法糖-@装饰器函数
def func(a): # 被装饰的函数
    time.sleep(0.01) # 由于一个print语句太少,所以这里故意设置一个时间间隔,以达到预期效果。
    print('今天好热',a)

# result = timmer(func) @timeer与此句一个作用相同
func(1) # 分析一下,此func等价于timmer(func),也就相当于inner。
装入带参数函数的装饰器

  上面一段代码是装入一个参数,如果我想在被装饰函数中加入两个参数呢?也许你会说,再加入一个变量,那么三个参数呢?这个时候我们就要用到前面学过的内容:*args。继续,如果我们再加入一个关键字参数呢?同样,我们要用到**kwargs。下面是代码:

'''
测试一段代码执行会经过多长时间
'''
# 新增功能-装入带参数函数的装饰器
import time

def timmer(f): # 装饰器函数
    def inner(*args,**kwargs):
        start = time.time()
        f(*args,**kwargs) # 调用被装饰的函数
        end = time.time()
        print('时间间隔为:',end - start)
    return inner

@timmer #语法糖-@装饰器函数
def func(a,b): # 被装饰的函数
    time.sleep(0.01) # 由于一个print语句太少,所以这里故意设置一个时间间隔,以达到预期效果。
    print('今天好热',a,b)

# result = timmer(func) @timeer与此句一个作用相同
func(1,b = 3) # 分析一下,此func等价于timmer(func),也就相当于inner。

 

  (1)不想修改函数的调用方式,但是还想在原来的函数前后添加功能。

  (2)timmer就是一个装饰器函数,只是对一个函数有一些装饰作用。

  对扩展是开放的。

  对修改是封闭的。

4.1._name_、_doc_

# 学习._name_和._doc_,在这里如果不做任何修改,._name_会输出inner,因为study和inner等价,但是我们做出以下修改,就会成功输出study
from functools import wraps #导入
def wrapper(func):
    @wraps(func)# 加上这句
    def inner(*args,**kwargs):
        print('在被装饰的函数执行前要做的事')
        ret = func(*args,**kwargs)
        print('在被装饰的函数执行后要做的事')
        return ret
    return inner

@wrapper
def study(days):
    '''
    这是一个注释
    :param days:
    :return:
    '''
    print('坚持学习%s天'%days)
    return '加油'

# ret = study(10)
# print(ret)

print(study.__name__)# 输出
print(study.__doc__)

4.2.多个函数下的装饰器

# 若多个函数同时用一个装饰器,一般来说就是在函数上面加一个@装饰器名,但是我们有不想用它的时候,如果我们一个一个去删除它则会非常的麻烦,下面这种方法将会解决这种问题。
import time
Flag = False

def timmer_out(Flag):
    def timmer(func):
        def inner(*args,**kwargs):
            if Flag:
                start = time.time()
                ret = func(*args,**kwargs)
                end = time.time()
                print(end - start)
                return ret
            else:
                ret = func(*args, **kwargs)
                return ret
        return inner
    return timmer
@timmer_out(Flag)
def para_fir():
    time.sleep(0.1)
    print('the first')

@timmer_out(Flag)
def para_sec():
    time.sleep(0.1)
    print('the second')

para_fir()
para_sec()
# 思想就是在装饰器外再加上一层,成为三层装饰器,通过判断Flag为True还是False,来执行相应的代码块

4.3.多个装饰器

def wrapper1(func):  # func-->f
    def inner1():
        print('wrapper1 ,before func')
        ret = func()
        print('wrapper1 ,after func')
        return ret
    return inner1

def wrapper2(func): # func = inenr1
    def inner2():
        print('wrapper2 ,before func')
        ret = func()
        print('wrapper2 ,after func')
        return ret
    return inner2


@wrapper2 # f = wrapper2(f) -> wrapper2(inner1) = inner2
@wrapper1 # f = wrapper1(f) = inner1
def f():
    print('in f')
    return '哈哈哈'

print(f()) # f = inner2

# result:
# wrapper2 ,before func
# wrapper1 ,before func
# in f
# wrapper1 ,after func
# wrapper2 ,after func
# 哈哈哈

# 仔细观察这个结果,首先执行wrapper1,将f传入wrapper1中,于是wrapper1中的func就是f,最后返回一个inner1。接着再执行wrapper2,但是此时传入wrapper2中的参数是上一次执行返回过来的inner1,所以wrapper2中的func是inner1,最后返回一个inner2。
# 为什么结果是先有wrapper2,但是实际上是先执行wrapper1呢,这是因为装饰器中的语法糖会找最近的一个被修饰的函数,显然wrapper1更接近f(),而wrapper2比较远,所以是先执行wrapper1,再是wrapper2。

 

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

day11-装饰器

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

day11-装饰器

这里先导入time模块的概念。import timeprint(time.time()) # 打印距离1970年到现在的秒数time.sleep(1) # 停留一秒再执行下一句'''测试一段代码执行会经过多长时间'''import tim
2023-01-31

python装饰器2:类装饰器

装饰器1:函数装饰器装饰器2:类装饰器装饰器3:进阶本文是装饰器相关内容的第二篇,关于类装饰器。"类装饰器"有两种解读方式:用来装饰类的装饰器;类作为装饰器装饰其它东西。你如何认为取决于你,两种说法都有出现在其它的文章中。我的文章中是将"类
2023-01-30

装饰器

def wrapper(func):  def inner(args*,**kwargs):    ret = func(args*,**kwargs)    return ret  return inner@wrapperdef func
2023-01-30

python装饰器1:函数装饰器详解

装饰器1:函数装饰器装饰器2:类装饰器装饰器3:进阶先混个眼熟谁可以作为装饰器(可以将谁编写成装饰器):函数方法实现了__call__的可调用类装饰器可以去装饰谁(谁可以被装饰):函数方法类基础:函数装饰器的表现方式假如你已经定义了一个函数
2023-01-30

python3--装饰器

# Author: Aaron Fan"""装饰器(别名:语法糖):定义:    本质是函数(装饰其它函数),就是为其它函数添加一些附件的功能原则:    1、不能修改被装饰的函数的源代码    2、不能修改被装饰的函数的调用方式    3
2023-01-31

python3装饰器

预备知识首先我们要知道在python,一切皆对象,函数也是一个对象 >>> def test():... return "Hello World"有自己的id值,有type,有自己的值>>> id(test)140155005410
2023-01-31

类装饰器

在理解类装饰器之前,先回忆一下有关装饰器的知识。装饰器本质上就是一个函数,它可以让其他函数在不需要做任何代码变动的前提下增加额外的功能,装饰器的返回值也是一个函数对象(函数的引用)。 __call__方法  一个对象是否可调用,看其中是否实
2023-01-30

python-装饰器

装饰器简介:给被装饰的函数在不更改代码的基础上增加新的功能;多个装饰器的执行顺序:从最靠近原始函数的装饰器开始执行,最后执行原始函数; 直接上个简单的例子就懂了: 一 最简单的装饰器:#!/usr/bin/python def deco(f
2023-01-31

python 装饰器

装饰器本质上是一个Python函数,它可以让其他函数在不雲要做任何代码变动的前提下增加额外功能,装饰器的返回值也是一个函数对象。它经常用于有切面雲求的场景,比如:插入日志、性能测试、事务处理、缓存、权限校验等场景。装饰器是解决这类问题的绝佳
2023-01-30

python3 装饰器

看廖雪峰官网的python3装饰器有感装饰器即将一个函数作为变量在新的函数中调用此函数。作业:能否写出一个@log的decorator,使它既支持:@logdef f():    pass又支持:@log('execute')def f()
2023-01-31

python装饰器

什么是装饰器:  装饰器就是python中的一个语法糖。作用就是在不改动之前代码的情况下给某个函数增加相应想要增加的功能。假设需求:  我在几个函数内分别放了一部电影,代码如下:1 def mv1():2 print("高清无码01
2023-01-30

day 15 装饰器

装饰器(重点,难点)开闭原则:            对功能的扩展开放           对代码的修改是封闭的在目标函数前和后插入一段新的代码.不改变原来的代码通用装饰器写法:# 存在的意义: 在不破坏原有函数调用的基础上,给韩式添加新的
2023-01-30

Python装饰器与类的装饰器怎么实现

这篇“Python装饰器与类的装饰器怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python装饰器与类的装饰器怎么
2023-06-29

Python之装饰器

在Python中一切皆对象,函数是一等对象。这意味着可以通过名字引用函数。>>> a=123>>> a123>>> name='zeng'>>> name'zeng'>>> def func():...     print "hello!"
2023-01-31

python_类装饰器

一.定义装饰器就是一个给对象添加额外功能的函数,其本质是函数。它的基本构造:高阶函数+函数嵌套+闭包。基础知识讲解详见:https://blog.51cto.com/10836356/2095118二.简单类的装饰器我们先看简单的类的装饰器
2023-01-31

Python中怎么使用装饰器装饰函数

这篇文章将为大家详细讲解有关Python中怎么使用装饰器装饰函数,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。***个函数deco是装饰函数,它的参数就是被装饰的函数对象。我们可以在deco
2023-06-17

Python带参装饰器

装饰器(无参)  它是一个函数;  函数作为它的形参;  返回值也是一个函数;  可以使用@functionname方式,简化调用;装饰器和高阶函数  装饰器是高阶函数,但装饰器是对传入函数的功能的装饰(功能增强)import dateti
2023-01-31

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录