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