溫馨提示×

溫馨提示×

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

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

python中怎么實現(xiàn)循環(huán)遍歷

發(fā)布時間:2021-07-10 15:26:18 來源:億速云 閱讀:277 作者:Leah 欄目:互聯(lián)網(wǎng)科技

今天就跟大家聊聊有關(guān)python中怎么實現(xiàn)循環(huán)遍歷,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

python之循環(huán)遍歷

關(guān)于循環(huán)遍歷大家都知道,不外乎for和while,今天我在這寫點不一樣的循環(huán)和遍歷。在實踐中有時會遇到刪除列表中的元素,那么循環(huán)遍歷列表刪除指定元素該怎么做呢?

還是直接上代碼看案例吧:

import time

# 刪除下面列表中所有張姓元素,輸出的結(jié)果應(yīng)該是['李老大','李老二']
lst = ['張老大', '張老二', '李老大', '張老三', '李老二']*10000

# 直接for循環(huán)遍歷列表,remove需要刪除的元素
def del1(lst):
    for i in lst:
        if i[0] == '張':
            lst.remove(i)  # 在刪lst[0]'張老大'的時候,列表長度變成4,導(dǎo)致lst[1]取值成了'李老大',跳過了'張老二'
    return lst  # 返回的結(jié)果不符合預(yù)期


# 正向遍歷,通過建一個原列表的副本,然后遍歷副本,刪除原列表中的元素
def del2(lst):
    lst2 = lst.copy()  # 創(chuàng)建副本內(nèi)存和時間開銷大
    for i in lst2:
        if i[0] == '張':
            lst.remove(i)  # 刪除第一個匹配的元素,檢索匹配時間開銷大
    return lst  # 結(jié)果雖然正確,但效率極低,不要用這種方法


# 使用高階函數(shù)filter方法
def del3(lst):
    def comp(n):  # 創(chuàng)建過濾函數(shù)
        return n[0] != '張'  #對于首字符不是'張'的元素返回True,予以保留。若返回False的予以刪除。
    return list(filter(comp, lst))  # filter高階函數(shù)刪除列表中的元素,
#  刪除條件是comp方法,返回的是迭代器,需要list方法轉(zhuǎn)成列表


# 倒序刪除法
def del4(lst):
    for i in range(len(lst) - 1, -1, -1):  # 注意len(lst)必須-1,因為列表元素下標是0至len(lst)-1;注意for循環(huán)左開右閉,
# 從lst隊尾循環(huán)到開頭必須是-1,寫0會漏了lst[0];-1表示倒序排列。range實際就是int數(shù)字列表生成式,在這實際生成的是
# [49999,49998,..1,0],通過下標訪問列表的指定元素。
        if lst[i][0] == '張':
            del lst[i]
    return lst


# 倒序刪除之while循環(huán),效果和for序號一致,運行效率差別極其微小(for序號方法內(nèi)存開銷略大一點點)。while循環(huán)需要寫7行,
# for循環(huán)只要5行,更推薦使用for循環(huán)。但while循環(huán)代碼閱讀起來更易懂。
def del5(lst):
    length = len(lst) - 1
    while length >= 0:
        if lst[length][0] == '張':
            del lst[length]
        length -= 1
    return lst


# lst = del1(lst)  # del1方法直接遍歷列表刪除指定元素,返回結(jié)果錯誤
# print(lst)

# t1 = time.time()
# lst = del2(lst)  # del2方法通過創(chuàng)建原列表副本,遍歷副本刪除原件中的指定元素,返回結(jié)果正確,但是運行效率極低
# t2 = time.time()
# print(f"遍歷方法刪除元素用時:{t2 - t1:.5f}")  # 4.51529,在這可以看到代碼優(yōu)化的必要性,運行結(jié)果雖然一致但性能差別極大。
# 評價性能一般看2個指標,1是時間消耗,2是資源消耗(通常指內(nèi)存消耗,特殊場合還有別的資源消耗)。

t1 = time.time()
lst = del3(lst)
t2 = time.time()
print(f"filter方法刪除元素用時:{t2 - t1:.5f}")  # 0.00596

# t1 = time.time()
# lst = del4(lst)
# t2 = time.time()
# print(f"遍歷方法刪除元素用時:{t2 - t1:.5f}")  # 0.07991

# t1 = time.time()
# lst = del5(lst)
# t2 = time.time()
# print(f"遍歷方法刪除元素用時:{t2 - t1:.5f}")  # 0.08516

看完上述內(nèi)容,你們對python中怎么實現(xiàn)循環(huán)遍歷有進一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細節(jié)

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

AI