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则可以保留原有函数名称和属性。
在这里插入图片描述

运行结果
在这里插入图片描述

Logo

CSDN联合极客时间,共同打造面向开发者的精品内容学习社区,助力成长!

更多推荐