成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

如何在Python中應(yīng)用裝飾器-創(chuàng)新互聯(lián)

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)如何在Python中應(yīng)用裝飾器,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

我們提供的服務(wù)有:成都網(wǎng)站制作、做網(wǎng)站、微信公眾號(hào)開(kāi)發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、瓊中黎族ssl等。為上千家企事業(yè)單位解決了網(wǎng)站和推廣的問(wèn)題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的瓊中黎族網(wǎng)站制作公司

1. 運(yùn)行業(yè)務(wù)函數(shù)fun()同時(shí)打印運(yùn)行花費(fèi)的時(shí)間

import time
def dec(fun):
  start = time.time()
  fun()
  end = time.time()
  a = end - start
  print a
def myfun():
  print 'run myfunction'
dec(myfun)

運(yùn)行結(jié)果

(virt2) root@ubuntu:/home/z# python z.py
run myfunction
0.00108599662781

但是每次運(yùn)行myfun都要調(diào)用dec,下面作下變動(dòng)解決這個(gè)問(wèn)題

2.

import time
def dec(fun):
  def wrap():
    start = time.time()
    fun()
    end = time.time()
    a = end - start
    print a
  return wrap
def myfun():
  print 'run myfunction'
myfun=dec(myfun)
myfun()

運(yùn)行結(jié)果:

(virt2) root@ubuntu:/home/z# python z.py
run myfunction
0.00122618675232

這個(gè)裝飾器dec就實(shí)現(xiàn)了,并且不影響函數(shù)myfun功能

3. 裝飾器@符

import time
def dec(fun):
  def wrap():
    start = time.time()
    fun()
    end = time.time()
    a = end - start
    print a
  return wrap
@dec
def myfun():
  print 'run myfunction'
myfun()

結(jié)果

(virt2) root@ubuntu:/home/z# python z.py
run myfunction
0.000470876693726

使用了@后,就不用給myfun重新賦值了

@dec就相當(dāng)于myfun=dec(myfun)

例子:

def level(leveel):
  def debug(func):
    def wrapper(*args, **kwargs):
      print("[DEBUG]: enter {}()".format(func.__name__),leveel)
      return func(*args, **kwargs)
    return wrapper
  return debug
@level(leveel='debuging')
def say(something):
  print ("hello {}!".format(something))
say(123)

輸出:

('[DEBUG]: enter say()', 'debuging')
hello 123!

'''
class logging(object):
  def __init__(self, func):
    self.func = func
  def __call__(self, *args, **kwargs):
    print ("[DEBUG]: enter function {func}()".format(
      func=self.func.__name__))
    return self.func(*args, **kwargs)
@logging
def say(something):
  print ("say {}!".format(something))
'''
class logging(object):
  def __init__(self, level='INFO'):
    self.level = level
  def __call__(self, func): # 接受函數(shù)
    def wrapper(*args, **kwargs):
      print ("[{level}]: enter function {func}()".format(
        level=self.level,
        func=func.__name__))
      func(*args, **kwargs)
    return wrapper #返回函數(shù)
@logging(level='INFO')
def say(something):
  print ("say {}!".format(something))
say(123)

輸出:

[INFO]: enter function say()
say 123!

python有哪些常用庫(kù)

python常用的庫(kù):1.requesuts;2.scrapy;3.pillow;4.twisted;5.numpy;6.matplotlib;7.pygama;8.ipyhton等。

上述就是小編為大家分享的如何在Python中應(yīng)用裝飾器了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

文章名稱:如何在Python中應(yīng)用裝飾器-創(chuàng)新互聯(lián)
新聞來(lái)源:http://jinyejixie.com/article18/dieogp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、網(wǎng)站制作微信小程序、面包屑導(dǎo)航、移動(dòng)網(wǎng)站建設(shè)、標(biāo)簽優(yōu)化

廣告

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

網(wǎng)站優(yōu)化排名
东山县| 泰顺县| 河南省| 灵丘县| 镇坪县| 舞阳县| 山东省| 宁安市| 商都县| 日土县| 沾化县| 朝阳区| 双牌县| 宝坻区| 赤壁市| 师宗县| 南汇区| 衡阳市| 多伦县| 长沙县| 科技| 庐江县| 昭觉县| 阿拉善左旗| 崇阳县| 华宁县| 盈江县| 临洮县| 丰顺县| 海口市| 贡嘎县| 犍为县| 遂宁市| 龙州县| 繁昌县| 洮南市| 上虞市| 永和县| 嘉义县| 会泽县| 梅河口市|