列表解析式是一種利用 [ 表達(dá)式 + for 循環(huán) [ + if判斷 ] ] 快速生成列表對(duì)象的python語(yǔ)法,方便使用者快速構(gòu)建列表。
語(yǔ)法:
創(chuàng)新互聯(lián)建站于2013年創(chuàng)立,先為海倫等服務(wù)建站,海倫等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為海倫企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問(wèn)題。
# 列表解析式 第一種效率會(huì)明顯高于第二種
[(i,j) for i in range(1000) if i > 700 for j in range(1000) if j > 900]
[{i,j} for i in range(1000) for j in range(1000) if j>900 if i > 700]
# 注:其中的元素必須可哈希,不允許是列表,字典,set()等不可哈希對(duì)象,否則將會(huì)報(bào)錯(cuò)
{ (i,j) for i in range(1000) if i > 700 for j in range(1000) if j > 900 }
it = (i for i in range(10)) #將會(huì)返回一個(gè)生成器對(duì)象
一個(gè)可以做指定操作,并在每次next()時(shí)返回一個(gè)值的對(duì)象,節(jié)省空間存放數(shù)據(jù),但每次計(jì)算需要等待.
一個(gè)可以被迭代的對(duì)象,for 將會(huì)全部迭代其中的元素,也可使用next()一個(gè)個(gè)取值返回,迭代器只可以使用一輪,無(wú)法反復(fù)使用,生成器也是一個(gè)迭代器
可以被迭代的對(duì)象,例如元組,字典,集合,列表等容器,生成器和迭代器也是可迭代對(duì)象
# len():返回集合類型的長(zhǎng)度,注:無(wú)法計(jì)算生成器或迭代器的長(zhǎng)度,可計(jì)算list,set,dict等集合的長(zhǎng)度
# len((i for i in range(5))) # ==> TypeError:object of type 'generator' has no len() 計(jì)算生成器的長(zhǎng)度
isinstance(True, int), issubclass(bool, int) # 實(shí)例判斷,子類判斷
divmod(124,3) # ==> (124/3, 124%3)==(41, 1)
chr(97) # ==> int(0-255) --> char
ord("a") # ==> char --> int
hex(ord("中")) # 中文使用的是unicode編碼表對(duì)應(yīng)關(guān)系, 兩字節(jié)長(zhǎng)度 '0x4e2d'
# 排序 迭代內(nèi)部容器,默認(rèn)升序并返回排序后的列表,set和dict也可排序,迭代器也可排序
sorted([1,2,3] + ['a'],reverse=True, key=str ) # 臨時(shí)轉(zhuǎn)化類型進(jìn)行比較,原值不會(huì)改變,123還是int類型 ['a', 3, 2, 1]
a = iter("abcd") # 對(duì)迭代器排序,會(huì)遍歷整個(gè)迭代器,返回一個(gè)排序好的列表;
sorted(a) # ['a', 'b', 'c', 'd']
返回迭代器的BIF
# reversed(seq) # 翻轉(zhuǎn)一個(gè)有序容器,set和dict無(wú)法翻轉(zhuǎn) ==> 返回一個(gè)翻轉(zhuǎn)后的迭代器,單個(gè)對(duì)象
[ i for i in reversed("abcd") ] # ==> ['d', 'c', 'b', 'a']
it = reversed(sorted({1,49,0,6,7,8,})) # ==>
print( [ i for i in it ] ) # 遍歷迭代器 [49, 8, 7, 6, 1, 0]
# 枚舉:enumerate(seq, start=0) # ==> 返回一個(gè)迭代器,每次返回一個(gè)二元組==> (index, elem)
en = enumerate([1,2,3,4,5])
next(en) # ==> (0, 1)
next(en) # ==>(1, 2)
print([i for i in en]) # [(2, 3), (3, 4), (4, 5)] 完全遍歷
# 迭代器
iter(iterable) # ==> 返回一個(gè)迭代器
iter(callable, sentinel) # ==> iterator
def fun():
x = 0
def fun1():
nonlocal x
x += 1
return x
return fun1
f = fun()
it = iter(f, 7) # == > f 必須可調(diào)用,0參,當(dāng)返回值等于 sentinel 結(jié)束
[i for i in it] # == > [1,2,3,4,5,6]
# 文件讀取操作時(shí)的使用
with open('mydata.txt') as fp:
for line in iter(fp.readline, ''):
process_line(line)
from functools import partial
with open('somefile.data', 'rb') as f:
records = iter(partial(f.read, RECORD_SIZE), b'')
for r in records:
pass
# iter() 函數(shù)有一個(gè)鮮為人知的特性,如果你給它傳遞一個(gè)可調(diào)用對(duì)象和一個(gè)標(biāo)記值,它
# 會(huì)創(chuàng)建一個(gè)迭代器。這個(gè)迭代器會(huì)一直調(diào)用傳入的可調(diào)用對(duì)象直到它返回標(biāo)記值為止
# 可迭代對(duì)象,包括:set, dict, 生成器,string,range(),
# in, not in
# 執(zhí)行in操作,對(duì)于線性順序結(jié)構(gòu)來(lái)說(shuō),本質(zhì)上就是對(duì)其進(jìn)行遍歷
# 生成器和迭代器也可以進(jìn)行 in 操作
a = iter("abcd")
"a" in a # ==> True, 遍歷到第一個(gè)元素找到 "a", 迭代器為使用完,可以繼續(xù)使用
next(a) # ==> 繼續(xù)使用返回下一個(gè) ==> 'b'
# zip()
for i in zip(range(5), "abcde"):
print(i ,end=" ") #==> (0, 'a') (1, 'b') (2, 'c') (3, 'd') (4, 'e')輸出結(jié)果使用enumerate()一樣