強大的list列表解析功能

2021-06-20 04:09:36 字數 2809 閱讀 9196

列表解析表示你可以在一行中使用乙個for迴圈將所有值放到乙個列表當中。列表解析甚至能做更複雜的事情,比如挑選出符合要求的值放入列表。

python列表解析屬於python的迭代中的一種,相比python for迴圈速度會快很多。下面看下python列表解析是怎麼工作的。

example:

a = [x+2 for x in range(10)]

print a

輸出的結果:

[2, 3, 4, 5, 6, 7, 8, 9, 10, 11]

下面說下上面這個例子的執行過程:

python會在直譯器裡對range(10)進行迭代,依次把列表裡的內容取出來,賦值給最左邊的x,然後執行x+2的操作,並且把執行好的結果儲存在列表裡。等range(10)迭代完以後就新生成了乙個列表,結果就是[2, 3, 4, 5, 6, 7, 8, 9, 10, 11],從上面可以看出,這也是建立python 列表的乙個方法。

上面的例子如果用python for 迴圈來實現,那會是什麼樣的呢?

a =

for i in range(10):

print a

輸出的結果:

[2, 3, 4, 5, 6, 7, 8, 9, 10, 11]

從上面可以看的出來,python列表解析比python for迴圈解析列表的**量會更少,解析速度會更快,寫起來也更酷,自己單獨寫指令碼的話,會非常的簡便,但是它也有不足之處,它的可讀性不太好,特別是在團隊開發的話,適當的還是少用點,這樣通用性比較好,對大家也有好處。

在需要改變列表而不是需要新建某列表時,可以使用列表解析。列表解析表示式為:

[expr for iter_var in iterable] [expr for iter_var in iterable if cond_expr]

第一種語法:首先迭代iterable裡所有內容,每一次迭代,都把iterable裡相應內容放到iter_var中,再在表示式中應用該iter_var的內容,最後用表示式的計算值生成乙個列表。

第二種語法:加入了判斷語句,只有滿足條件的內容才把iterable裡相應內容放到iter_var中,再在表示式中應用該iter_var的內容,最後用表示式的計算值生成乙個列表。

舉例如下:

>>> l= [(x+1,y+1) for x in range(3) for y in range(5)]

>>> l

[(1, 1), (1, 2), (1, 3), (1, 4), (1, 5), (2, 1), (2, 2), (2, 3), (2, 4), (2, 5), (3, 1), (3, 2), (3, 3), (3, 4), (3, 5)]

>>> n=[x+10 for x in range(10) if x>5]

>>> n

[16, 17, 18, 19]

生成器表示式

生成器表示式是在python2.4中引入的,當序列過長, 而每次只需要獲取乙個元素時,應當考慮使用生成器表示式而不是列表解析。生成器表示式的語法和列表解析一樣,只不過生成器表示式是被()括起來的,而不是,如下:

(expr for iter_var in iterable)

(expr for iter_var in iterable if cond_expr) 例:

>>> l= (i + 1 for i in range(10) if i % 2)

>>> l

at 0xb749a52c>

>>> l1=

>>> for i in l:

...

>>> l1

[2, 4, 6, 8, 10]

生成器表示式並不真正建立數字列表, 而是返回乙個生成器,這個生成器在每次計算出乙個條目後,把這個條目「產生」(yield)出來。 生成器表示式使用了「惰性計算」,只有在檢索時才被賦值( evaluated),所以在列表比較長的情況下使用記憶體上更有效。

一些說明:

1. 當需要只是執行乙個迴圈的時候盡量使用迴圈而不是列表解析,這樣更符合python提倡的直觀性。

for item in sequence:

process(item)

2. 當有內建的操作或者型別能夠以更直接的方式實現的,不要使用列表解析。

例如複製乙個列表時,使用:l1=list(l)即可,不必使用:

l1=[x for x in l]

>>> freshfruit = ['  banana', '  loganberry ', 'passion fruit  '] 

>>> [str.strip() for str in freshfruit] 

['banana', 'loganberry', 'passion fruit'] 

把列表中,大於3的元素,乘以2 

>>> vec = [2, 4, 6] 

>>> [2*x for x in vec if x > 3] 

[8, 12] 

把列表1的每乙個元素和列表2的每乙個元素相乘 

>>> lst1 = [2, 4, 6] 

>>> lst2 = [4, 3, -9] 

>>> [x*y for x in lst1 for y in lst2] 

[8, 6, -18, 16, 12, -36, 24, 18, -54] 

獲取[0-10)的平方 

[x**2 for x in range(10)] 

或 map(lambda x : x*x, range(10)) 

獲取[0-10)中奇數的平方 

[x**2 for x in filter( lambda x : x%2, range(10) )]

python列表解析

列表解析是乙個列表對映出另乙個列表,它的基本形式是乙個方括號裡面包含乙個for語句對乙個iterable物件迭代 expression for target1 in iterable1 if condition1 for targetn in iterablen if conditionn 上面是列...

列表解析(推導)

優雅 清晰和務實都是python的核心價值觀,如果想通過操作和處理乙個序列 或其他的可迭代物件 來建立乙個新的列表時可以使用列表解析 list comprehensions 和生成表示式,通過這兩個操作,我們可以看到這三個觀點是如何在python中和諧統一起來的。列表解析 在需要改變列表而不是需要新...

python 列表解析

m 1,2,3 4,5,6 7,8,9 col2 row 1 for row in m 獲取列表m的每個元素的第二個元素的值組成的列表 print col2 print row 1 1 for row in m 獲取列表m的每個元素的第二個元素 1的值組成的列表 print row 1 for ro...