1. 程式人生 > >每日一python(3):python 中對list去重的兩種方法

每日一python(3):python 中對list去重的兩種方法

在python相關職位的面試過程中,會對列表list的去重進行考察。(注意有時會要求保證去重的順序性

方法1:直觀方法

思路:先建立一個新的空列表,通過遍歷原來的列表,再利用邏輯關係not in 來去重

程式碼:

   #coding:utf-8
   
	ll = [1, 2, 3, 3, 4, 5, 6, 6, 6,7,8,8,9,10,10]
	new_ll = []
	for i in ll:
		if i not in new_ll:
			new_ll.append(i)
	print(new_ll)

輸出:

[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

**總結:**這樣可以做出來,但是過程不夠簡單。但是此方法保證了列表的順序性

方法2:利用set的自動去重功能

**思路:**將列表轉化為集合再轉化為列表,利用集合的自動去重功能,簡單快速。缺點是:使用set方法無法保證去重後的順序。

程式碼:

ll = [11,22,33,44,11,22]
ll = list(set(ll))
print(ll)

輸出:

[33, 11, 44, 22]

雖然set方法不能保證去重後的順序,但是可以通過列表中索引(index)的方法保證去重後的順序不變,如下:

ll = [11,22,33,44,11,22]
new_ll = list(set(ll))
new_ll.sort(key=ll.index)
print(new_ll)

輸出:

[11, 22, 33, 44]

總結:python的set和其他語言類似,是一個無序不重複元素集