列表生成式即list comprehensions,是python內建的非常簡單卻強大的可以用來建立list的生成式。
舉個例子,要生成list[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
可以用list(range(1, 11))
:
>>> list(range(1, 11))
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
但如果要生成[1x1, 2x2, 3x3, ..., 10x10]
怎麼做?方法一是迴圈:
>>> l =
>>>
for x in range(1, 11):
...>>> l
[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
但是迴圈太繁瑣,而列表生成式則可以用一行語句代替迴圈生成上面的list:
>>> [x * x for x in range(1, 11)]
[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
寫列表生成式時,把要生成的元素x * x
放到前面,後面跟for
迴圈,就可以把list建立出來,十分有用,多寫幾次,很快就可以熟悉這種語法。
for迴圈後面還可以加上if判斷,這樣我們就可以篩選出僅偶數的平方:
>>> [x * x for x in range(1, 11) if x % 2 == 0]
[4, 16, 36, 64, 100]
還可以使用兩層迴圈,可以生成全排列:
>>> [m + n for m in
'abc'
for n in
'xyz']
['ax', 'ay', 'az', 'bx', 'by', 'bz', 'cx', 'cy', 'cz']
三層和三層以上的迴圈就很少用到了。
運用列表生成式,可以寫出非常簡潔的**。例如,列出當前目錄下的所有檔案和目錄名,可以通過一行**實現:
>>>
import os # 匯入os模組,模組的概念後面講到
>>> [d for d in os.listdir('.')] # os.listdir可以列出檔案和目錄
for
迴圈其實可以同時使用兩個甚至多個變數,比如dict
的items()
可以同時迭代key和value:
>>> d =
>>>
for k, v in d.items():
... print(k, '=', v)
...y = b
x = a
z = c
因此,列表生成式也可以使用兩個變數來生成list:
>>> d =
>>> [k + '=' + v for k, v in d.items()]
['y=b', 'x=a', 'z=c']
最後把乙個list中所有的字串變成小寫:
>>> [s.lower() for s in l]
如果list中既包含字串,又包含整數,由於非字串型別沒有lower()
方法,所以列表生成式會報錯:
>>> [s.lower() for s in l]
traceback (most recent call last):
file "", line 1, in
file "", line 1, in
attributeerror: 'int' object has no attribute 'lower'
使用內建的isinstance
函式可以判斷乙個變數是不是字串:
>>> x = 'abc'
>>> y = 123
>>> isinstance(x, str)
true
>>> isinstance(y, str)
false
請修改列表生成式,通過新增if
語句保證列表生成式能正確地執行:
運用列表生成式,可以快速生成list,可以通過乙個list推導出另乙個list,而**卻十分簡潔。
python列表生成式
全都是重點!列表生成式即listcomprehensions,是python內建的非常簡單卻強大的可以用來建立list的生成式。舉個例子,要生成list 1,2,3,4,5,6,7,8,9,10 可以用range 1,11 range 1,11 1,2,3,4,5,6,7,8,9,10 但如果要生成...
python列表生成式
全都是重點!列表生成式即listcomprehensions,是python內建的非常簡單卻強大的可以用來建立list的生成式。舉個例子,要生成list 1,2,3,4,5,6,7,8,9,10 可以用range 1,11 range 1,11 1,2,3,4,5,6,7,8,9,10 但如果要生成...
python 列表生成式
要生成 1x1,2x2,3x3,10x10 怎麼做?方法一是迴圈 l forx inrange 1,11 l 1,4,9,16,25,36,49,64,81,100 但是迴圈太繁瑣,而列表生成式則可以用一行語句代替迴圈生成上面的list x x forx inrange 1,11 1 4,9 16,...