Python 實現(xiàn)子類獲取父類的類成員方法
大家好,今天在寫代碼的時候,遇到了這樣一種情況。我有如下所示的幾個類用來存放程序配置(其實當(dāng)做命名空間來用,同時感覺能夠繼承方便一點),
import os class Config: BASE_DIR = "/tmp" class TestConfig(Config): DATA_DIR = os.path.join(Config.BASE_DIR, "data")
然后我在子類中想要訪問父類的類成員變量,而且這兩個類都是只有類成員變量。感覺目前我使用的方法笨一點,就是直接引用父類的名字,感覺這樣的方法不靈活,我想找一種方法,可以讓子類訪問到父類。
我在網(wǎng)上搜索了一下,找了這么兩種方法,但是感覺都不怎么符合我的需求:
1. 在子類方法中調(diào)用super(TestConfig, self)來獲取父類(我的類只有類成員變量,沒有self)
2. 通過子類的名字SubConfig.__bases__來獲取父類(我是在SubConfing這個子類內(nèi)部執(zhí)行相關(guān)語句的,會拋出SubConfig還未定義的NameError)
然后就沒有找到其他的辦法了,所以想來和大家請教一下,像我這種想法,有辦法可以實現(xiàn)嗎?應(yīng)該怎么做???這個問題問的可能比較傻,還請大家不要見怪。
@Python Yiyi
利用Python3 metaclass 實現(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í)行類定義時,將執(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__屬性,那么類的命名空間初始化一個空的dict()實例。
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 實現(xiàn)子類獲取父類的類成員方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python實現(xiàn)數(shù)據(jù)庫編程方法詳解
這篇文章主要介紹了Python實現(xiàn)數(shù)據(jù)庫編程方法,較為詳細的總結(jié)了Python數(shù)據(jù)庫編程涉及的各種常用技巧與相關(guān)組件,需要的朋友可以參考下2015-06-06深入理解Python虛擬機中元組(tuple)的實現(xiàn)原理及源碼
在本篇文章當(dāng)中主要給大家介紹?cpython?虛擬機當(dāng)中針對列表的實現(xiàn),在?Python?中,tuple?是一種非常常用的數(shù)據(jù)類型,在本篇文章當(dāng)中將深入去分析這一點是如何實現(xiàn)的2023-03-03