Python高级笔记(十一)装饰器【面试】
1. 需求
开发封闭原则:虽然在这个原则是用的面向对象开发,但是也适用于函数式编程,简单来说,它规定已经实现的功能代码不允许被修改,但可以被拓展,即:
- 封闭:已实现的功能代码块
- 开发:对拓展开发
2. 使用装饰器
2.1 未使用装饰器(原理)
def w1(func):
def inner():
# 验证1
# 验证2
# 验证3
print("----正在验证权限----")
func()
return inner def f1():
print("---f1----") def f2():
print("---f2----") f1 = w1(f1) f1()
----正在验证权限----
---f1----
2.2 使用装饰器
def w1(func):
def inner():
# 验证1
# 验证2
# 验证3
print("----正在验证权限----")
func()
return inner @w1
def f1():
print("---f1----") @w1
def f2():
print("---f2----") f1()
f2()
----正在验证权限----
---f1----
----正在验证权限----
---f2----
3. 再议装饰器
# 定义函数:完成包裹数据
def makeBold(fn):
def wrapped():
print("-----1------")
return "<b>" + fn() + "</b>"
return wrapped # 定义函数:完成包裹数据
def makeItalic(fn):
def wrapped():
print("-----2------")
return "<i>" + fn() + "</i>"
return wrapped @makeBold
@makeItalic
def test3():
print("-----3-----")
return "hello world" s = test3()
print(s)
-----1------
-----2------
-----3-----
<b><i>hello world</i></b>
4. 装饰器执行时间
@w1
def f1():
print("---f1----")
只要Python解释器执行到了这个代码 ,那么就会自动的进行装饰,而不是等到调用的时候才装饰
5. 装饰器对有参数、无参数函数进行装饰
5.1 无参数
def func(functionName):
print("-----func----1-----")
def func_in():
print("---func_in----1----")
functionName()
print("---func_in----2----") print("-----func----2-----")
return func_in @func
def test():
print("----test------") test()
-----func----1-----
-----func----2-----
---func_in----1----
----test------
---func_in----2----
5.2 函数有参数
def func(functionName):
print("-----func----1-----")
def func_in(aa, bb):
print("---func_in----1----")
functionName(aa, bb)
print("---func_in----2----") print("-----func----2-----")
return func_in @func
def test(a, b):
print("----test---a=%d---b=%d---" %(a, b)) test(11, 22)
-----func----1-----
-----func----2-----
---func_in----1----
----test---a=11---b=22---
---func_in----2----
5.3 函数有不定参数
def func(functionName):
print("-----func----1-----")
def func_in(*args, **kargs):
print("---func_in----1----")
functionName(*args, **kargs)
print("---func_in----2----") print("-----func----2-----")
return func_in @func
def test(a, b, c):
print("----test---a=%d---b=%d---c=%d-------" %(a, b, c)) test(11, 22, 33)
-----func----1-----
-----func----2-----
---func_in----1----
----test---a=11---b=22---c=33-------
---func_in----2----
5.4 函数有返回值
def func(functionName):
print("-----func----1-----")
def func_in(*args, **kargs):
print("---func_in----1----")
res = functionName(*args, **kargs)
print("---func_in----2----")
return res print("-----func----2-----")
return func_in @func
def test(a, b, c):
print("----test---a=%d---b=%d---c=%d-------" %(a, b, c))
return "hahaha" res = test(11, 22, 33)
print("res: ", res)
-----func----1-----
-----func----2-----
---func_in----1----
----test---a=11---b=22---c=33-------
---func_in----2----
res: hahaha
6. 通用的装饰器
核心代码:
def func(functionName):
print("-----func----1-----")
def func_in(*args, **kargs):
print("---func_in----1----")
res = functionName(*args, **kargs)
print("---func_in----2----")
return res print("-----func----2-----")
return func_in
验证:
def func(functionName):
print("-----func----1-----")
def func_in(*args, **kargs):
print("---func_in----1----")
res = functionName(*args, **kargs)
print("---func_in----2----")
return res print("-----func----2-----")
return func_in @func
def test(a, b, c):
print("----test---a=%d---b=%d---c=%d-------" %(a, b, c))
return "hahaha" @func
def test2(a):
print("-----test2---%d---"%a) res = test(11, 22, 33)
print("res: ", res) test2(3)
-----func----1-----
-----func----2-----
-----func----1-----
-----func----2-----
---func_in----1----
----test---a=11---b=22---c=33-------
---func_in----2----
res: hahaha
---func_in----1----
-----test2---3---
---func_in----2----
7. 装饰器有参数
from time import ctime, sleep def timefun_arg(pre="hello"):
def timefun(func):
def wrappedfunc():
print("%s called at %s %s" %(func.__name__, ctime(), pre))
return func()
return wrappedfunc
return timefun @timefun_arg("douzi")
def foo():
print("I am foo") @timefun_arg("python")
def too():
print("I am too") foo()
sleep(2)
too()
foo called at Thu May 9 00:57:58 2019 douzi
I am foo
too called at Thu May 9 00:58:00 2019 python
I am too
8. 综合
from time import ctime, sleep def timefun_arg(pre="hello"):
print("fun_1")
def timefun(func):
print("fun_in_1")
def wrappedfunc(*args, **kwargs):
print("%s called at %s %s" %(func.__name__, ctime(), pre))
return func(*args, **kwargs)
print("fun_in_2")
return wrappedfunc
print("fun_2")
return timefun @timefun_arg("douzi")
def foo(fname):
print(fname, "I am foo") @timefun_arg("python")
def too():
print("I am too") foo("fname ")
sleep(2)
too()
Python高级笔记(十一)装饰器【面试】的更多相关文章
- Python学习笔记012——装饰器
1 装饰器 1.1装饰器定义 在代码运行期间动态增加功能的方式,称之为“装饰器”(Decorator). 1.2 装饰器分类 装饰器:函数装饰器,类装饰器,函数的装饰器,类的装饰器 装饰器:函数装饰函 ...
- Python学习笔记:装饰器
Python 装饰器的基本概念和应用 代码编写要遵循开放封闭原则,虽然在这个原则是用的面向对象开发,但是也适用于函数式编程,简单来说,它规定已经实现的功能代码不允许被修改,但可以被扩展,即: 封闭:已 ...
- python高级编程之装饰器04
from __future__ import with_statement # -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrat ...
- python学习笔记:装饰器2
python的装饰器本质是函数,为了不改变装饰目标函数内部代码而增加额外功能而存在 一.一般装饰函数实例: import datetime def func_name(func):#定义一个装饰函数, ...
- Python高级--闭包与装饰器
前言:在Python中,闭包是一种非常有用的功能!它通常与装饰器一起搭配使用,可以在不改变被装饰函数的功能的基础上,完成更多的功能.如权限认证. 一.如何定义闭包 1.闭包就是两个嵌套的函数,外层函数 ...
- python学习笔记(五):装饰器、生成器、内置函数、json
一.装饰器 装饰器,这个器就是函数的意思,连起来,就是装饰函数,装饰器本身也是一个函数,它的作用是用来给其他函数添加新功能,比如说,我以前写了很多代码,系统已经上线了,但是性能比较不好,现在想把程序里 ...
- python学习笔记之装饰器、生成器、内置函数、json(五)
一.装饰器 装饰器,这个器就是函数的意思,连起来,就是装饰函数,装饰器本身也是一个函数,它的作用是用来给其他函数添加新功能比如说,我以前写了很多代码,系统已经上线了,但是性能比较不好,现在想把程序里面 ...
- python学习笔记之装饰器、递归、算法(第四天)
参考老师的博客: 金角:http://www.cnblogs.com/alex3714/articles/5161349.html 银角:http://www.cnblogs.com/wupeiqi/ ...
- Python学习笔记之装饰器原理
def decorator(fn): def wrapper(): print("询价") fn() print("购买成功!") return wrapper ...
- python笔记 - day4-之装饰器
python笔记 - day4-之装饰器 需求: 给f1~f100增加个log: def outer(): #定义增加的log print("log") ...
随机推荐
- 分布式存储-ceph
1. ceph 简介 Ceph是一种为优秀的性能.可靠性和可扩展性而设计的统一的.分布式文件系统().ceph 的统一体现在可以提供文件系统.块存储和对象存储,分布式体现在可以动态扩展.在国内一些公司 ...
- Docker万字详解!
一.简介 1.了解Docker的前生LXC LXC为Linux Container的简写.可以提供轻量级的虚拟化,以便隔离进程和资源,而且不需要提供指令解释机制以及全虚拟化的其他复杂性.相当于C+ ...
- tkinter代码正式版
可以绘图了. import json import tkinter as tk from tkinter import filedialog from tkinter import LabelFram ...
- 解决SELinux导致Apache更改端口后无法启动的问题
systemctl start httpd # 将Apache的默认端口改为90后,启动Apache时提示失败 systemctl status httpd # 查看Apache的状态 可 ...
- 【转】libgo
原文:https://blog.csdn.net/libaineu2004/article/details/80554870 ------------------------------------- ...
- eclipse spring MVC maven项目 maven install target下无war包
1.排查问题 一步步去看,首先查看本地maven是否安装 命令:ctrl+r cmd 输入 mvn -v 查看maven版本 2.查看 window>preference ...
- Dubbo源码分析:ChannelHandler
背景 一个请求经过序列化二进制数据转化成对象之后.请求进入netty框架,netty框架经过业务处理把主动权转交给NettyHandler对象.NettyHandler进入ChannelHandler ...
- war包部署到服务器后,如何直接访问,而不需要在地址后面加war包名
正常情况下,但我们把war部署到服务器上,访问地址是:服务器ID:端口/war包名 但是如果个人建站显然不适合以此方式. 方式一:修改服务器Tomcat的server.xml配置 注意:你的报名如果是 ...
- SpringBoot终章(整合小型进销系统)
在前面的章节中我们学习Spring的时候可以看到配置文件比较多,所以我们有了SpringBoot 1. 引入依赖 <dependencies> <dependency> < ...
- solidworks 学习 (三)
汽车轮毂三维建模