生成器、BIF

列表解析式

列表解析式是一種利用 [ 表達式 + for 循環 [ + if判斷 ] ] 快速生成列表對象的python語法,方便使用者快速構建列表。
語法

# 列表解析式   第一種效率會明顯高於第二種
[(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()等不可哈希對象,否則將會報錯
{ (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))          #將會返回一個生成器對象

生成器對象

一個可以做指定操作,並在每次next()時返回一個值的對象,節省空間存放數據,但每次計算需要等待.

迭代器對象

一個可以被迭代的對象,for 將會全部迭代其中的元素,也可使用next()一個個取值返回,迭代器只可以使用一輪,無法反覆使用,生成器也是一個迭代器

可迭代對象

可以被迭代的對象,例如元組,字典,集合,列表等容器,生成器和迭代器也是可迭代對象

內置函數(BIF)

# len():返回集合類型的長度,注:無法計算生成器或迭代器的長度,可計算list,set,dict等集合的長度
# len((i for i in range(5)))       # ==> TypeError:object of type 'generator' has no len()  計算生成器的長度

isinstance(True, int), issubclass(bool, int) # 實例判斷,子類判斷
divmod(124,3)                       #  ==>   (124/3, 124%3)==(41, 1)
chr(97)                                  # ==>  int(0-255) --> char
ord("a")                                 # ==>  char  --> int
hex(ord("中"))                       # 中文使用的是unicode編碼表對應關係, 兩字節長度 '0x4e2d'

# 排序  迭代內部容器,默認升序並返回排序後的列表,set和dict也可排序,迭代器也可排序
sorted([1,2,3] + ['a'],reverse=True, key=str )   # 臨時轉化類型進行比較,原值不會改變,123還是int類型 ['a', 3, 2, 1]
a = iter("abcd")        # 對迭代器排序,會遍歷整個迭代器,返回一個排序好的列表;
sorted(a)                 # ['a', 'b', 'c', 'd']

返回迭代器的BIF

# reversed(seq)                                    # 翻轉一個有序容器,set和dict無法翻轉 ==> 返回一個翻轉後的迭代器,單個對象
[ i for i in reversed("abcd") ]                   # ==> ['d', 'c', 'b', 'a']
it = reversed(sorted({1,49,0,6,7,8,}))    # ==> <list_reverseiterator at 0x212dce3ccf8>
print( [ i for i in it ] )                                  # 遍歷迭代器 [49, 8, 7, 6, 1, 0]

# 枚舉:enumerate(seq, start=0) # ==> 返回一個迭代器,每次返回一個二元組==> (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)                                 # ==> 返回一個迭代器
# 可迭代對象,包括:set, dict, 生成器,string,range(), 

# in, not in 
# 執行in操作,對於線性順序結構來說,本質上就是對其進行遍歷
# 生成器和迭代器也可以進行 in 操作
a = iter("abcd")   
"a" in a             # ==> True, 遍歷到第一個元素找到 "a", 迭代器爲使用完,可以繼續使用
next(a)             # ==> 繼續使用返回下一個 ==>  'b'

# zip() 
for i in zip(range(5), "abcde"):
    print(i ,end=" ")       #==>  (0, 'a') (1, 'b') (2, 'c') (3, 'd') (4, 'e')輸出結果使用enumerate()一樣
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章