日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無(wú)先后,達(dá)者為師

網(wǎng)站首頁(yè) 編程語(yǔ)言 正文

python的迭代器,生成器和裝飾器你了解嗎_python

作者:野貓炫 ? 更新時(shí)間: 2022-04-15 編程語(yǔ)言

python 迭代器與生成器,裝飾器

迭代器對(duì)象從集合的第一個(gè)元素開(kāi)始訪(fǎng)問(wèn),直到所有的元素被訪(fǎng)問(wèn)完結(jié)束。

迭代器有兩個(gè)基本的方法:iter() 和 next()。

字符串,列表或元組對(duì)象都可用于創(chuàng)建迭代器:

list1=[1,2,3]
s=iter(list1) # 創(chuàng)建迭代器對(duì)象
print(next(s)) # 輸出迭代器的下一個(gè)元素
print(next(s))
print(next(s))

在這里插入圖片描述

直到計(jì)算出最后一個(gè)元素,沒(méi)有更多的元素時(shí),拋出StopIteration的錯(cuò)誤

在這里插入圖片描述

迭代器對(duì)象可以使用常規(guī)for語(yǔ)句進(jìn)行遍歷:

list2=[1,2,3,4,5]
s2 = iter(list2)    # 創(chuàng)建迭代器對(duì)象
for h in s2:
    print (h, end="-")

在這里插入圖片描述

生成器

帶有 yield 的函數(shù)在 Python 中被稱(chēng)之為 generator(生成器)(自己制作迭代器可以看做是生成器)

#注意括號(hào)
#列表生成式
lis = [x+x for x in range(5)]
print(lis)
#生成器
gen= (x+x for x in range(5))
print(gen)
# gen = (x+x for x in range(5))
# print(next(gen))
# print(next(gen))
# print(next(gen))
# print(next(gen))
# print(next(gen))
generator_ex = (x+x for x in range(5))
for i in generator_ex:
    print(i)

在這里插入圖片描述

自己產(chǎn)生一個(gè)支持小數(shù)的range生成器(即帶yield的迭代器)

你先把yield看做“return”,這個(gè)是直觀的,它首先是個(gè)return,普通的return是什么意思,就是在程序中返回某個(gè)值,返回之后程序就不再往下運(yùn)行了。看做return之后再把它看做一個(gè)是生成器(generator)的一部分(帶yield的函數(shù)才是真正的迭代器),

def frange(star,stop,step):
    x=star
    while x<stop:
        yield x
        x+=step
for i in frange(10,20,0.5):
    print(i)

在這里插入圖片描述

下圖最直觀得可以看出yield的作用

把yield想想成return,return了一個(gè)4之后,程序停止,并沒(méi)有執(zhí)行賦值給res操作。
一個(gè)帶有 yield 的函數(shù)就是一個(gè) generator,生成一個(gè) generator 看起來(lái)像函數(shù)調(diào)用,但不會(huì)執(zhí)行任何函數(shù)代碼,直到對(duì)其調(diào)用 next()(在 for 循環(huán)中會(huì)自動(dòng)調(diào)用 next())才開(kāi)始執(zhí)行。雖然執(zhí)行流程仍按函數(shù)的流程執(zhí)行,但每執(zhí)行到一個(gè) yield 語(yǔ)句就會(huì)中斷,并返回一個(gè)迭代值,下次執(zhí)行時(shí)從 yield 的下一個(gè)語(yǔ)句繼續(xù)執(zhí)行。看起來(lái)就好像一個(gè)函數(shù)在正常執(zhí)行的過(guò)程中被 yield 中斷了數(shù)次,每次中斷都會(huì)通過(guò) yield 返回當(dāng)前的迭代值。

def foo():
    print("starting...")
    while True:
        print("yield前")
        res = yield 4
        print("yield后")
        print("res:", res)
g = foo()
print(next(g))
print("*" * 20)
print(next(g))

在這里插入圖片描述

在我們調(diào)用這個(gè)函數(shù)的時(shí)候,第一件事并不是執(zhí)行這個(gè)函數(shù),而是將這個(gè)函數(shù)做為參數(shù)傳入它頭頂上這頂帽子,這頂帽子我們稱(chēng)之為裝飾函數(shù) 或 裝飾器。
裝飾器的使用方法很固定:
先定義一個(gè)裝飾函數(shù)(帽子)(也可以用類(lèi)、偏函數(shù)實(shí)現(xiàn))
再定義你的業(yè)務(wù)函數(shù)、或者類(lèi)(人)
最后把這頂帽子帶在這個(gè)人頭上
裝飾器的簡(jiǎn)單的用法有很多,這里舉兩個(gè)常見(jiàn)的。
日志打印器
時(shí)間計(jì)時(shí)器

# 這是裝飾函數(shù)
def logger(func):
    def wrapper(*args, **kw):
        print('我準(zhǔn)備開(kāi)始計(jì)算:{} 函數(shù)了:'.format(func.__name__))
        # 真正執(zhí)行的是這行。
        func(*args, **kw)
        print('啊哈,我計(jì)算完啦。給自己加個(gè)雞腿!!')
    return wrapper
@logger
def add(x, y):
    print('{} + {} = {}'.format(x, y, x+y))
add(200, 50)

在這里插入圖片描述

# 這是裝飾函數(shù)
def timer(func):
    def wrapper(*args, **kw):
        t1=time.time()
        # 這是函數(shù)真正執(zhí)行的地方
        func(*args, **kw)
        t2=time.time()
        # 計(jì)算下時(shí)長(zhǎng)
        cost_time = t2-t1
        print("花費(fèi)時(shí)間:{}秒".format(cost_time))
    return wrapper
import time
@timer
def want_sleep(sleep_time):
    time.sleep(sleep_time)
want_sleep(10)

在這里插入圖片描述

def american():
    print("我來(lái)自中國(guó)。")
def chinese():
    print("I am from America.")
def say_hello(contry):
    def wrapper(func):
        def deco(*args, **kwargs):
            if contry == "china":
                print("你好!")
            elif contry == "america":
                print('hello.')
            else:
                return
            # 真正執(zhí)行函數(shù)的地方
            func(*args, **kwargs)
        return deco
    return wrapper
@say_hello("china")
def american():
    print("我來(lái)自中國(guó)。")
@say_hello("america")
def chinese():
    print("I am from America.")

在這里插入圖片描述

總結(jié)

原文鏈接:https://blog.csdn.net/weixin_44740756/article/details/122844911

欄目分類(lèi)
最近更新