国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

python生成器表達式和列表解析

2020-01-04 17:38:53
字體:
來源:轉載
供稿:網友
最近在學習python的過程中,對列表解析及生成器表達式有點疑惑。從表面上看,兩者很相似,只有一點不同:列表解析采用中括號[]來包含,生成器表達式采用小括號()來包含。本文我們就來詳細看下python生成器表達式和列表解析
 

絕大多數情況下,遍歷一個集合都是為了對元素應用某個動作或是進行篩選。如果看過本文的第二部分,你應該還記得有內建函數map和filter提供了這些功能,但Python仍然為這些操作提供了語言級的支持。

(x+1 for x in lst) #生成器表達式,返回迭代器。外部的括號可在用于參數時省略。 [x+1 for x in lst] #列表解析,返回list

如你所見,生成器表達式和列表解析(注:這里的翻譯有很多種,比如列表展開、列表推導等等,指的是同一個意思)的區別很小,所以人們提到這個特性時,簡單起見往往只描述成列表解析。然而由于返回迭代器時,并不是在一開始就計算所有的元素,這樣能得到更多的靈活性并且可以避開很多不必要的計算,所以除非你明確希望返回列表,否則應該始終使用生成器表達式。接下來的文字里我就不區分這兩種形式了:)

你也可以為列表解析提供if子句進行篩選:

(x+1 for x in lst if x!=0)

或者提供多條for子句進行嵌套循環,嵌套次序就是for子句的順序:

((x, y) for x in range(3) for y in range(x))

列表解析就是鮮明的Pythonic。我常遇到兩個使用列表解析的問題,本應歸屬于最佳實踐,但這兩個問題非常典型,所以不妨在這里提一下:

第一個問題是,因為對元素應用的動作太復雜,不能用一個表達式寫出來,所以不使用列表解析。這是典型的思想沒有轉變的例子,如果我們將動作封裝成函數,那不就是一個表達式了么?

第二個問題是,因為if子句里的條件需要計算,同時結果也需要進行同樣的計算,不希望計算兩遍,就像這樣:

(x.doSomething() for x in lst if x.doSomething()>0)

這樣寫確實很糟糕,但組合一下列表解析即可解決:

(x for x in (y.doSomething() for y in lst) if x>0)

內部的列表解析變量其實也可以用x,但為清晰起見我們改成了y。或者更清楚的,可以寫成兩個表達式:

tmp = (x.doSomething() for x in lst)(x for x in tmp if x > 0)

列表解析可以替代絕大多數需要用到map和filter的場合,可能正因為此,著名的靜態檢查工具pylint將map和filter的使用列為了警告。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 渑池县| 鹿邑县| 梁山县| 新巴尔虎左旗| 英吉沙县| 雷波县| 宝应县| 西安市| 卢氏县| 晋宁县| 合水县| 芒康县| 东阿县| 寿阳县| 池州市| 寿光市| 兴化市| 松潘县| 开封县| 宽城| 南平市| 延边| 阜城县| 治县。| 汉川市| 桐梓县| 临桂县| 大埔县| 白水县| 惠水县| 封丘县| 临西县| 德江县| 瑞昌市| 中阳县| 喀喇| 华阴市| 东兴市| 塘沽区| 乌拉特中旗| 富锦市|