本文實例講述了Python實現列表刪除重復元素的三種常用方法。分享給大家供大家參考,具體如下:
給定一個列表,要求刪除列表中重復元素。
listA = ['python','語','言','是','一','門','動','態','語','言']
方法1,對列表調用排序,從末尾依次比較相鄰兩個元素,遇重復元素則刪除,否則指針左移一位重復上述過程:
def deleteDuplicatedElementFromList(list): list.sort(); print("sorted list:%s" % list) length = len(list) lastItem = list[length - 1] for i in range(length - 2,-1,-1): currentItem = list[i] if currentItem == lastItem: list.remove(currentItem) else: lastItem = currentItem return list方法2,設一臨時列表保存結果,從頭遍歷原列表,如臨時列表中沒有當前元素則追加:
def deleteDuplicatedElementFromList2(list): resultList = [] for item in list: if not item in resultList: resultList.append(item) return resultList
方法3,利用python中集合元素惟一性特點,將列表轉為集合,將轉為列表返回:
def deleteDuplicatedElementFromList3(listA): #return list(set(listA)) return sorted(set(listA), key = listA.index)
執行結果:
print(deleteDuplicatedElementFromList(listA))#sorted list:['python', '一', '動', '態', '是', '言', '言', '語', '語', '門']#['python', '一', '動', '態', '是', '言', '語', '門']print(deleteDuplicatedElementFromList2(listA))#['python', '語', '言', '是', '一', '門', '動', '態']print(deleteDuplicatedElementFromList3(listA))#['python', '語', '言', '是', '一', '門', '動', '態']
分析:
方法1,邏輯復雜,臨時變量保存值消耗內存,返回結果破壞了原列表順序,效率最差
方法2,直接調用append方法原處修改列表,邏輯清晰,效率次之
方法3,極度簡潔,使用python原生方法效率最高
PS:這里再為大家提供幾款去重復工具供大家參考使用:
在線去除重復項工具:
http://tools.jb51.net/code/quchong
在線文本去重復工具:
http://tools.jb51.net/aideddesign/txt_quchong
更多關于Python相關內容感興趣的讀者可查看本站專題:《Python列表(list)操作技巧總結》、《Python數組操作技巧總結》、《Python字符串操作技巧匯總》、《Python函數使用技巧總結》、《Python入門與進階經典教程》及《Python數據結構與算法教程》
希望本文所述對大家Python程序設計有所幫助。
新聞熱點
疑難解答