python常用修饰器

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值