網(wǎng)站首頁 編程語言 正文
迭代器
每一個可迭代類內(nèi)部都要實(shí)現(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
實(shí)現(xiàn)一個自己自定的迭代類,規(guī)定迭代一個可迭代的數(shù)據(jù)結(jié)構(gòu)為“倒計(jì)時”模式。
# 可迭代對象類 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ù)??梢詫?shí)現(xiàn)的功能是可以實(shí)現(xiàn)讓函數(shù)內(nèi)部暫停,實(shí)現(xiàn)了程序的異步功能,這樣可以及進(jìn)行該函數(shù)與外部構(gòu)件的信息交互,實(shí)現(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)行迭代 # 可以實(shí)現(xiàn)讓函數(shù)內(nèi)部暫停,實(shí)現(xiàn)了程序的異步功能,同時也實(shí)現(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ù)的裝飾器(實(shí)現(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()
實(shí)現(xiàn)一個裝飾器類(這樣寫可以簡化裝飾器函數(shù),并且提高封裝性)
# 帶參數(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é)
原文鏈接:https://blog.csdn.net/FangNJ/article/details/122986008
相關(guān)推薦
- 2022-05-12 python2中input()漏洞
- 2022-09-26 SharedPreferences存儲HashMap和相互轉(zhuǎn)化
- 2023-04-09 使用Pytest.main()運(yùn)行時參數(shù)不生效問題解決_python
- 2022-07-09 Python如何通過變量ID得到變量的值_python
- 2022-08-29 C#中Attribute特性的用法_C#教程
- 2022-09-06 C#任務(wù)并行Parellel.For和Parallel.ForEach_C#教程
- 2022-10-05 Numpy中Meshgrid函數(shù)基本用法及2種應(yīng)用場景_python
- 2022-05-26 簡單聊一聊SQL注入及防止SQL注入_數(shù)據(jù)庫其它
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支