如下:
links.extend(link for link in get_links(html) if re.match(link_regex, link))
# 上面的語句分開寫,如下
# 但下面需要使用links.append,如果依然使用links.extend會(huì)出現(xiàn)錯(cuò)誤的結(jié)果
for link in get_links(html):
if re.match(link_regex, link):
links.append(link)
讓我們用ipython做個(gè)實(shí)驗(yàn):

由上圖可以看出,for in if 連擊推導(dǎo)式隱式的將link由str轉(zhuǎn)變?yōu)榱薼ist,而分開寫是不會(huì)幫我們轉(zhuǎn)換的,所以需要使用append把整個(gè)str加入到list.
補(bǔ)充:python的for i in list 陷阱
d = [1,2,3,4,5]
for i in d:
d.remove(i)
print d
結(jié)果是 :
這個(gè)陷阱比較隱蔽,我再用白盒子測試的時(shí)候,發(fā)現(xiàn)了這個(gè)bug,大致原因就是remove d[0]之后,i 自動(dòng)變成了 d[1], 但是 d已經(jīng)變成了 d[2,3,4,5],所以i=d[1]就悲催的指向了3,跳過了2!
看來python還是要注意了解底層實(shí)現(xiàn)啊!
解決辦法是
d = [1,2,3,4,5]
for i in d[:]:
d.remove(i)
print d
就可以實(shí)現(xiàn)邊遍歷邊刪除了
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- Python中在for循環(huán)中嵌套使用if和else語句的技巧
- python中for in的用法詳解
- Python for循環(huán)及基礎(chǔ)用法詳解