python中可變參數與裝飾器的例子

python的可變參數

方法定義

#*args是可以傳list類型的可變參數,**kwargs是可以傳dict的可變參數
def wrapper(*args, **kwargs):

使用示例

def foo(*args, **kwargs):
    print 'args = ', args
    print 'kwargs = ', kwargs
    print '---------------------------------------'

if __name__ == '__main__':
    foo(1,2,3,4)
    foo(a=1,b=2,c=3)
    foo(1,2,3,4, a=1,b=2,c=3)
    foo('a', 1, None, a=1, b='2', c=3)

輸出結果:

輸出結果如下:
args =  (1, 2, 3, 4)
kwargs =  {}
---------------------------------------
args =  ()
kwargs =  {'a': 1, 'c': 3, 'b': 2}
---------------------------------------
args =  (1, 2, 3, 4)
kwargs =  {'a': 1, 'c': 3, 'b': 2}
---------------------------------------
args =  ('a', 1, None)
kwargs =  {'a': 1, 'c': 3, 'b': '2'}

例子來源《Python tips: 什麼是*args和**kwargs? - MK2 - 博客園 (cnblogs.com)


裝飾器例子

搭配裝飾器使用,用來判斷是否爲空

#定義一個函數,並進行wrapper一層,用來當作裝飾器
def leftTopUICheck(func):
	def wrapper(*args, **kwargs):
		if hasattr(xxglobal.rds, 'MainPartLeftTopUI'):
			return func(*args, **kwargs)
		else:
			return
	return wrapper

@leftTopUICheck
def setLeftTopPictureFrameRes(filename):
	xxglobal.rds.MainPartLeftTopUI.setPictureFrameRes(filename)

定義

@符號是一個語法糖,當執行函數時,會把當前函數傳入到@指向的函數中執行。


裝飾器用途

結合項目代碼來看,目前我們大多是用在前置檢查,且會把裝飾器函數定義在sys.path內的文件中,避免每次使用都要import。如果裝飾器的函數實現在同一個文件中則不需要import。


裝飾器與C#

在C#中有Attribute,寫法上和裝飾器一樣都是在方法名的上行加上,它也可以達到裝飾器的一些功能。

//MenuItem 定義:
public MenuItem(string itemName, bool isValidateFunction)
    
//用法
[MenuItem("Assets/開啓XXX", false)]
public static void openXXFunc()
{

}

但是如果要實現裝飾器完整的前置檢查,在C#中我一般是傳入一個(Action callback)來處理。

void Check(Action callback){
    if (not 前置檢查) return;
    callback.Invoke();
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章