巢狀清單理解:分解語法
在Python 中,清單理解是一種基於現有清單產生新清單的簡潔方法一。然而,當涉及到嵌套列表推導式時,語法可能會有點混亂。
考慮以下程式碼片段:
a = [[1,2],[3,4],[5,6]] b = [x for xs in a for x in xs]
此程式碼將巢狀清單 a 轉換為展平清單 b包含 a 中的所有元素。為了理解它是如何運作的,讓我們分解語法:
[x for xs in a for x in xs]
這是一個兩級嵌套理解。它本質上是說:
# Loop over the outer list for xs in a: # Loop over the inner list for x in xs: # Add x to the new list b b.append(x)
換句話說,它首先迭代外部列表 a,將每個子列表分配給變數 xs,然後迭代子列表,將每個元素分配給變數 x。對於每個元素 x,它將其新增至新清單 b。
此展開過程遵循循環的編寫順序:最外層循環最慢,其次是內部循環。這是 PEP202 中提到的「Right One」原則,即推導式應該在最內層循環上使用變化最快的索引來編寫。
透過理解這項原則,您可以自信地破解複雜的嵌套列表推導式.
以上是嵌套列表推導式如何在 Python 中展平列表?的詳細內容。更多資訊請關注PHP中文網其他相關文章!