91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何正確使用裝飾器

發布時間:2021-10-19 15:17:53 來源:億速云 閱讀:91 作者:iii 欄目:web開發

本篇內容主要講解“如何正確使用裝飾器”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“如何正確使用裝飾器”吧!

如何正確使用裝飾器

一、裝飾器的簡單定義

外層函數返回里層函數的引用,里層函數引用外層函數的變量。

二、裝飾器的作用

通俗來講裝飾器的作用就是在不改變已有函數代碼前提下,為該函數增加新的功能。

def run():    print('我會跑') fun()

現在我想在原有函數的基礎上新增一個功能:我會唱歌。這個時候利用裝飾器則輕松可以幫我們實現這個功能。

三、實例理解

(1)不傳參的裝飾器

def outer(fun):    def inner():       fun()  //fun是外層函數的變量,在inner里面用    return inner //inner就是里層函數的引用

(2)傳遞參數的裝飾器:

def func(fun):    def add(*args,**kwarge):       return fun(*args,**kwargs)    return add

現在對于裝飾器的基本格式有一定的了解,就可以直接寫函數了。下面實現文章開頭的 我會唱歌 的功能

def outer(fun):     def inner(*args, **kwarge):         print("我會唱歌")         return fun(*args, **kwarge)     return inner

四、如何使用裝飾器

方法一:使用@符號+裝飾器的名字   把它放在想要裝飾函數的上一行即可 @outer def run():    print('我會跑')     run()   方法二: def run():     print('我會跑')  run=outer(run)   #就等價于@outer run()  最終打印結果是: 我會唱歌 我會跑

如果我想知道fun 傳遞的參數是什么,在裝飾器內部可以使用如下方式:

def outer(fun):     a = 1     def inner(*args, **kwarge): # args是一個數組,kwargs一個字典         print(fun.__name__) #打印fun接收的函數的名字         print("我會唱歌")         return fun(*args, **kwarge)     return inner

但是如果我們 print(run.__name__,6666666)  輸出的結果是inner,并不是我們想要的run,這里的函數被warpTheFunction替代了。它重寫了我們函數的名字和注釋文檔(docstring)。解決方法如下:

from functools import wraps  def outer(fun):     @wraps(fun)     def inner(*args, **kwargs):         print(fun.__name__,11111111111)         print("我會唱歌")         return fun(*args, **kwargs)     return inner  @outer def run():    print('我會跑')      print(run.__name__,6666666)  //輸出結果為 run 666666

五、自己實現裝飾器

  1. def subuser_keymanage(view_func): 

  2.     '''功能是實現用戶管理權限的判定''' 

  3.     def _wrapper_view(request, *args, **kwargs): 

  4.         user = request.user #一個Customer對象,包含了用戶名/密碼等信息 

  5.         customer = user.customer.customer_id #用戶的id 

  6.         select_status = get_curuser_permission(user=user, customer=customer)#調用函數返回的值有兩種0和1 

  7.         if not select_status:#如果返回0表示沒有權限,返回錯誤碼 

  8.             return render_response(request, ErrorCode.FAILED) 

  9.         return view_func(request, *args, **kwargs) 

  10.     return _wrapper_view 


@subuser_keymanage  def generate_subuser_ak_sk(request):     params = json.loads(request.body) #獲取卡前端傳遞的參數     user_id_only = params.get("user_id") #獲取用戶表示id值     中間代碼就忽略了......     return render_response(request, ErrorCode.FAILED)

六、裝飾器小結

通過裝飾器很大程度上可以減少代碼的復用,在代碼規范中這一點是很重要的。

以上就是裝飾器的基本知識,即便沒有任何基礎,按照作者的思路,套用固定的格式,不需要完全理解,只要按照流程一步一步就能寫出高端大氣上檔次的裝飾器了,恭喜你!

前方高能請注意:裝飾器傳參,三層嵌套函數一般用的比較少,其實也不難,一層一層看,跟上文講的一樣,僅作為知識的拓寬。

  1. import logging 

  2. def use_logging(level): 

  3.     def decorator(func): 

  4.         def wrapper(*args, **kwargs): 

  5.             if level == "warn": 

  6.                 logging.warn("%s is running" % func.__name__) 

  7.             elif level == "info": 

  8.                 logging.info("%s is running" % func.__name__) 

  9.             return func(*args) 

  10.         return wrapper 

  11.  

  12.     return decorator 

  13.  

  14. @use_logging(level="warn") 

  15. def foo(name='foo'): 

  16.     print("i am %s" % name) 

  17.  

  18. foo() 


i am foo WARNING:root:foo is running

到此,相信大家對“如何正確使用裝飾器”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

来安县| 北京市| 永川市| 平顺县| 阿勒泰市| 德安县| 拜城县| 梁河县| 黄冈市| 邢台县| 巫山县| 潞城市| 石狮市| 武宁县| 来凤县| 犍为县| 舟曲县| 民勤县| 定州市| 讷河市| 金山区| 睢宁县| 大城县| 延庆县| 尖扎县| 全州县| 邵武市| 辽宁省| 晋城| 平果县| 阿瓦提县| 汝南县| 盐津县| 霍邱县| 元谋县| 定襄县| 内黄县| 扎赉特旗| 岗巴县| 金寨县| 砚山县|