1. 列表推導(dǎo)式
列表推導(dǎo)式是通過舊的列表通過公式推導(dǎo)出新的列表
還有集合推導(dǎo)式联逻、字典推導(dǎo)式,與列表推導(dǎo)式類似
格式為:
[表達(dá)式 for 變量 in 舊列表]
[表達(dá)式 for 變量 in 舊列表 if條件]
# 過濾掉長度小于或等于3的人名
names = ['tom','lily','abc','jack','steven']
result = [name for name in names if len(name) > 3]
print(result) #['lily', 'jack', 'steven']
# 過濾掉長度小于或等于3的人名锨推,并使每個(gè)人名首字母大寫
result = [name.capitalize() for name in names if len(name) > 3]
print(result) #['Lily', 'Jack', 'Steven']
# 將1-100之間能被3整除换可,組成一個(gè)新的列表
newlist = [i for i in range(1,101) if i % 3 == 0 and i % 5 ==0]
# 將0-5的偶數(shù),0-10的奇數(shù)組成元組慨飘,添加到新的列表中
newlist = [(x,y) for x in range(5) if i%2 == 0 for y in range(10) if y % 2 != 0]
# 如果判斷條件有else译荞,如果寫推導(dǎo)式
newlist = [i+1 if i > 3 else i-1 for i in range(5)]
2. 生成器
2.1 生成器的概念
通過列表生成式(列表推導(dǎo)式)吞歼,我們可以直接創(chuàng)建一個(gè)列表。
但是篙骡,受到內(nèi)存限制医增,列表容量肯定是有限的老虫。
而且,創(chuàng)建一個(gè)包含100萬個(gè)元素的列表忽刽,不僅占用很大的存儲(chǔ)空間跪帝,如果我們僅僅需要訪問前面幾個(gè)元素伞剑,那后面絕大多數(shù)元素占用的空間部白白浪費(fèi)了市埋。
所以,如果列表元素可以按照某種算法推算出來抒倚,那我們是否可以在循環(huán)的過程中不斷推算出后續(xù)的元素呢托呕?
這樣就不必創(chuàng)建完整的list,從而節(jié)省大量的空間馅扣。在Python中呆抑,這種一邊循環(huán)一邊計(jì)算的機(jī)制,稱為生成器:generator厌殉。
2.2 創(chuàng)建生成器
通過列表推導(dǎo)式創(chuàng)建
# 通過:(列表推導(dǎo)式)可以得到生成器
g = (x*3 for x in range(20))
print(type(g))
print(g)
# 方式1:通過調(diào)用__next()__方式得到元素
print(g.__next__()) #0
print(g.__next__()) #3
print(g.__next__()) #6
# 方式2:通過next(生成器對象)方法
print(next(g)) #6
print(next(g)) #12
print(next(g)) #15
借助函數(shù)創(chuàng)建
只要函數(shù)中出現(xiàn)了yield公罕,說明函數(shù)就不是函數(shù)耀销,變成了生成器
創(chuàng)建步驟:
- 定義一個(gè)函數(shù),在函數(shù)中使用yield關(guān)鍵字
- 調(diào)用函數(shù)罐柳,接收調(diào)用結(jié)果
- 得到的結(jié)果就是生成器
- 借助于next()张吉、next()得到元素
def func():
n = 0
while True:
n += 1
yield n # 相當(dāng)于return n + 暫停
g = func()
print(g) #<generator object func at 0x000002687B393DC8>
print(next(g)) #1
print(next(g)) #2
print(next(g)) #3
2.3 生成器的作用
實(shí)現(xiàn)線程下協(xié)程的操作
def task1(n):
for i in range(n):
print("正在聽第{}首歌".format(i))
yield None
def task2(n):
for i in range(n):
print("正在搬第{}塊轉(zhuǎn)".format(i))
yield None
g1 = task1(5)
g2 =task2(5)
while True:
try:
g1.__next__()
g2.__next__()
except:
pass
3. 迭代器
3.1 可迭代對象
生成器肮蛹、元組创南、列表、字典昆码、集合邻储、字符串都是可迭代的
判斷是否可迭代可用方法isinstance()
3.2 迭代器的概念
迭代是訪問集合元素的一種方式。迭代器是一個(gè)可以記住遍歷的位置的對象冬耿。
迭代器對象從集合的第一個(gè)元素開始訪問萌壳,直到所有的元素被訪問完結(jié)束。
迭代器只能往前不會(huì)后退缤骨。
可以被next()函數(shù)調(diào)用并不斷返回下一個(gè)值的對象稱為迭代器:Iterator绊起。
可迭代對象不一定是迭代器,列表是可迭代對象蜂绎,但不是迭代器笋鄙;生成器是可迭代對象,也是是迭代器
3.3 迭代器的創(chuàng)建
通過iter()函數(shù)將可迭代對象變成迭代器
list = [1,3,4,6]
list1 = iter(list)
print(next(list1))
print(next(list1))
print(next(list1))