python中裝飾器有哪些作用

這篇文章主要為大家展示了“python中裝飾器有哪些作用”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“python中裝飾器有哪些作用”這篇文章吧。

創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供漳州網(wǎng)站建設(shè)、漳州做網(wǎng)站、漳州網(wǎng)站設(shè)計、漳州網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、漳州企業(yè)網(wǎng)站模板建站服務(wù),十多年漳州做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。

python裝飾器

python裝飾器就是用于拓展原來函數(shù)功能的一種函數(shù),這個函數(shù)的特殊之處在于它的返回值也是一個函數(shù),使用python裝飾器的好處就是在不用更改原函數(shù)的代碼前提下給函數(shù)增加新的功能。

一般而言,我們要想拓展原來函數(shù)代碼,最直接的辦法就是侵入代碼里面修改,但是最簡單的方式并不是最安全最合適的方式,根據(jù)擴展開放修改封閉的原則,修改原函數(shù)代碼是不可取的.比如下面的有一個案例:

A公司有一個核心接口部門M提供核心業(yè)務(wù)接口,有三個業(yè)務(wù)部門(N,W,Z)需要調(diào)用核心業(yè)務(wù)接口,在正常運行了一年后,公司規(guī)范接口調(diào)用需要驗證用戶權(quán)限進行接口調(diào)用,現(xiàn)在需要實現(xiàn)這個擴展功能如何在花費最小成本完成?

樣例代碼如下:

############### 核心接口部門 ###############

def f1():
    print('f1')

def f2():
    print('f2')

def f3():
    print('f3')

def f4():
    print('f4')

############### 業(yè)務(wù)部門N 調(diào)用核心接口提供的功能 ###############

f1()
f2()
f3()
f4()

############### 業(yè)務(wù)部門W 調(diào)用核心接口提供的功能 ###############

f1()
f2()
f3()
f4()

############### 業(yè)務(wù)部門Z 調(diào)用核心接口提供的功能 ###############

f1()
f2()
f3()
f4()

.核心接口部門重構(gòu)原函數(shù),添加驗證代碼

############### 核心接口部門 ###############
def verify():
    print('驗證代碼')

def f1():
   verify()
    print('f1')

def f2():
    verify()
    print('f2')

def f3():
    verify()
    print('f3')

def f4():
   verify()
    print('f4')

分析:違反了開放封閉原則!對擴展是開放的,對修改封閉。對于核心的功能寫好之后是不應(yīng)許進入到功能里面去修改的。如果有1000個接口,你就得改一千次,雖然對于調(diào)用者無感,但核心接口部門成本很高。

核心接口部門擴展驗證接口,業(yè)務(wù)部門調(diào)用時驗證

############### 核心接口部門 ###############
def verify():
    print('驗證代碼')

def f1():
    print('f1')

def f2():
    print('f2')

def f3():
    print('f3')

def f4():
    print('f4')

############### 業(yè)務(wù)部門N 調(diào)用核心接口提供的功能 ###############
if(verify()){
f1()
f2()
f3()
f4()
} else {
    print('未通過驗證')
}

############### 業(yè)務(wù)部門W 調(diào)用核心接口提供的功能 ###############
if(verify()){
f1()
f2()
f3()
f4()
} else {
    print('未通過驗證')
}

############### 業(yè)務(wù)部門Z 調(diào)用核心接口提供的功能 ###############
if(verify()){
f1()
f2()
f3()
f4()
} else {
    print('未通過驗證')
}

分析:
上述代碼滿足開放封閉原則。核心接口部門也是只要擴展一個驗證功能即可,但業(yè)務(wù)調(diào)用部門需要進行驗證功能調(diào)用,這不利于調(diào)用者使用。

核心接口裝飾器進行驗證,業(yè)務(wù)部門無感

############### 核心接口部門 ###############

def verify(func):
    def inner():
        # 驗證1
        # 驗證2
        # 驗證3
        return func()
    return inner

@verify
def f1():
    print('f1')
@verify
def f2():
    print('f2')
@verify
def f3():
    print('f3')
@verify
def f4():
    print('f4')

分析:

上述裝飾器解決驗證問題,只要核心接口部門進行操作,并且滿足開放封閉原則。下面以f1為例,
執(zhí)行verify函數(shù),并將 @verify 下面的 函數(shù) 作為verify函數(shù)的參數(shù),即:@verify 等價于verify(f1)
所以,內(nèi)部就會去執(zhí)行:
def inner:
    #驗證
    return f1()   # func是參數(shù),此時 func 等于 f1
return inner     # 返回的 inner,inner代表的是函數(shù),非執(zhí)行函數(shù)
    其實就是將原來的 f1 函數(shù)塞進另外一個函數(shù)中
    將執(zhí)行完的 verify 函數(shù)返回值賦值給@verify下面的函數(shù)的函數(shù)名
    verify函數(shù)的返回值是:
    def inner:
    #驗證
    return 原來f1()  # 此處的 f1 表示原來的f1函數(shù)
            然后,將此返回值再重新賦值給 f1,即:
            新f1 = def inner:
                        #驗證
                        return 原來f1() 
    所以,以后業(yè)務(wù)部門想要執(zhí)行 f1 函數(shù)時,就會執(zhí)行 新f1 函數(shù),
    在 新f1 函數(shù)內(nèi)部先執(zhí)行驗證,再執(zhí)行原來的f1函數(shù),然后將 原來f1 函數(shù)的返回值 返回給了業(yè)務(wù)調(diào)用者。
    如此一來, 即執(zhí)行了驗證的功能,又執(zhí)行了原來f1函數(shù)的內(nèi)容,并將原f1函數(shù)返回值 返回給業(yè)務(wù)調(diào)用著。

擴展

上面我們寫的是沒有帶參數(shù)的,我們?nèi)绾螌憥?shù)的呢?

帶一個參數(shù)

def verify(func):
    def inner(arg1):
        # 驗證1
        # 驗證2
        # 驗證3
        return func(arg1)
    return inner
@verify
def f1(arg1):
    print('f1')

備注:如果你要指定參數(shù)個數(shù),就添加指定個數(shù)參數(shù)到里面即可。如下:

帶兩個參數(shù)

def verify(func):
    def inner(arg1,arg2):
        # 驗證1
        # 驗證2
        # 驗證3
        return func(arg1,arg2)
    return inner

@verify
def f1(arg1,arg2):
    print('f1')

帶N個參數(shù)

def verify(func):
    def inner(*args,**kwargs):
        # 驗證1
        # 驗證2
        # 驗證3
        return func(*args,**kwargs)
    return inner

@verify
def f1(arg1,arg2,arg3,arg4,arg5):
    print('f1')

一個函數(shù)可以有多個裝飾器

def w1(func):
    def inner(*args,**kwargs):
        # 驗證1
        # 驗證2
        # 驗證3
        return func(*args,**kwargs)
    return inner

def w2(func):
    def inner(*args,**kwargs):
        # 驗證1
        # 驗證2
        # 驗證3
        return func(*args,**kwargs)
    return inner

@w1
@w2
def f1(arg1,arg2,arg3):
    print 'f1'

以上是“python中裝飾器有哪些作用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

本文題目:python中裝飾器有哪些作用
URL鏈接:http://muchs.cn/article2/jchsoc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動網(wǎng)站建設(shè)、響應(yīng)式網(wǎng)站服務(wù)器托管、用戶體驗App開發(fā)、品牌網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)