python 列表去重(陣列)的幾種方法
阿新 • • 發佈:2018-12-10
一、方法1
程式碼如下 | 複製程式碼 |
ids = [1,2,3,3,4,2,3,4,5,6,1] news_ids = [] for id in ids: if id not in news_ids: news_ids.append(id) print news_ids |
思路看起來比較清晰簡單 ,也可以保持之前的排列順序。
二、方法2
通過set方法進行處理
程式碼如下 | 複製程式碼 |
ids = [1,4,3,3,4,2,3,4,5,6,1] ids = list(set(ids)) |
處理起來比較簡單,使用了集合方法set進行處理,不過結果不會保留之前的順序。
三、方法3
利用lambda匿名函式和 reduce 函式處理
程式碼如下 | 複製程式碼 |
ids = [1,4,3,3,4,2,3,4,5,6,1] func = lambda x,y:x if y in x else x + [y] reduce(func, [[], ] + ids) |
四、方法4
使用itertools模組
程式碼如下 | 複製程式碼 |
import itertools ids = [1,4,3,3,4,2,3,4,5,6,1] ids.sort() it = itertools.groupby(ids) for k, g in it: print k |
五、無法保持原有順序
程式碼如下 | 複製程式碼 |
liebiao=set(liebiao) |
六、while遍歷去重
程式碼如下 | 複製程式碼 |
def delRepeat(liebiao): for x in liebiao: while liebiao.count(x)>1: del liebiao[liebiao.index(x)] return liebiao |