国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Python3 一個類中存在大量結構接近的方法,能否用修飾器來避免大量代方法的機械性的改寫?

瀏覽:84日期:2022-06-30 10:40:29

問題描述

class Classname(object): def __init__(self, p1, p2=’’):self.p1 = p1self.p2 = p2 # @Classname.decorator def method_one(self, p_list):return function_one(p_list) def method_one(self, p_list):return function_two(p_list) def method_one(self, p_list):return function_three(p_list)

其中大量都是這樣的method_one調用funciton_one,但是現在要根據用戶是否傳入p2來改變調用function_xxx的方法,希望改成這個樣子function_xxx的代碼我無法修改.

def method_two(self, p_list):if self.p2: return function_two(self.p2, p_list)else: return function_two(p_list)

考慮過使用修飾器來處理,但是使用修飾器來處理話似乎只能在函數外面包一層,而無法侵入性的改變調用方法,請問此處有什么合適的解決方法嗎?如果以后還可能根據self.p3 self.p4來修改調用方法,有什么更好的解決方法嗎?

問題解答

回答1:

你可以使用元類魔改類,這里放出個例子

def function_one(*args): print(1, args)def function_two(*args): print(2, args)def make_method(func): # 此處填邏輯 def _method(self, plist):func(plist) return _method# 元類工廠方法,傳入包含 function_xxx 的模塊對象def meta(mod): class Meta(type):def __new__(cls, name, bases, attrs): fnames = attrs.get(’FUNCTIONS’, []) for n in fnames:func = getattr(mod, ’function_’ + n)attrs[’method_’+n] = make_method(func) return super(Meta, cls).__new__(cls, name, bases, attrs) return Metaimport sysmyself = sys.modules[__name__]class Class(metaclass=meta(myself)): FUNCTIONS = [’one’, ’two’]obj = Class()obj.method_one(’one’)obj.method_two(’two’)

標簽: Python 編程
主站蜘蛛池模板: 国产一区二区三区欧美精品 | 黄页网站18以下禁止观看 | 69xx欧美| 一级全免费视频播放 | a级毛片免费高清毛片视频 a级毛片免费高清视频 | 中文成人在线视频 | 久草在线免费看 | 国产成人国产在线观看入口 | 美国亚洲成年毛片 | 亚洲综合小视频 | 亚洲欧美精品国产一区色综合 | 国产综合久久一区二区三区 | 久草在线色站 | 欧美一级视频精品观看 | 性盈盈影院影院67194 | 亚洲精品国自产拍影院 | 国产黄色三级三级三级 | 日本久久草| 亚洲高清国产一线久久 | 国产黄a三级三级看三级 | 91久久精品国产一区二区 | 91久久国产综合精品女同我 | 美女扒开腿让男人桶 | 男女视频在线观看免费高清观看 | 日本黄色毛片 | 精产网红自拍在线 | 一区二区三区在线看 | 成人免费在线观看视频 | 白嫩美女直冒白浆 | 国产男女乱淫真视频全程播放 | 怡红院视频在线 | 台湾三级在线播放 | 99视频免费 | 99视频免费在线观看 | 日韩性色| 久久综合久久久 | 成人精品一区久久久久 | 日本久久草 | 毛片免费观看的视频在线 | 97国产在线视频 | 欧美精品成人一区二区在线观看 |