網(wǎng)站首頁 編程語言 正文
1.生成器
# 一邊循環(huán)一邊計算的機制,稱為生成器:generator; # 創(chuàng)建generator方法: # 1.把一個列表生成式的[]改成() numsList = [num * num for num in range(10)] print("列表生成式生成numsList:",numsList) numsGenerator = (num * num for num in range(10)) print("生成器生成numsGenerator:",numsGenerator) # 使用next()函數(shù)獲得generator的下一個返回值 print("打印numsGenerator第一個元素:",next(numsGenerator)) print("打印numsGenerator第二個元素:",next(numsGenerator)) print("--------------------------------------------------------") # 使用for循環(huán)打印generator元素 print("使用循環(huán)打印生成器中的元素!") for num in numsGenerator: print(num,end = " ") print("\n") print("--------------------------------------------------------") # 斐波拉契數(shù)列(Fibonacci):除第一個和第二個數(shù)外,任意一個數(shù)均可由前兩個數(shù)相加得到 # 1,1,2,3,5,8,13,21,34 def fibonacci(num): n, a, b = 0, 0, 1 while n < num: print(b,end = " ") a, b = b, a + b n = n + 1 return "Done" print("Fibonacci前10項為:") fibonacci(10) print("\n") print("--------------------------------------------------------") # 2.把fibonacci()函數(shù)變成generator函數(shù) def fibonacci(num): n, a, b = 0, 0, 1 while n < num: yield b a, b = b, a + b n = n + 1 return "Done" # Tips: # 1.如果一個函數(shù)定義中包含yield關(guān)鍵字,則這個函數(shù)是一個generator函數(shù); # 2.調(diào)用一個generator函數(shù)將返回一個generator; fib = fibonacci(10) print("fib的值:",fib)
# 結(jié)果輸出:
列表生成式生成numsList: [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
生成器生成numsGenerator: <generator object <genexpr> at 0x0000028F0E6ACB88>
打印numsGenerator第一個元素: 0
打印numsGenerator第二個元素: 1
--------------------------------------------------------
使用循環(huán)打印生成器中的元素!
4 9 16 25 36 49 64 81?--------------------------------------------------------
Fibonacci前10項為:
1 ?1 ?2 ?3 ?5 ?8 ?13 ?21 ?34 ?55 ?--------------------------------------------------------
fib的值: <generator object fibonacci at 0x0000028F0E7839A8>
?
# 普通函數(shù)和generator函數(shù)的執(zhí)行流程: # 1.普通函數(shù):順序執(zhí)行,遇到return語句或最后一行函數(shù)語句就返回; # 2.generator函數(shù):在每次調(diào)用next()的時候執(zhí)行,遇到y(tǒng)ield語句返回; # 3.再次執(zhí)行時從上次返回的yield語句處繼續(xù)執(zhí)行; # 實例:定義一個generator函數(shù),依次返回"Willard",18,"Engineer" def willardInfo(): print("STEP1") yield "Willard" print("--------") print("STEP2") yield 18 print("--------") print("STEP3") yield "Engineer" # 調(diào)用willardInfo()這個generator函數(shù),先生成一個generator對象 # 然后用next()函數(shù)不斷獲得下一個返回值,即可用循環(huán)直接打印 willardInfoObject = willardInfo() for willard in willardInfoObject: print(willard)
# 結(jié)果輸出:
STEP1
Willard
--------
STEP2
18
--------
STEP3
Engineer
?
2.迭代器
# 可直接用于for循環(huán)的數(shù)據(jù)類型: # 1.list、tuple、dict、set、str等; # 2.generator,包括:生成器和帶yield的generator function; # 3.可以直接作用于for循環(huán)的對象稱為可迭代對象:Iterable; # 4.使用isinstance()判斷一個對象是否為Iterable對象; from collections.abc import Iterable print("判斷l(xiāng)ist是否為可迭代對象!",isinstance([],Iterable)) print("判斷dict是否為可迭代對象!",isinstance({},Iterable)) print("判斷str是否為可迭代對象!",isinstance("Willard",Iterable)) print("判斷生成式是否為可迭代對象!",isinstance((num for num in range(10)),Iterable)) print("判斷number是否為可迭代對象!",isinstance(99,Iterable))
# 結(jié)果輸出:
判斷l(xiāng)ist是否為可迭代對象! True
判斷dict是否為可迭代對象! True
判斷str是否為可迭代對象! True
判斷生成式是否為可迭代對象! True
判斷number是否為可迭代對象! False
?
# 可以被next()函數(shù)調(diào)用并不斷返回下一個值的對象稱為迭代器:Iterator # 使用isinstance()判斷一個對象是否為Iterator對象; from collections.abc import Iterator print("判斷生成器是否為迭代器!",isinstance((num for num in range(10)),Iterator)) print("判斷l(xiāng)ist是否為迭代器!",isinstance([],Iterator)) print("判斷dict是否為迭代器!",isinstance({},Iterator)) print("判斷str是否為迭代器!",isinstance("Willard",Iterator)) print("----------------------------------------------------------") # Tips: # 1.生成器都是Iterator對象,但list、dict、str是Iterable但不是Iterator; # 2.Iterator對象表示數(shù)據(jù)流,Iterator對象可以被next()函數(shù)調(diào)用并不斷返回下一個數(shù)據(jù), # 直到?jīng)]有數(shù)據(jù)時拋出StopIteration錯誤;這個數(shù)據(jù)流可以看作一個有序序列, # 但不能提前知道序列的長度,只能不斷通過next()函數(shù)實現(xiàn)按需計算下一個數(shù)據(jù), # Iterator的計算是惰性的,只有在需要返回下一個數(shù)據(jù)時才計算; # 3.使用iter()函數(shù)把list、dict、str變成Iterator; print("使用iter()函數(shù)把list、dict、str變成Iterator.") print("判斷l(xiāng)ist是否為迭代器!",isinstance(iter([]),Iterator)) print("判斷dict是否為迭代器!",isinstance(iter({}),Iterator)) print("判斷str是否為迭代器!",isinstance(iter("Willard"),Iterator))
# 結(jié)果輸出:
判斷生成器是否為迭代器! True
判斷l(xiāng)ist是否為迭代器! False
判斷dict是否為迭代器! False
判斷str是否為迭代器! False
----------------------------------------------------------
使用iter()函數(shù)把list、dict、str變成Iterator.
判斷l(xiāng)ist是否為迭代器! True
判斷dict是否為迭代器! True
判斷str是否為迭代器! True
?
總結(jié)
原文鏈接:https://fuxi-willard.blog.csdn.net/article/details/122673716
相關(guān)推薦
- 2022-08-06 Flutter?隊列任務(wù)的實現(xiàn)_Android
- 2022-10-27 Python入門之字符串操作詳解_python
- 2022-10-25 在IIS上部署Go?API項目_win服務(wù)器
- 2023-04-20 flex 的 三個參數(shù):flex-grow、flex-shrink、flex-basis
- 2022-02-20 Hive-SQL查詢連續(xù)活躍登錄用戶思路詳解_MsSql
- 2022-09-22 python 參數(shù)內(nèi)存地址相關(guān)
- 2023-05-29 批標(biāo)準(zhǔn)化層?tf.keras.layers.Batchnormalization()解析_pytho
- 2022-04-01 k8s報錯:Error response from daemon: pull access deni
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(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)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支