在 Python 中,可以透過多種方式建立包含相同重複元素的多個清單。本討論探討了一種繞過列表推導式的方法。
解:
Python 提供了運算子 * 來複製元素。要建立一個包含n 個元素e 的列表,只需使用表達式[e] * n.
範例:
e = 5 list_of_e = [e] * 10 # [5, 5, 5, 5, 5, 5, 5, 5, 5, 5]
注意:
如果e 是一個空列表,此方法將建立一個列表,其中n 個引用指向同一空列表。提供獨立的空列表需要不同的方法。
效能評估:
雖然 itertools.repeat() 最初可能看起來更快,但它需要轉換為清單來執行比較。運算符* 直接傳回一個列表,從而獲得更好的效能:
import timeit n = 1000000 timeit.timeit('[0] * 10', number=n) # Faster timeit.timeit('list(itertools.repeat(0, 10))', number=n) # Slower
結論:
要建立不含列表推導式的重複元素列表,請利用* 運算符,提供了簡潔且有效率的解決方案。當需要延遲生成元素時,請考慮 itertools.repeat()。
以上是如何在不使用列表推導式的情況下在 Python 中高效創建包含重複元素的列表?的詳細內容。更多資訊請關注PHP中文網其他相關文章!