day28-描述符应用与类的装饰器】的更多相关文章

#!/usr/bin/env python# -*- coding:utf-8 -*-# ------------------------------------------------------------## 参考资料:# 面向对象进阶 - linhaifeng - 博客园# https://www.cnblogs.com/linhaifeng/articles/6204014.html#_label12## python之函数介绍及使用 - 病毒尖er - 博客园# http://www…
 1.前言 Python的描述符是接触到Python核心编程中一个比较难以理解的内容,自己在学习的过程中也遇到过很多的疑惑,通过google和阅读源码,现将自己的理解和心得记录下来,也为正在为了该问题苦恼的朋友提供一个思考问题的参考,由于个人能力有限,文中如有笔误.逻辑错误甚至概念性错误,还请提出并指正.本文所有测试代码使用Python 3.4版本 注:本文为自己整理和原创,如有转载,请注明出处. 2.什么是描述符 Python 2.2 引进了 Python 描述符,同时还引进了一些新的样式类,…
描述符1.描述符是什么:描述符本质就是一个新式类,在这个新式类中,至少实现了__get__(),__set__(),__delete__()这三个内置方法中的一个,描述符也被称为描述符协议(1):__get__()调用一个属性时触发(2):__set__()为一个属性赋值时触发(3):__delete__()采用del删除属性时触发2.描述符的作用是用来代理另外一个类的属性的(必须把描述符定义成这个类的属性,不能定义到构造函数) class Foo: #定义新式类 def __get__(sel…
类是一个对象也可以像函数一样加装饰器 类的装饰器.py def deco(obj): print('======',obj) obj.x=1 obj.y=2 obj.z=3 return obj # @deco #test=deco(test) # def test(): # print('test函数运行') #运行了装饰器所以打印了装饰器里面的print内容 @deco #Foo=deco(Foo)#====== class Foo: pass #打印类的字典,其中xyz属性是在装饰器函数里…
一.类的装饰器 类作为一个对象,也可以被装饰. 例子 def wrap(obj): print("装饰器-----") obj.x = 1 obj.y = 3 obj.z = 5 return obj ​ @wrap #将Foo类作为一个参数传入装饰器函数wrap,返回同时返回该对象,把新对象重新命名为Foo #即 Foo = wrap(Foo) class Foo: pass ​ #执行结果: #装饰器----- ​ print(Foo.__dict__) #输出结果可以看到,新的F…
我们知道,在不改变原有代码的基础上,我们可以使用装饰器为函数添加新的功能.同理,一切皆对象,我们也可以使用装饰器为类添加类属性.what? def deco(obj): obj.x = 1 obj.y = 2 return obj @deco # Foo = deco(Foo) class Foo: pass print(Foo.__dict__) 上述的代码为Foo属性字典添加了x和y属性,但如果想添加'name' = 'harden'呢,这需要更灵活的定义了.so def deco(**kw…
1.普通就是一个函数作为装饰器,也可以用类名作为装饰器. 因为类和函数都是callable的,都可以使用括号来调用运行他. 2.上上篇的缓存一段时间的还是函数作为装饰器,类只是充当了比模块更下一级的命名空间,因为我的模块很大,不想搞很多模块级全局变量,所以用了class外壳. 正宗的类装饰器是这样 from functools import update_wrapper class Deco: """ Deco 的document """ def…
""" 类的装饰器: @property 当类的函数属性声明 @property后, 函数属性不需要加括号 即可调用 @staticmethod 当类的函数属性声明 @staticmethod后, 把函数属性声明为静态属性, 不能直接访问类属性与实例属性 @classmethod 当函数属性声明 @classmethod后,把函数属性声明为类属性,不能直接访问实例属性,类可以直接调用 """ class A(): q = "清华大学&q…
类的装饰器 # def deco(func): # print('==========') # return func # # # @deco #test=deco(test) # # def test(): # # print('test函数运行') # # test() # # @deco #Foo=deco(Foo) # class Foo: # pass def deco(obj): print('==========',obj) obj.x=1 obj.y=2 obj.z=3 retu…
第7.18节 案例详解:Python类中装饰器@staticmethod定义的静态方法 上节介绍了Python中类的静态方法,本节将结合案例详细说明相关内容. 一.    案例说明 本节定义了类StaticMethod,在类中定义了静态方法stmethod.类方法clsmethod和实例方法objmethod,重写了__new__(self)方法.演示内容包括: 1.    在类方法clsmethod中通过cls和类名两种方式调用静态方法stmethod: 2.    在实例方法objmetho…
根据别人发布整理,个人爱好收集(原文:https://blog.csdn.net/mydistance/article/details/83958655 ) 第一种:定义函数装饰器,在函数,类中使用函数装饰器 一.定义视图类 定义类视图,且类视图继承自View(举例) from django.views.generic import View class DemoView(View): """ 具体的视图函数 """ 定义路由: urlpatte…
装饰器方法 类的另外的特性,装饰器方法:静态方法(staticmethod).类方法(classmethod).属性方法(property) 一.静态方法 在方法名前加上@staticmethod装饰器,表示此方法为静态方法 class Dog(object): def __init__(self,name): self.name = name @staticmethod #在方法前加上staticmethod 装饰器定义静态方法 def eat(): print("dog is eating&…
这里用到了__call__的class内置参数 #类装饰器: class zsq(): #本质是定义一个参数,让装饰的主题传递至__call__方法内部 def __init__(self,obj): self.obj = obj #利用__call__将类转变为可执行 #__call__内相当于函数装饰器最外层 def __call__(self, *args, **kwargs): print("start") #返回主机函数 re = self.obj(*args, **kwar…
类在创建对象时,会调用 __init__ 初始化一些东西 , 然后 如果类中定义了 __call__ 方法,可以直接用  对象()  这种方法调用,所以可以用类来装饰函数: class Test(object): def __init__(self, func): print('----装饰-----') print('func name is %s' % func.__name__) self.__func = func def __call__(self, *args, **kwargs):…
学习了函数的装饰器的写法,然后想到如果要在类中初始化或获取信息时能用装饰器做过滤和验证应该怎么写呢, 在网上查了下相关信息,感觉这样也是可以的,不知道会不会有什么问题class Ctj(): class Ctj(): sex = 'man' name = 'name' age = ' def wrapper_func(func): # self 通过结构 可将需要单独使用的参数取出来 # *args 获取位置参数的可变参数 # **kwargs 关键字参数的可变参数 def wrapper(se…
# -*- coding: utf-8 -*- # author:baoshan # python对某个对象是否能通过装饰器形式使用只有一个要求:decorator必须是一个可被调用的对象. # 我们最熟悉的就是函数了 # 除函数之外,类也可以是callable对象,只要实现了__call__函数. # 如下DelayFunc是一个实现了__call__的类,delay返回一个偏函数,在这里delay就可以作为一个装饰器 import time import functools class De…
一.代码 #利用__call__方法,装饰器的执行流程:当添加装饰器语法糖时,会把语法糖的变量名加()执行,并将被装饰的函数名传入.所以当类加()执行时,执行了__init__,产生的对象就是被装饰的函数,而对象()执行时触发__call__,call方法下就能添加一些新的功能了 import time class Timeit: def __init__(self,func): self.func=func def __call__(self, *args, **kwargs): start_…
@classmethod 有的时候在类中会有一种情况,就是这个方法并不需要使用每一个对象属性 因此 这个方法中的self参数一个完全无用的参数,使用classmethod class A: __count = 0 # 隐藏类count属性 def __init__(self, name): self.name = name self.__add_count() # 每一次实例化的时候掉 # 用私有方法来对__count 进行累加 @classmethod def __add_count(cls)…
要将login_required装饰到view class的dispatch方法上, 因为dispatch方法为类方法,不是单个的函数,所以需要将装饰函数的装饰器 login_required转化为装饰类方法的装饰器,就要用到method_decorator . method_decorator的参数可以是单个装饰器,也可是一个装饰器组成的列表 from django.views.generic import View from django.contrib.auth.decorator imp…
# class Test(object): # def __call__(self): # print('-----test----') # t= Test()# t() 调用主要有个__call__方法 # __new__ __init__ __del__ __str__ __slots__ __call__ class Test(object): def __init__(self, func): print("---初始化---") print("func name i…
python  time模块 导入模块: import time #time模块是python中最基本的模块之一 输出时间戳:time.time() #可以用变量接收,要打印出来要用print(),如 a = time.time(),print(a)     输出为:1516330026.4591534(1970年1月1日00:00:00后经过的浮点秒数) 时间元组: time.localtime() #可以用变量接收,用print()打印,默认是当前的时间:也可以传入一个时间戳, 如:time…
class Myclass(object): def __init__(self): pass #必须实例化才能调用 def sayhi(self): print 'hello' #静态方法,跟类没什么关系,不需要实例化即可调用,类的工具包 @staticmethod def sayhi2(self): print 'hello2' #不需要实例化即可调用,不能访问实例数据 @classmethod def sayhi3(self): print 'hello3' #将函数变成静态属性 @pro…
1.property property是一种特殊的属性,可实现把函数名变为属性名使用.它可以在不改变类接口的前提下使用存取方法 (即读值和取值) 来修改数据的属性,property类有3个方法getter(读操作).setter(赋值操作).deleter(删除操作),分别把对应的操作 绑定到指定的函数实现,应用如下: class People: def __init__(self,name,weight,height): self.__name=name self.wt=weight self…
# def deco(obj): # print("=====",obj) # obj.x=1 # return obj # @deco#===> test = deco(test)----->return func # def test(): # print("test函数运行") # # test() def deco(obj): print("=====",obj) obj.x=1 obj.y=2 return obj @dec…
1.描述符 #!/usr/bin/python env # coding=utf-8 # 数据描述符__get__ __set__ __delete__ ''' 描述符总结 描述符是可以实现大部分python类特性中的底层魔法,包括@classmethod,@staticmethd,@property甚至是__slots__属性 描述符是很多高级库和框架的重要工具之一,描述符通常是使用到装饰器或者元类的大型框架中的一个组件 注意事项: 一 描述符本身应该定义成新式类,被代理的类也应该是新式类 二…
描述符是什么:描述符本质就是一个新式类,在这个新式类中,至少实现了__get__(),__set__(),__delete__()中的一个,这也被称为描述符协议 __get__():调用一个属性时,触发 __set__():为一个属性赋值时,触发 __delete__():采用del删除属性时,触发 class Foo: #在python3中Foo是新式类,它实现了三种方法,这个类就被称作一个描述符 def __get__(self, instance, owner): pass def __s…
一.再看property                                                                          一个静态属性property本质就是实现了get,set,delete三种方法 class Foo: @property def AAA(self): print('get的时候运行我啊') @AAA.setter def AAA(self,value): print('set的时候运行我啊') @AAA.deleter de…
目录 一.描述符 二.描述符的作用 2.1 何时,何地,会触发这三个方法的执行 三.两种描述符 3.1 数据描述符 3.2 非数据描述符 四.描述符注意事项 五.使用描述符 5.1 牛刀小试 5.2 拔刀相助 5.3 磨刀霍霍 5.4 大刀阔斧 5.4.1 类的装饰器:无参 5.4.2 类的装饰器:有参 5.5 刀光剑影 六.描述符总结 七.自定制@property 7.1 property回顾 7.2 自定制property 7.3 实现延迟计算功能 八.打破延迟计算 九.自定制@classm…
描述符(__get__和__set__和__delete__) 一.描述符 描述符是什么:描述符本质就是一个新式类,在这个新式类中,至少实现了__get__(),set(),delete()中的一个,这也被称为描述符协议 __get__():调用一个属性时,触发 __set__():为一个属性赋值时,触发 __delete__():采用del删除属性时,触发 定义一个描述符 class Foo: # 在python3中Foo是新式类,它实现了__get__(),__set__(),__delet…
实验性的特性,需要在tslint里面把这项设置为true 作用域类的声明方法.访问符.属性和参数上 使用@符号加一个名字来定义,名字必须是一个函数,或者求值后是一个函数 装饰器工厂,setPro当做一个装饰器工厂,里面返回一个函数的结果. 调用的时候直接@setProp() 后面加上括号去调用 装饰器组合使用,装饰器工厂是从上往下调用,普通的装饰器是从下往上一次执行 如果都是装饰器工厂,就是从上向下执行,依次就出来装饰器工厂内的值 定义两个装饰器工厂   在类的上面加上装饰器的工厂,从上到下执行…