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

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

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

瀏覽:106日期: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 編程
主站蜘蛛池模板: 欧美人与z0z0xxxx | 亚洲欧美一区二区久久香蕉 | 精品久久精品久久 | 国产在线精品一区二区夜色 | 久久精品视频播放 | 欧美一级片在线免费观看 | 欧美韩国日本在线 | 国产一区二区三区在线观看视频 | 日本乱人伦片中文字幕三区 | 日韩精品福利视频一区二区三区 | 天天看片天天爽_免费播放 天天看夜夜 | 国产免费自拍 | 日本肥老妇色xxxxx日本老妇 | 亚洲最大情网站在线观看 | 精品亚洲综合久久中文字幕 | 最新国产成人综合在线观看 | 国产成人深夜福利短视频99 | 外国成人网在线观看免费视频 | 一区二区不卡视频在线观看 | 欧美在线 | 欧美 | 国产成人教育视频在线观看 | 在线高清一级欧美精品 | 国产精品自在线天天看片 | 亚洲在线免费观看视频 | 在线a毛片免费视频观看 | 国产精品亚洲一区二区在线观看 | 精品亚洲大全 | 欧美日韩精品一区二区三区视频播放 | 欧美亚洲一区二区三区四 | va欧美| 手机在线毛片 | 日韩毛片免费在线观看 | 成人久久18免费软件 | 美女国产在线观看免费观看 | 日韩美女在线看免费观看 | 亚洲国产精品久久精品成人 | 色噜噜亚洲男人的天堂 | 日韩亚洲欧美在线 | 韩国免费a级毛片 | 看亚洲a级一级毛片 | 在线视频欧美日韩 |