《python網路資料擷取》讀後感 第三章:開始採集

來源:互聯網
上載者:User

標籤:div   clu   attr   span   append   follow   attrs   open   one   

 1 from urllib.request import urlopen 2 from bs4 import BeautifulSoup 3 import re 4 import random 5 import datetime 6  7 pages = set() 8 random.seed(datetime.datetime.now()) 9 10 #擷取當前頁面所有內鏈的表11 def getInternalLinks(bsObj,includeUrl):12     internalLinks = []13     #找出所有以"/"開頭的連結14     for link in bsObj.findAll("a",href = re.compile("^(/|.*"+includeUrl+")")):15         if link.attrs[‘href‘] is not None:16             if link.attrs[‘href‘] not in internalLinks:17                 internalLinks.append(link.attrs[‘href‘])18 19     return internalLinks20 21 #擷取當前頁面所有外鏈的表22 def getExternalLinks(bsObj,excludeUrl):23     externalLinks = []24     #找出所有以‘http‘和‘www‘開頭且不包含當前URL的連結25     for link in bsObj.findAll("a",26                               href=re.compile("^(http|www)((?!"+excludeUrl+").)*$")):27         if link.attrs[‘href‘] is not None:28             if link.attrs[‘href‘] not in externalLinks:29                 externalLinks.append(link.attrs[‘href‘])30 31     return externalLinks32 33 def splitAddress(address):34     addressParts = address.replace("http://","").split("/")35     return addressParts36 37 38 def getNextExternalLink(param):39     pass40 41 42 def getRandomExternalLink(startingPage):43     html = urlopen(startingPage)44     bsObj = BeautifulSoup(html)45     externalLinks = getExternalLinks(bsObj, splitAddress(startingPage)[0])46     if len(externalLinks) == 0:47         internalLinks = getInternalLinks(startingPage)48         return getNextExternalLink(internalLinks[random.randint(0,49                                     len(internalLinks)-1)])50     else:51         return externalLinks[random.randint(0, len(externalLinks)-1)]52 53 def followExternalOnly(startingSite):54     externalLink = getRandomExternalLink("http://oreilly.com")55     print("隨機外鏈是:"+externalLink)56     followExternalOnly(externalLink)57 58 followExternalOnly("http://oreilly.com")

 

《python網路資料擷取》讀後感 第三章:開始採集

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.