欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python中的迭代器,生成器與裝飾器詳解

 更新時間:2022年02月18日 11:17:13   作者:FangNJ  
大家好,本篇文章主要講的是python中的迭代器,生成器與裝飾器詳解,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下

迭代器

每一個可迭代類內(nèi)部都要實現(xiàn)__iter__()方法,返回一個迭代類對象,迭代類對象則定義了這個可迭代類如何迭代。

for循環(huán)調(diào)用list本質(zhì)上是是調(diào)用了list的迭代器進(jìn)行迭代。

# 對list進(jìn)行for循環(huán)本質(zhì)上是調(diào)用了list的迭代器
list = [1,2,3,4]

# for 循環(huán)調(diào)用
for elem in list:
    print(elem)

# 迭代器調(diào)用
list_iter = list.__iter__()
while True:
   try:
    print(next(list_iter)) 
   except StopIteration:
       break

實現(xiàn)一個自己自定的迭代類,規(guī)定迭代一個可迭代的數(shù)據(jù)結(jié)構(gòu)為“倒計時”模式。

# 可迭代對象類
class CountDown(object):
    def __init__(self,num):
        self.num = num
    def __iter__(self):
        return MyIterator(self.num)

# 迭代類
class MyIterator(object):
    def __init__(self,num):
        self.NUM= num
        self.FINAL = 0
        self.now = num
        
    def __iter__(self):
        return self
    
    def __next__(self):
        step = 1 if self.NUM<self.FINAL else -1
        while self.now != self.FINAL:
            self.now += step
            return self.now - step
        raise StopIteration
        
cd_pos = CountDown(5)
cd_neg = CountDown(-5)
for i,j in zip(cd_pos,cd_neg):
    print(f'pos:{i}\tneg:{j}')

生成器

含有yield指令的函數(shù)可以稱為生成器,它可以將函數(shù)執(zhí)行對象轉(zhuǎn)化為可迭代的對象。這樣就可以像debug一樣一步一步推進(jìn)函數(shù)??梢詫崿F(xiàn)的功能是可以實現(xiàn)讓函數(shù)內(nèi)部暫停,實現(xiàn)了程序的異步功能,這樣可以及進(jìn)行該函數(shù)與外部構(gòu)件的信息交互,實現(xiàn)了系統(tǒng)的解耦。

from  collections import Iterable
def f():
    pass
# 含有yield指令的函數(shù)可以稱為生成器
def g():
    yield()
print(type(f()),isinstance(f(),Iterable))
print(type(g()),isinstance(g(),Iterable))

使用生成器可以降低系統(tǒng)的耦合性

import os
# 生成器是迭代器的一種,讓函數(shù)對象內(nèi)部進(jìn)行迭代
# 可以實現(xiàn)讓函數(shù)內(nèi)部暫停,實現(xiàn)了程序的異步功能,同時也實現(xiàn)了解耦。

def my_input():
    global str    
    str = input('input a line')
    pass

def my_write():
    with open('workfile.txt','w') as f:
        while(str):
            f.write(str+'\n')
            yield()
        return 


mw = my_write()
while(True):
    my_input()
    try:
        next(mw)
    except StopIteration:
        pass
    if not str:
        break   

裝飾器

裝飾器封裝一個函數(shù),并且用這樣或者那樣的方式來修改它的行為。

不帶參數(shù)的裝飾器

# 不帶參數(shù)的裝飾器
from functools import wraps
# 裝飾器封裝一個函數(shù),并且用這樣或者那樣的方式來修改它的行為。
def mydecorator(a_func):
    @wraps(a_func)  #聲明這個注解就可以不重寫傳入的函數(shù),只是調(diào)用的時候wrap一下。不加的話,a_func函數(shù)可以看作被重寫為wrapTheFunction.
    def wrapTheFunction():
        print(f"function in {id(a_func)} starts...")
        a_func()
        print(f"function in {id(a_func)} ends...")
    return wrapTheFunction

# 在函數(shù)定義前加入此注解就可以將函數(shù)傳入裝飾器并包裝
@mydecorator
def f():
    print('hi')
    pass

f()
print(f.__name__)

帶參數(shù)的裝飾器(實現(xiàn)輸出到自定義的日志文件)

# 帶參數(shù)的裝飾器(實現(xiàn)輸出到自定義的日志文件)
from functools import wraps

