對並行列表進行排序時保持原始位置
在您有並行列表並希望在重新排列另一個列表的同時對一個清單進行排序的情況下以同步的方式,存在一個強大的解決方案。利用「裝飾、排序、取消裝飾」方法簡化了過程,特別是使用 Python 的內建 zip 函數。
Pythonic 解決方案需要創建一個裝飾後的 zip 對象,然後對其進行排序,最後提取原始列表從已排序的 zip 中。這種技術保留了兩個清單中元素的原始位置。
例如,給定清單:
list1 = [3, 2, 4, 1, 1] list2 = ['three', 'two', 'four', 'one', 'one2']
執行下列程式碼:
list1, list2 = zip(*sorted(zip(list1, list2)))
將產生:
list1 = [1, 1, 2, 3, 4] list2 = ['one', 'one2', 'two', 'three', 'four']
但是,如果清單為空,則此特定方法將無法正常運作。稍微修改一下就可以解決這個問題:
list1, list2 = (list(t) for t in zip(*sorted(zip(list1, list2))))
Python 提供了另一種就地排序方法,雖然比較冗長,但可以為較小的列表提供輕微的性能提升:
tups = zip(list1, list2) tups.sort() list1, list2 = zip(*tups)
總而言之,雖然有多種方法可以解決這個問題,但zip 方法提供了一種簡潔高效的解決方案,可以在整個排序過程中保持元素的原始位置。
以上是如何在 Python 中對一個列表進行排序,同時保持並行列表的原始順序?的詳細內容。更多資訊請關注PHP中文網其他相關文章!