这篇文章给大家分享的是有关Python如何实现子类获取父类的类成员方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
python常用的库:1.requesuts;2.scrapy;3.pillow;4.twisted;5.numpy;6.matplotlib;7.pygama;8.ipyhton等。
class Config: BASE_DIR = "/tmp" class TestConfig(Config): DATA_DIR = os.path.join(Config.BASE_DIR, "data")
然后我在子类中想要访问父类的类成员变量,而且这两个类都是只有类成员变量。感觉目前我使用的方法笨一点,就是直接引用父类的名字,感觉这样的方法不灵活,我想找一种方法,可以让子类访问到父类。
我在网上搜索了一下,找了这么两种方法,但是感觉都不怎么符合我的需求:
1. 在子类方法中调用super(TestConfig, self)来获取父类(我的类只有类成员变量,没有self)
2. 通过子类的名字SubConfig.__bases__来获取父类(我是在SubConfing这个子类内部执行相关语句的,会抛出SubConfig还未定义的NameError)
然后就没有找到其他的办法了,所以想来和大家请教一下,像我这种想法,有办法可以实现吗?应该怎么做啊?这个问题问的可能比较傻,还请大家不要见怪。
@Python Yiyi
利用Python3 metaclass 实现
>>> import os >>> class M(type): @classmethod def __prepare__(metacls, name, bases, **kwds): d = dict() for base in bases: for key, value in base.__dict__.items(): if not key.startswith('_'): d[key] = value return d def __new__(cls, name, bases, namespace, **kwds): for base in bases: for key, value in base.__dict__.items(): if not key.startswith('_'): del namespace[key] return type.__new__(cls, name, bases, dict(namespace)) >>> class Config(metaclass=M): BASE_DIR = "/tmp" >>> class TestConfig(Config): DATA_DIR = os.path.join(BASE_DIR, "data") >>> TestConfig.DATA_DIR '/tmp\\data' >>> >>> TestConfig.__dict__ mappingproxy({'__doc__': None, '__module__': '__main__', 'DATA_DIR': '/tmp\\data'}) >>>
附上上述代码的解释,基本都来自于Python 语言参考中描述:
当执行类定义时,将执行以下步骤:
确定正确的元类
准备类的命名空间
执行类的主体
创建类对象
3.3.3.1. 确定正确的元类
3.3.3.2. 准备类的命名空间
确定正确的元类后,则开始准备类的命名空间。如果元类具有__prepare__属性,那么它以namespace = metaclass.__prepare__(name, bases, **kwds)形式调用(其中如果有额外的关键字参数,那么它们来自类的定义)。
如果元类没有__prepare__属性,那么类的命名空间初始化一个空的dict()实例。
3.3.3.3. 执行类的主体
类的主体(大体上)以exec(body, globals(), namespace)的方式执行。(从这里可以看出,BASE_DIR找不到的原因是globals() 和namespace 中没有BASE_DIR定义。解决办法是将基类的成员拷贝到namespace中)
3.3.3.4. 创建类对象
类的命名空间通过执行类的主体创建完之后,通过调用metaclass(name, bases, namespace, **kwds)创建类对象(这里传递过来的额外的关键字参数与传递给__prepare__的相同)。
感谢各位的阅读!关于“Python如何实现子类获取父类的类成员方法”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。