python 利用 for ... else 跳出雙層嵌套循環

背景

週末在寫一個爬蟲時,遇到這樣一種場景:從搜索結果中下載指定數量的文件app

例如:搜索結果中共分爲10頁展現,加起來一共50條數據,如今要作的是從50條數據中下載指定數量的數據spa

爲了實現這個功能,開始我是這樣想的:code

一、依次遍歷10頁數據,而且把每頁的數據都追加到同一個列表中,這樣的話,請求完10頁數據後,這個列表中就包含了全部結果;blog

二、而後再從這個大列表中提取指定數量的數據進行下載便可教程

這種方法確實可行,可是在運行過程當中發現一個問題:程序運行速度太慢了,緣由是不管你想下載多少條數據,都會先把全部數據請求下來並追加到列表中,這個過程實在是太耗時了,並且也不合理get

因此換一種思路:要下載n條數據,就只提取n條,不提早把全部數據請求下來for循環

具體實現方法

上面舉的例子,能夠抽象爲以下功能class

首先有一個嵌套的列表搜索

[[1,2,3,4,5],[6,7,8,9,10],[11,12,13,14,15],[16,17,18,19,20]]

而後提取這個列表中的數據到一個新的列表中,例如取前3個數字、前5個數字或者前8個數字循環

能夠經過雙層for循環來實現,另外要注意設置條件來跳出循環,以下

 1 source = [[1,2,3,4,5],[6,7,8,9,10],[11,12,13,14,15],[16,17,18,19,20]]
 2 target = []
 3 
 4 def get_data(source, count):
 5     for i in range(0, len(source)+1):
 6         temp = source[i]
 7         for j in temp:
 8             target.append(j)
 9             if len(target) >= count:
10                 break
11 
12         else:
13             continue
14         break
15 
16 t = get_data(source, 6)
17 print(target)

source表明原列表;count表明提取數字的個數

根據菜鳥教程的提示, for ... else 的意思以下:

一、for 中的語句和普通的沒有區別,else 中的語句會在循環正常執行完的狀況下執行(即 for 不是經過 break 跳出而中斷的);

二、若是for是因爲break中斷的,則不會執行else語句

來具體分析下count爲不一樣值時的運行過程及結果

 一、count=3

當count=3時,獲得以下結果

target = [1, 2, 3]

source中包含4個子列表,每一個子列表包含5個數字;

遍歷外層for循環,當遍歷到第一個子列表時,就可以知足內層for循環中斷的條件了,即:當提取到第一個字列表的數字3時,target的長度等於3,知足len(target)>=count,跳出內層for循環

因爲此時不是正常退出內層for循環,因此不會執行後面的else語句(ps:這裏else語句下是執行continue指令,也就是繼續遍歷外層for循環),而後繼續執行else後的berak語句,跳出外層for循環

綜上,獲得 target = [1, 2, 3] 的結果

二、count=8

當count=3時,獲得以下結果

target = [1, 2, 3, 4, 5, 6, 7, 8]

一樣,先取出外層for循環的第一個子列表,第一個子列表只有5個數字,當遍歷完後,target的長度等於5,不知足len(target)>=count

此時內層for循環正常結束第一輪遍歷,因爲for循環正常結束,因此執行else下的語句,也就是執行continue指令,這裏的continue是針對外層for循環的,也就是說繼續取出外層for循環的第二個子列表

當第二個子列表遍歷到第三個數字時,target的長度等於8,知足len(target)>=count,,跳出內層for循環

同理,因爲此時不是正常退出內層for循環,因此不會執行後面的else語句,而後繼續執行else後的berak語句,跳出外層for循環

綜上,獲得 target =[1, 2, 3, 4, 5, 6, 7, 8] 的結果

 

以上就是 for ... else 跳出雙層嵌套循環的內容,但願對你們有幫助~

相關文章
相關標籤/搜索