def logit(logfile='out.log'):
    def mydecorator2(a_func):
        @wraps(a_func)
        def wrapTheFunction(*args, **kwargs):   # 這個保證了函數(shù)可以含有任意形參
            log_string = a_func.__name__ + " was called"
            print(log_string)
            # 打開logfile,并寫入內(nèi)容
            with open(logfile, 'a') as opened_file:
                # 現(xiàn)在將日志打到指定的logfile
                opened_file.write(log_string + '\n')
                return a_func(*args, **kwargs)
        return wrapTheFunction
    return mydecorator2

# func group1 
@ logit('out1.log')
def func1(str):
    print(str)
    pass
@ logit('out2.log')
def func2(): pass
            
func1('I have a foul smell')
func2()        

實現(xiàn)一個裝飾器類(這樣寫可以簡化裝飾器函數(shù),并且提高封裝性)

# 帶參數(shù)的裝飾器(實現(xiàn)輸出到自定義的日志文件)
from functools import wraps

def logit(logfile='out.log'):
    def mydecorator2(a_func):
        @wraps(a_func)
        def wrapTheFunction(*args, **kwargs):   # 這個保證了函數(shù)可以含有任意形參
            log_string = a_func.__name__ + " was called"
            print(log_string)
            # 打開logfile,并寫入內(nèi)容
            with open(logfile, 'a') as opened_file:
                # 現(xiàn)在將日志打到指定的logfile
                opened_file.write(log_string + '\n')
                return a_func(*args, **kwargs)
        return wrapTheFunction
    return mydecorator2

# func group1 
@ logit('out1.log')
def func1(str):
    print(str)
    pass
@ logit('out2.log')
def func2(): pass
            
func1('I have a foul smell')
func2()        
    

總結(jié)

到此這篇關(guān)于python中的迭代器,生成器與裝飾器詳解的文章就介紹到這了,更多相關(guān)python迭代器,生成器與裝飾器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python?編程操作連載之字符串,列表,字典和集合處理

    Python?編程操作連載之字符串,列表,字典和集合處理

    這篇文章主要介紹了Python?編程操作連載之字符串,列表,字典和集合處理,文章圍繞主題相關(guān)資料展開詳細(xì)的內(nèi)容介紹,需要的朋友可參考一下下面文章內(nèi)容
    2022-06-06
  • django 數(shù)據(jù)庫 get_or_create函數(shù)返回值是tuple的問題

    django 數(shù)據(jù)庫 get_or_create函數(shù)返回值是tuple的問題

    這篇文章主要介紹了django 數(shù)據(jù)庫 get_or_create函數(shù)返回值是tuple的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • 詳解Python中is和==的區(qū)別

    詳解Python中is和==的區(qū)別

    這篇文章主要介紹了Python中is和==的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • 從運(yùn)行效率與開發(fā)效率比較Python和C++

    從運(yùn)行效率與開發(fā)效率比較Python和C++

    今天小編就為大家分享一篇關(guān)于從運(yùn)行效率與開發(fā)效率比較Python和C++,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • 基于python全局設(shè)置id 自動化測試元素定位過程解析

    基于python全局設(shè)置id 自動化測試元素定位過程解析

    這篇文章主要介紹了基于python全局設(shè)置id 自動化測試元素定位過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-09-09
  • 淺談django 重載str 方法

    淺談django 重載str 方法

    這篇文章主要介紹了淺談django 重載str 方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • PyQT中QTableWidget如何根據(jù)單元格內(nèi)容設(shè)置自動寬度

    PyQT中QTableWidget如何根據(jù)單元格內(nèi)容設(shè)置自動寬度

    這篇文章主要介紹了PyQT中QTableWidget如何根據(jù)單元格內(nèi)容設(shè)置自動寬度問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • 如何徹底解決python?NameError:name?'__file__'?is?not?defined

    如何徹底解決python?NameError:name?'__file__'?is?not?

    這篇文章主要給大家介紹了關(guān)于如何徹底解決python?NameError:name?'__file__'?is?not?defined的相關(guān)資料,文中通過圖文將解決的辦法介紹的非常詳細(xì),需要的朋友可以參考下
    2023-02-02
  • python字符串拼接.join()和拆分.split()詳解

    python字符串拼接.join()和拆分.split()詳解

    這篇文章主要為大家介紹了python字符串拼接.join()和拆分.split(),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • Python裝飾器的兩種使用心得

    Python裝飾器的兩種使用心得

    裝飾器(Decorators)是 Python 的一個重要部分。簡單地說:他們是修改其他函數(shù)的功能的函數(shù)。他們有助于讓我們的代碼更簡短,也更Pythonic(Python范兒),今天通過本文給大家分享Python裝飾器使用小結(jié),感興趣的朋友一起看看吧
    2021-09-09

最新評論