python常用修饰器
1. @staticmethod不需要实例化即可使用class的属性,方法#!/usr/bin/python# -*- coding: UTF-8 -*-class A(object):bar = 1def func1(self):print ('foo')@classmethoddef func2(cls):print ('func2')print (cls.bar)cls()
·
1. @staticmethod, @classmethod
不需要实例化即可使用class的属性,方法
#!/usr/bin/python
# -*- coding: UTF-8 -*-
class A(object):
bar = 1
def func1(self):
print ('foo')
@classmethod
def func2(cls):
print ('func2')
print (cls.bar)
cls().func1() # 调用 foo 方法
A.func2() # 不需要实例化
结果
2. @abc.abstractmethod
抽象基类。我们通过一些装饰器或者特殊的方法来把类里的方法虚化,虚化后的方法不能通过当前类调用,必须使用子类继承并且实现该方法才能调用该方法
import abc #先调用abc模块
class Canmjh(metaclass= abc.ABCMeta):#通过元类对象等于abc模块下的ABCMeta类才能调用该装饰器
@abc.abstractmethod
def dell(cls):
print('111')
class camkl(Canmjh):
def dell(cls):
print('clss') #一旦使用虚化然后在子类里必须重写该方法
a = camkl()
>>>clss
如果父类使用了@abc.abstractmethod装饰器,而子类没有将每一个父类重写都会报错,抽象基类也是这个原理。
3. @property
讲方法变成类的一个属性来调用
4. functools.partial
改变函数默认参数
def foo(a,b=0) :
'''
int add'
'''
print a + b
#user default argument
foo(1)
#change default argument once
foo(1,1)
#change function's default argument, and you can use the function with new argument
import functools
foo1 = functools.partial(foo, b=5) #change "b" default argument
foo1(1)
5. retry
Request失败后自动重试
6. functools.wraps
python装饰器在实现的时候,直接将被装饰函数变成了另一个函数,其函数名和函数属性均会发生变化。而使用functools.warps则可以保留原有函数名称和属性。
运行结果
更多推荐
已为社区贡献1条内容
所有评论(0)