Python序列的推導式實現代碼
推導式comprehensions
(又稱解析式),是Python的一種獨有特性。
推導式是可以從一個數據序列構建另一個新的數據序列(的一種結構體)。
Python中共有三種推導,在Python2和3中都有支持:
- 列表推導式
- 字典推導式
- 集合推導式
1、列表推導式
作用:用一個表達式創建一個有規律的列表或控制一個有規律列表。
列表推導式又叫列表生成式。
(1)快速體驗
需求:創建一個0-10的列表。
while
循環實現
# 1. 準備一個空列表 list1 = [] # 2. 書寫循環,依次追加數字到空列表list1中 i = 0 while i < 10: list1.append(i) i += 1 # 結果:[0, 1, 2, 3, 4, 5, 6, 7, 8, 9] print(list1)
for
循環實現
list1 = [] for i in range(10): list1.append(i) # 結果:[0, 1, 2, 3, 4, 5, 6, 7, 8, 9] print(list1)
列表推導式實現
""" 因為是列表推導式,所以等號右邊的表達式要用[]括起來 因為最終要返回一個列表。 在推導式中,讀與寫都從for循環開始, for的左側是一個返回值,一次for循環返回的數值。 for每一次遍歷,都向列表中添加一個i變量。 """ # 結果:[0, 1, 2, 3, 4, 5, 6, 7, 8, 9] list1 = [i for i in range(10)] print(list1)
列表推導式就是化簡代碼,創建或控制有規律的列表。
(2)帶if的列表推導式
需求:創建0-10的偶數列表
方法一:通過range()
步長實現
# 結果:[0, 2, 4, 6, 8] list1 = [i for i in range(0, 10, 2)] print(list1)
方法二:通過if
實現
# 1. for循環加if 創建有規律的列表 list2 = [] for i in range(10): if i % 2 == 0: list2.append(i) # 結果:[0, 2, 4, 6, 8] print(list2) # 2.把for循環配合if的代碼 改寫 帶if的列表推導式 list1 = [i for i in range(10) if i % 2 == 0] # 結果:[0, 2, 4, 6, 8] print(list1)
(3)多個for循環實現列表推導式
需求,創建列表如下:
[(1, 0), (1, 1), (1, 2), (2, 0), (2, 1), (2, 2)]
代碼如下:
list1 = [(i, j) for i in range(1, 3) for j in range(3)] print(list1) # 推導過程如下 # 多for的列表推導式等同於for循環嵌套 # [(1, 0), (1, 1), (1, 2), (2, 0), (2, 1), (2, 2)] # 數據1 : 1 和 2 range(1,3) # 數據2 :0 1 2 range(3) list1 = [] for i in range(1, 3): for j in range(3): # 列表裡面追加元組: 循環前準備一個空列表, # 然後這裡追加元組數據到列表 list1.append((i, j)) print(list1) # 多個for實現列表推導式 list2 = [(i, j) for i in range(1, 3) for j in range(3)] print(list2)
2、字典推導式
思考:如果有如下兩個列表:
list1 = ['name', 'age', 'gender'] list2 = ['Tom', 20, 'man']
如何快速合並為一個字典?
答:用for
循環拼接可以實現,但是我們可以通過改寫for
循環,變成一個字典推導式。
字典推導式作用:快速合並列表為字典或提取字典中目標數據。
通過下面示例快速體驗字典推導式。
(1)創建一個字典
字典key
是1-5數字,value
是這個數字的2次方。
# dict1 = {k: v for i in range(1, 5)} dict1 = {i: i**2 for i in range(1, 5)} print(dict1) # {1: 1, 2: 4, 3: 9, 4: 16}
{i:i**2}
表示的是一個字典,key
是i
,value
是i**2
。
最後要返回一個字典,所以右邊表達式的最外層是一個大括號。
(2)將兩個列表合並為一個字典
list1 = ['name', 'age', 'gender'] list2 = ['Tom', 20, 'man'] dict1 = {list1[i]: list2[i] for i in range(len(list1))} print(dict1) # 結果:{'name': 'Tom', 'age': 20, 'gender': 'man'}
總結:
如果兩個列表數據個數相同,
len
統計任何一個列表的長度都可以。如果兩個列表數據個數不同,
len
統計數據多的列表數據個數會報錯;len
統計數據少的列表數據個數不會報錯。(這點一定要註意)
(3)提取字典中目標數據
counts = {'MBP': 268, 'HP': 125, 'DELL': 201, 'Lenovo': 199, 'acer': 99} # 需求:提取上述電腦數量大於等於200的字典數據 count1 = {key: value for key, value in counts.items() if value >= 200} print(count1) # {'MBP': 268, 'DELL': 201}
3、集合推導式
集合推導式比上面兩個推導式使用的頻率要少很多。
需求:創建一個集合,數據為下方列表的2次方。
list1 = [1, 1, 2]
代碼如下:
list1 = [1, 1, 2] set1 = {i ** 2 for i in list1} print(set1) # {1, 4}
註意:集合有數據去重功能。
4、補充提示
我們如何查看Python中關於序列的相關文檔:
- 打開文件找到序列部分文檔
- [The Python Standard Library(Python標準庫)] —> 右邊頁面[Sequence Type]
Common Sequence Operations
下的列表為序列的通用操作。- 就是可變序列和不可變序列都可以用的方法或者函數。
Mutable Sequence Types
下的列表為可變序列可以用的方法或者函數。
到此這篇關於Python序列的推導式實現代碼的文章就介紹到這瞭,更多相關Python序列的推導式內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!