python實現七種列表去重方法


#encoding=utf-8
import time
time_start=time.time()
print u"列表去重的七種方法"
print u"第一種測試方法"
repeat_list=[1,2,4,1,5,1,2,5]
result=[]
for i in repeat_list:
    if i not in result:
        result.append(i)
print u"第一種去重結果: ",result
print u"第二種測試方法"
repeat_list=[1,2,4,1,5,1,2,5]
result={}
print u"第二種去重結果: ",list(result.fromkeys(repeat_list))
print u"第三種測試方法"
repeat_list=[1,2,4,1,5,1,2,5]
print u"第三種去重結果: ",list(set(repeat_list))
print u"第四種測試方法"
repeat_list=[1,2,4,1,5,1,2,5]
import itertools
def test_groupby(x):
    if x==1:
        print "lower"
    elif x>1 and x<4:
        print "middle"
    elif x>=4:
        print "higher"
repeat_list=sorted(repeat_list)
data=itertools.groupby(repeat_list,key=test_groupby)
for i,j in data:
    print list(j)
data=itertools.groupby(repeat_list)
result=[]
for i,j in data:
    result.append(i)
print u"第四種去重結果: ",result
print u"第五種測試方法"
repeat_list=[1,2,4,1,5,1,2,5]
for i in [j for j in repeat_list if repeat_list.count(i)>1]:
    for x in range(repeat_list.count(i)-1):
     repeat_list.remove(i)
print u"第五種去重結果: ",repeat_list
print u"第六種測試方法"
repeat_list=[1,2,4,1,5,1,2,5]
i=0
while i<=len(repeat_list)-1:
    if repeat_list.count(repeat_list[i])>1:
        repeat_list.pop(i)
    else:
        i+=1
print u"第六種去重結果: ",repeat_list
print u"第七種測試方法"
repeat_list=[1,2,4,1,5,1,2,5]
func=lambda x,y:x if y in x else x + [y]
print u"第七種去重結果: ",reduce(func,[[],]+repeat_list)
print "_"*20
print u"去重程序耗時%f" % (time.time()-time_start)
print "_"*20
time.sleep(3)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM