python进阶(三)~~~装饰器和闭包
一、闭包
满足条件:
1. 函数内嵌套一个函数;
2.外层函数的返回值是内层函数的函数名;
3.内层嵌套函数对外部作用域有一个非全局变量的引用;
def func():
print("===func====")
num=2
def wrapper():
print("------wrapper------")
print(num2) # 或者直接引用func的传参
return wrapper res=fun()
res()
闭包的作用:实现数据锁定,不受外部影响。
二、装饰器
开放封闭原则:面向对象的核心。软件实体应当是可扩展,而不可修改的。也就是说,对扩展是开放的,对修改是封闭的。
装饰器:在不改变原来函数功能的情况下,进行扩展。同时,不改变调用方式。
使用:@装饰器名称。 @为装饰器的语法糖
常见应用场景:
1. 权限校验,预判断是否有执行函数功能的权限;
2. 计时,计算函数运行时间;
3. 进行环境准备和恢复工作;
4. web自动化用例失败截图;
# 示例4:失败截图装饰器
from selenium import webdriver browser=webdriver.Chrome()
browser.get("https://www.baidu.com") def decorator(func):
def wrapper():
try:
func()
except:
browser.save_screenshots("error.png")
raise e
return wrapper @decorator
def test_search():
browser.find_element_by_xpath("//input[@id='kw']").sendkeys("ninmen")
browser.find_element_by_xpath("//input[@id='su123']").click() test_search()
1、普通装饰器
def decorator(func):
def wrapper():
print("----这是装饰器内层函数----")
func()
return wrapper @decorator # 等同于执行func = decorator(func)
def func():
print("====这是原功能函数====") func() # 此时,不改变调用方式的同时,实现了功能扩展
2、带参数的装饰器
3、通用装饰器
#带参数
def decorator(func):
def wrapper(a,b):
print("----这是装饰器内层函数----")
func(a,b)
return wrapper #通用
def decorator(func):
def wrapper(*args,**kwargs):
print("----这是装饰器内层函数----")
func(*args,**kwargs)
return wrapper @decorator # 等同于执行func = decorator(func)
def func(a,b):
print("====求和====",a+b) func()
4、类实现装饰器
__call__:魔术方法,在对象使用括号时被触发
class Decorator():
'''类实现通用的装饰器'''
def __init__(self,func):
self.func=func def __call__(self,*args,**kwargs):
print("----这是装饰器内层函数----")
return self.func(*args,**kwargs) @Decorator # 等同于执行func = Decorator(func)
def func(a,b):
print("====求和====",a+b)
5、装饰器装饰类
class Decorator():
'''类实现通用的装饰器'''
def __init__(self,func):
self.func=func def __call__(self,*args,**kwargs):
print("----这是装饰器内层函数----")
return self.func(*args,**kwargs) @Decorator # 等同于执行func = Decorator(Hero)
class Hero:
def func(a,b):
print("====求和====",a+b) h=Hero()
h.func() #也可以使用 2中的通用装饰器
def decorator(func):
def wrapper(*args,**kwargs):
print("扩展功能")
obj=func(*args,**kwargs)
return obj #返回类对象
return wrapper @decorator # 等同于执行func = decorator(Hero)
class Hero:
def func(a,b):
print("====求和====",a+b) h=Hero()
h.func()
6、三个内置的装饰器
1、@property 将某函数,做为属性使用
property可以将python定义的函数当做属性访问,从而提供更加友好访问方式,但是有时候setter/deleter也是需要的
只有@property表示只读。
同时有@property和@x.setter表示可读可写。
同时有@property和@x.setter和@x.deleter表示可读可写可删除。
class Foo:
def __init__(self, name):
self.__name = name
@property
def name(self):
return self.__name
@name.setter
def name(self, value):
if not isinstance(value, str):
raise TypeError('name must be str')
self.__name = value
@name.deleter
def name(self):
raise TypeError('can not delete')
f = Foo('jack')
print(f.name) # jack
f.name = 'hanmeimei'
print(f.name) # hanmeimei
# del f.name # TypeError: can not delete
2、@classmethod 修饰类的方式:仅仅与类交互而不和实例交互,类在使用时会将类本身当做参数传给类方法的第一个参数
带修饰类方法:cls做为方法的第一个参数,隐式的将类做为对象,传递给方法,调用时无须实例化。
普通函数方法:self做为第一个参数,隐式的将类实例传递给方法,调用方法时,类必须实例化。
class Date: def __init__(self, year, month, day):
self.year = year
self.month = month
self.day = day @classmethod
def now(cls):
t = time.localtime()
return cls(t.tm_year, t.tm_mon, t.tm_mday) def __str__(self):
return '%s-%s-%s' % (self.year, self.month, self.day) e = Date.now()
print(e) # 2018-8-1
3、@staticmethod 修饰类的方式
1) 静态方法和在普通的非class的method作用是一样的,只不过是命名空间是在类里面。
2) 一般使用场景就是和类相关的操作,但是又不会依赖和改变类、实例的状态,比如一些工具方法。
class Date: def __init__(self, year, month, day):
self.year = year
self.month = month
self.day = day @staticmethod
def now():
t = time.localtime()
return Date(t.tm_year, t.tm_mon, t.tm_mday) def __str__(self):
return '%s-%s-%s' % (self.year, self.month, self.day) e = Date.now()
print(e) # 2018-8-1
python进阶(三)~~~装饰器和闭包的更多相关文章
- Python进阶(六)----装饰器
Python进阶(六)----装饰器 一丶开放封闭原则 开放原则: 增加一些额外的新功能 封闭原则: 不改变源码.以及调用方式 二丶初识装饰器 装饰器: 也可称装饰器函数,诠释开放封闭原则 ...
- python进阶04 装饰器、描述器、常用内置装饰器
python进阶04 装饰器.描述器.常用内置装饰器 一.装饰器 作用:能够给现有的函数增加功能 如何给一个现有的函数增加执行计数的功能 首先用类来添加新功能 def fun(): #首先我们定义一个 ...
- Python进阶之装饰器
函数也是对象 要理解Python装饰器,首先要明白在Python中,函数也是一种对象,因此可以把定义函数时的函数名看作是函数对象的一个引用.既然是引用,因此可以将函数赋值给一个变量,也可以把函数作为一 ...
- python函数下篇装饰器和闭包,外加作用域
装饰器和闭包的基础概念 装饰器是一种设计模式能实现代码重用,经常用于查日志,性能测试,事务处理等,抽离函数大量不必的功能. 装饰器:1.装饰器本身是一个函数,用于装饰其它函数:2.功能:增强被装饰函数 ...
- Python进阶: Decorator 装饰器你太美
函数 -> 装饰器 函数的4个核心概念 1.函数可以赋与变量 def func(message): print('Got a message: {}'.format(message)) send ...
- python学习-42 装饰器 --- 函数闭包1
函数闭包举例: def father(name): print('hello world') def son(): print('儿子说:我的爸爸是%s' % name) def grandfson( ...
- python进阶:装饰器
1.闭包 简单理解:闭包就是多层函数的嵌套,外层函数的返回值是内层函数的引用. def out_func(n): num = 100 def in_fucn(*args,**kwargs): # no ...
- [Python进阶]002.装饰器(1)
装饰器(1) 介绍 HelloWorld 需求 使用函数式编程 加入装饰器 解析 介绍 Python的装饰器叫Decorator,就是对一个模块做装饰. 作用: 为已存在的对象添加额外功能. 与Jav ...
- Python进阶(装饰器)
from datetime import datetime def log(func):#func表示装饰器作用于的函数 def wrapper(*args,**kw):#wrapper返回装饰器作用 ...
随机推荐
- 提升Essay写作说服力,需要注意这几个细节
很多留学生对于essay写作都不精通,能够勉强通过就不错了.那么Essay写作到底该怎么提分呢?可以从哪些方面入手?小编给同学们指几条路,相信可以帮到大家. 在有说服力的Essay中总结您的论点.尽管 ...
- 修正png
这是修正+取MD5的方法 function MD5FileTextPng(filename: AnsiString): AnsiString; var buf: ..MAX_PATH - ] of C ...
- ACM-Antiprime数
问题描述: swust打不开,随便找了个博客.... 对于任何正整数x,起约数的个数记做g(x).例如g(1)=1,g(6)=4. 定义:如果某个正整数x满足:对于任意i(0<i<x) ...
- 编写程序,实现在带头结点的单链表L中删除一个最小值节点的算法。
算法复杂度0(n) #!/usr/bin/env python3 class LNode(object): def __init__(self, elem, next_=None): self.ele ...
- Python基础笔记:input()输入与数据类型转换
input就是个万能输入,不过input输入的元素都是以str形式保存的,如果要他作为一个整数的话,就需要进行数据类型转换. input的使用 name=input('please input you ...
- DFS(深度优先搜索遍历求合格条件总数)--07--DFS--蓝桥杯方格填数
此题方法多种,我用规范的DFS来求解 题目:方格填数 如下的10个格子,填入0~9的数字.要求:连续的两个数字不能相邻. (左右.上下.对角都算相邻)一共有多少种可能的填数方案? 输出 请填写表示 ...
- Flask—路由的注册方法
第一种注册方法 from flask import Flask app = Flask(__name__) @app.route("/hello") # 第一种注册方法 def h ...
- Sqlserver 增删改查----改
--我们就以院系,班级,学生来举例. create TABLE [dbo].YuanXi ( Id ,) NOT NULL,--学校id 自增量 YuanXiName varchar() null, ...
- Marvolo Gaunt's Ring(巧妙利用前后缀进行模拟)
Description Professor Dumbledore is helping Harry destroy the Horcruxes. He went to Gaunt Shack as h ...
- 在Mac上如何运行jar文件
操作一:编译,打包. 操作二: 运行jar文件,提示:jar中没有主清单属性. 解决办法: 使用解压工具解压HelloWorld.jar文件,往MANIFEST.MF中添加Main-Class. 1. ...