溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

python中比較兩個(gè)列表不同的方法

發(fā)布時(shí)間:2020-08-25 10:18:46 來源:億速云 閱讀:517 作者:小新 欄目:編程語言

這篇文章主要介紹了python中比較兩個(gè)列表不同的方法,具有一定借鑒價(jià)值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

通過不斷的測試發(fā)現(xiàn),python實(shí)現(xiàn)高效快速比對兩個(gè)列表的不同,可借助python集合set()提供的集合運(yùn)算進(jìn)行操作,此方式效率非常高.

而在java語言中,如下方法中方法1相比方法2(集合運(yùn)算)的方式效率更高速度更快一些.這算是兩種語言相通之處的一點(diǎn)不同吧.

代碼如下:

#-*- coding:utf-8 -*-
import time

#方法1:
def getDiff1(arr1,arr2):
    start_time = time.time()
    print('1_start:',start_time)
    arr_more1 = []
    arr_more2 = []
    dic_result = {}

    for str_1 in arr1:
        dic_result[str(str_1)] = 1

    for str_2 in arr2:
        if dic_result.get(str(str_2)):
            dic_result[str(str_2)] = 2
        else:
            arr_more2.append(str_2)

    for key,val in dic_result.items():
        if val == 1:
            arr_more1.append(key)

    print('arr1比arr2多的內(nèi)容為:',len(arr_more1))
    print('arr2比arr1多的內(nèi)容為:',len(arr_more2))

    end_time = time.time()
    print('1_end:',end_time)
    print('方法1_比對用時(shí)為',end_time-start_time)


#方法2:使用集合運(yùn)算:
def getDiff2(arr1,arr2):
    start_time = time.time()
    print('2_start:',start_time)
    set_1 = ()
    set_2 = ()

    #將列表轉(zhuǎn)換為集合set()
    set_1 = set(arr1)
    set_2 = set(arr2)

    set_more1 = ()
    set_more2 = ()

    #集合運(yùn)算
    set_1_2 = set_1 & set_2
    set_more1 = set_1 -set_1_2
    set_more2 = set_2 -set_1_2

    print('arr1比arr2多的內(nèi)容為:',len(set_more1))
    print('arr2比arr1多的內(nèi)容為:',len(set_more2))

    end_time = time.time()
    print('2_end:',end_time)
    print('方法2_比對用時(shí)為',end_time-start_time)

#測試

# 初始化500w條數(shù)據(jù)數(shù)據(jù)
arr1 = []
arr2 = []
i = 0
while(True):
    arr1.append(i * 2)
    arr2.append(i * 3)
    i += 1
    if i > 5000000:
        break

print('arr1的長度為:',len(arr1))
print('arr2的長度為:',len(arr2))
print('+'*30)
getDiff1(arr1,arr2)
print('-'*30)
getDiff2(arr1,arr2)

運(yùn)行結(jié)果:

python中比較兩個(gè)列表不同的方法

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享python中比較兩個(gè)列表不同的方法內(nèi)容對大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,遇到問題就找億速云,詳細(xì)的解決方法等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI