Python 實(shí)現(xiàn)子類獲取父類的類成員方法
大家好,今天在寫代碼的時(shí)候,遇到了這樣一種情況。我有如下所示的幾個(gè)類用來存放程序配置(其實(shí)當(dāng)做命名空間來用,同時(shí)感覺能夠繼承方便一點(diǎn)),
import os class Config: BASE_DIR = "/tmp" class TestConfig(Config): DATA_DIR = os.path.join(Config.BASE_DIR, "data")
然后我在子類中想要訪問父類的類成員變量,而且這兩個(gè)類都是只有類成員變量。感覺目前我使用的方法笨一點(diǎn),就是直接引用父類的名字,感覺這樣的方法不靈活,我想找一種方法,可以讓子類訪問到父類。
我在網(wǎng)上搜索了一下,找了這么兩種方法,但是感覺都不怎么符合我的需求:
1. 在子類方法中調(diào)用super(TestConfig, self)來獲取父類(我的類只有類成員變量,沒有self)
2. 通過子類的名字SubConfig.__bases__來獲取父類(我是在SubConfing這個(gè)子類內(nèi)部執(zhí)行相關(guān)語句的,會(huì)拋出SubConfig還未定義的NameError)
然后就沒有找到其他的辦法了,所以想來和大家請教一下,像我這種想法,有辦法可以實(shí)現(xiàn)嗎?應(yīng)該怎么做啊?這個(gè)問題問的可能比較傻,還請大家不要見怪。
@Python Yiyi
利用Python3 metaclass 實(shí)現(xiàn)
>>> 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 語言參考中描述:
當(dāng)執(zhí)行類定義時(shí),將執(zhí)行以下步驟:
確定正確的元類
準(zhǔn)備類的命名空間
執(zhí)行類的主體
創(chuàng)建類對象
3.3.3.1. 確定正確的元類
3.3.3.2. 準(zhǔn)備類的命名空間
確定正確的元類后,則開始準(zhǔn)備類的命名空間。如果元類具有__prepare__屬性,那么它以namespace = metaclass.__prepare__(name, bases, **kwds)形式調(diào)用(其中如果有額外的關(guān)鍵字參數(shù),那么它們來自類的定義)。
如果元類沒有__prepare__屬性,那么類的命名空間初始化一個(gè)空的dict()實(shí)例。
3.3.3.3. 執(zhí)行類的主體
類的主體(大體上)以exec(body, globals(), namespace)的方式執(zhí)行。(從這里可以看出,BASE_DIR找不到的原因是globals() 和namespace 中沒有BASE_DIR定義。解決辦法是將基類的成員拷貝到namespace中)
3.3.3.4. 創(chuàng)建類對象
類的命名空間通過執(zhí)行類的主體創(chuàng)建完之后,通過調(diào)用metaclass(name, bases, namespace, **kwds)創(chuàng)建類對象(這里傳遞過來的額外的關(guān)鍵字參數(shù)與傳遞給__prepare__的相同)。
以上這篇Python 實(shí)現(xiàn)子類獲取父類的類成員方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python實(shí)現(xiàn)數(shù)據(jù)庫編程方法詳解
這篇文章主要介紹了Python實(shí)現(xiàn)數(shù)據(jù)庫編程方法,較為詳細(xì)的總結(jié)了Python數(shù)據(jù)庫編程涉及的各種常用技巧與相關(guān)組件,需要的朋友可以參考下2015-06-06
PyAutoGUI圖形用戶界面自動(dòng)化的超詳細(xì)教程
PyautoGUI是一個(gè)純Python的自動(dòng)化工具,能實(shí)現(xiàn)用程序自動(dòng)控制鼠標(biāo)和鍵盤操作,下面這篇文章主要給大家介紹了關(guān)于PyAutoGUI圖形用戶界面自動(dòng)化的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04
深入理解Python虛擬機(jī)中元組(tuple)的實(shí)現(xiàn)原理及源碼
在本篇文章當(dāng)中主要給大家介紹?cpython?虛擬機(jī)當(dāng)中針對列表的實(shí)現(xiàn),在?Python?中,tuple?是一種非常常用的數(shù)據(jù)類型,在本篇文章當(dāng)中將深入去分析這一點(diǎn)是如何實(shí)現(xiàn)的2023-03-03

