基于Python列表解析(列表推導式)
列表解析——用來動態(tài)地創(chuàng)建列表
[expr for iter_var in iterable if cond_expr]
例子一:
map(lambda x: x**2, range(6)) [0, 1, 4, 9, 16, 25]
[x**2 for x in range(6)] [0, 1, 4, 9, 16, 25]
列表解析式可以取代內(nèi)建的map()函數(shù)以及l(fā)ambda,而且++效率更高++。
例子二:
seq = [11, 10, 9, 8, 7, 6] filter(lambda x: x % 2, seq) [11, 9, 7]
[x for x in seq if x % 2] [11, 9, 7]
例子三:
找出文本中最長的詞
# 第一個最長的詞 longest = '' for word in text: if len(word) > len(longest): longest = word
#所有最長的詞 maxlen = max(len(word) for word in text) # 生成器表達式 [word for word in text if len(word) == maxlen] #鏈表推導式
不足:列表解析得一個不足就是必要生成所有數(shù)據(jù),用于創(chuàng)建整個列表。這可能對有大量數(shù)據(jù)得迭代其有負面效應。
++解決方法++:生成器表達式,通過結合列表解析和生成器解決了這個問題。
嵌套列表推導式
例一
all_data = [[1,3,5,7,9], [2,4,6,8,10]] result = [] for nums in all_data: temp_num = [num for num in nums if num >= 5] result.extend(temp_num)
嵌套列表推導式
result = [num for nums in all_data for num in nums if num >= 5]
推導式中for的部分是按嵌套順序排列的。
例二
some_tuples = [(1,2,3), (4,5,6), (7,8,9)] flattened = [x for tup in some_tuples for x in tup] flattened [1,2,3,4,5,6,7,8,9]
以上這篇基于Python列表解析(列表推導式)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Python的Flask框架標配模板引擎Jinja2的使用教程
Jinja2是Python世界的一款高人氣template engine,是許多開源Web框架的選擇,包括Flask這樣的明星級項目,這里我們就來共同學習Python的Flask框架標配模板引擎Jinja2的使用教程2016-07-07python內(nèi)置函數(shù)anext的具體使用
本文主要介紹了python內(nèi)置函數(shù)anext的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-01-01python利用requests庫模擬post請求時json的使用教程
這篇文章主要介紹了python利用requests庫模擬post請求時json的使用 ,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2018-12-12Python設計模式中單例模式的實現(xiàn)及在Tornado中的應用
這篇文章主要介紹了Python設計模式中單例模式的實現(xiàn)及在Tornado中的應用,講解了單例模式用于設計Tornado框架中的線程控制方面的相關問題,需要的朋友可以參考下2016-03-03