Python 实现子类获取父类的类成员方法


Posted in Python onJanuary 11, 2019

大家好,今天在写代码的时候,遇到了这样一种情况。我有如下所示的几个类用来存放程序配置(其实当做命名空间来用,同时感觉能够继承方便一点),

import os
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 实现子类获取父类的类成员方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python根据京东商品url获取产品价格
Aug 09 Python
详解Python 模拟实现生产者消费者模式的实例
Aug 10 Python
分析Python中解析构建数据知识
Jan 20 Python
TensorFLow用Saver保存和恢复变量
Mar 10 Python
在cmd中运行.py文件: python的操作步骤
May 12 Python
Python处理命令行参数模块optpars用法实例分析
May 31 Python
Python用csv写入文件_消除空余行的方法
Jul 06 Python
Python后台开发Django的教程详解(启动)
Apr 08 Python
适合Python初学者的一些编程技巧
Feb 12 Python
Django Admin设置应用程序及模型顺序方法详解
Apr 01 Python
pycharm开发一个简单界面和通用mvc模板(操作方法图解)
May 27 Python
Python分类测试代码实例汇总
Jul 23 Python
python使用xlrd模块读取xlsx文件中的ip方法
Jan 11 #Python
python远程调用rpc模块xmlrpclib的方法
Jan 11 #Python
解决PySide+Python子线程更新UI线程的问题
Jan 11 #Python
python PrettyTable模块的安装与简单应用
Jan 11 #Python
对python多线程中互斥锁Threading.Lock的简单应用详解
Jan 11 #Python
pyqt5实现俄罗斯方块游戏
Jan 11 #Python
python之线程通过信号pyqtSignal刷新ui的方法
Jan 11 #Python
You might like
使用PHP数组实现无限分类,不使用数据库,不使用递归.
2006/12/09 PHP
在Ubuntu 18.04上安装PHP 7.3 7.2和7.0的方法
2019/04/09 PHP
原生javascript实现图片按钮切换
2015/01/12 Javascript
Bootstrap每天必学之轮播(Carousel)插件
2016/04/25 Javascript
js实现页面跳转的几种方法小结
2016/05/16 Javascript
js获取文件里面的所有文件名(实例)
2017/10/17 Javascript
web前端vue之CSS过渡效果示例
2018/01/10 Javascript
angular6.0开发教程之如何安装angular6.0框架
2018/06/29 Javascript
jQuery实现的淡入淡出图片轮播效果示例
2018/08/29 jQuery
JavaScript实现小球沿正弦曲线运动
2020/09/07 Javascript
JavaScript实现多个物体同时运动
2020/03/12 Javascript
vue实现div可拖动位置也可改变盒子大小的原理
2020/09/16 Javascript
vue使用echarts图表自适应的几种解决方案
2020/12/04 Vue.js
python处理PHP数组文本文件实例
2014/09/18 Python
Python获取邮件地址的方法
2015/07/10 Python
Python 搭建Web站点之Web服务器网关接口
2016/11/06 Python
对Python中gensim库word2vec的使用详解
2018/05/08 Python
深入flask之异步非堵塞实现代码示例
2018/07/31 Python
Python实现Mysql数据统计及numpy统计函数
2019/07/15 Python
Python学习笔记之字符串和字符串方法实例详解
2019/08/22 Python
redis数据库及与python交互用法简单示例
2019/11/01 Python
python日期与时间戳的各种转换示例
2020/02/12 Python
Python如何实现FTP功能
2020/05/28 Python
全面介绍python中很常用的单元测试框架unitest
2020/12/14 Python
HTML5 语义化结构化规范化
2008/10/17 HTML / CSS
SIDESTEP荷兰:在线购买鞋子
2019/11/18 全球购物
华为的Java面试题
2014/03/07 面试题
SQL SERVER面试资料
2013/03/30 面试题
顶岗实习计划书
2014/01/10 职场文书
家居饰品店创业计划书
2014/01/31 职场文书
部队万能检讨书
2014/02/20 职场文书
推广活动策划方案
2014/08/23 职场文书
高二学年自我鉴定范文(2篇)
2014/09/26 职场文书
群众路线四风问题整改措施
2014/09/27 职场文书
廉政承诺书2015
2015/04/28 职场文书
学历证明范文
2015/06/16 职场文书