python @classmethod详解

classmethod 修饰符对应的函数不需要实例化,不需要 self 参数,但第一个参数需要是表示自身类的cls参数,
可以来调用类的属性,类的方法,实例化对象等。
废话不多说,直接上代码
1.简洁调用方式

class TestClass(object):

    def __init__(self, data_str):
        self.data_str = data_str

    def get_year(self):
        data_list = self.data_str.split('.')
        print(data_list[0])

class TestClass2(object):

    def __init__(self, data_str):
        self.data_str = data_str
    @classmethod
    def get_year(cls, data_str):
        data_list = data_str.split('.')
        print(data_list[0])

tc = TestClass('1992.9.2') # 实例化类
tc.get_year()              # 再调用类方法
TestClass2.get_year('1992.9.2') # 直接调用类方法

TestClass 类使用的是普通的成员方法
TestClass2 则使用classmethod修饰方法
可以看到,TestClass2在调用类方法时,不需要实例化类,更加简洁

2.方便扩展功能

请看下面代码

class TestClass(object):
    day = ''
    month = ''
    year = ''
    def __init__(self, year='', month='', day=''):
        self.day = day
        self.month = month
        self.year = year
    def out_print(self):
        print('year: %s month: %s day: %s' %(self.year, self.month, self.day))

ss = TestClass('2022','10','24')
ss.out_print()

输出 year: 2022 month: 10 day: 24        
这是一个输入三个数字字符串,然后输出年月日的类
现在可能有人觉得输入三个字符串太麻烦了,就想输入一个类似这样的字符串'2022.10.24'
怎么办呢,当然是使用classmethod修饰方法

class TestClass2(object):
    day = ''
    month = ''
    year = ''
    def __init__(self, year='', month='', day=''):
        self.day = day
        self.month = month
        self.year = year
    @classmethod
    def format_date(cls, str_date):
        year, month, day = str_date.split('.')
        new_date = cls(year, month, day)# 返回一个初始化类对象
        return new_date
    def out_print(self):
        print('year: %s month: %s day: %s' %(self.year, self.month, self.day))
ss = TestClass2.format_date('2022.10.24')
ss.out_print()

输出 year: 2022 month: 10 day: 24

当然也可以使用继承的方式

class TestClass3(TestClass):
    @classmethod
    def format_date(cls, str_date):
        year, month, day = str_date.split('.')
        new_date = cls(year, month, day)
        return new_date
tt = TestClass3.format_date('1992.9.2')
tt.out_print()

输出 year: 1992 month: 9 day: 2

文章出处登录后可见!

已经登录?立即刷新

共计人评分,平均

到目前为止还没有投票!成为第一位评论此文章。

(0)
社会演员多的头像社会演员多普通用户
上一篇 2023年3月5日 下午7:54
下一篇 2023年3月5日 下午7:55

相关推荐