溫馨提示×

溫馨提示×

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

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

Python中的裝飾器 Decorators的使用方法

發(fā)布時間:2021-10-09 17:42:59 來源:億速云 閱讀:163 作者:柒染 欄目:大數(shù)據(jù)

本篇文章給大家分享的是有關(guān)Python中的裝飾器 Decorators的使用方法,小編覺得挺實用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

python的五大特點是什么

python的五大特點:

1.簡單易學(xué),開發(fā)程序時,專注的是解決問題,而不是搞明白語言本身。

2.面向?qū)ο?,與其他主要的語言如C++和Java相比, Python以一種非常強大又簡單的方式實現(xiàn)面向?qū)ο缶幊獭?/p>

3.可移植性,Python程序無需修改就可以在各種平臺上運行。

4.解釋性,Python語言寫的程序不需要編譯成二進制代碼,可以直接從源代碼運行程序。

5.開源,Python是 FLOSS(自由/開放源碼軟件)之一。


def my_logging(func):
   def wrapper():
       print('logging - {} is running'.format(func.__name__))
       func()  # run func()  Equivalent run f1()

   return wrapper


def bold(func):
   def wrapper():
       print("<b>")
       func()
       print("</b>")

   return wrapper


def italic(func):
   def wrapper():
       print("<i>")
       func()
       print("</i>")

   return wrapper


@my_logging
@bold
@italic
def f1():
   print("f1")


f1()

其實上面這段 code 也相當(dāng)這樣的

def my_logging(func):
   def wrapper():
       print('logging - {} is running'.format(func.__name__))
       func()  # run func()  Equivalent run f1()

   return wrapper


def bold(func):
   def wrapper():
       print("<b>")
       func()
       print("</b>")

   return wrapper


def italic(func):
   def wrapper():
       print("<i>")
       func()
       print("</i>")

   return wrapper


def f1():
   print("f1")


f1 = my_logging(bold(italic(f1)))
f1()

這邊只需要稍微注意一下執(zhí)行的順序????,剛剛的 f1() 是沒有帶入?yún)?shù)的,今天假如我希望帶入?yún)?shù)呢?

def my_logging(func):
   def wrapper(*args, **kwargs):
       print('logging - {} is running'.format(func.__name__))
       func(*args, **kwargs)

   return wrapper


@my_logging
def f1(*args, **kwargs):
   print("f1")

   for thing in args:
       print('hello {}'.format(thing))

   for name, value in kwargs.items():
       print('{0} = {1}'.format(name, value))


f1('twtrubiks', apple='fruit', cabbage='vegetable')

使用 *args **kwargs 這樣寫的話,不管 f1() 帶入什麼參數(shù)都不用擔(dān)心????。裝飾器還有更大的彈性,像是今天如果我希望將裝飾器帶入?yún)?shù)。

def my_logging(level):
   def decorator(func):
       def wrapper(*args, **kwargs):
           if level == "1":
               print('level {} logging - {} is running'.format(level, func.__name__))
           elif level == "2":
               print('level {} logging - {} is running'.format(level, func.__name__))

           func(*args, **kwargs)

       return wrapper

   return decorator


@my_logging(level="1")
def f1(*args, **kwargs):
   print("f1")

   for thing in args:
       print('hello {}'.format(thing))

   for name, value in kwargs.items():
       print('{0} = {1}'.format(name, value))


f1('twtrubiks', apple='fruit', cabbage='vegetable')

這邊簡單說明,就是為了要將裝飾器帶入?yún)?shù),我們必須再包一層。

以上就是Python中的裝飾器 Decorators的使用方法,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注億速云行業(yè)資訊頻道。


向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI