欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用Python多線程爬蟲爬取電影天堂資源

 更新時間:2016年09月23日 16:25:13   作者:O賣女孩的小火柴O  
這篇文章主要介紹了使用Python多線程爬蟲爬取電影天堂資源 的相關資料,需要的朋友可以參考下

最近花些時間學習了一下Python,并寫了一個多線程的爬蟲程序來獲取電影天堂上資源的迅雷下載地址,代碼已經上傳到GitHub上了,需要的同學可以自行下載。剛開始學習python希望可以獲得寶貴的意見。

  先來簡單介紹一下,網絡爬蟲的基本實現原理吧。一個爬蟲首先要給它一個起點,所以需要精心選取一些URL作為起點,然后我們的爬蟲從這些起點出發(fā),抓取并解析所抓取到的頁面,將所需要的信息提取出來,同時獲得的新的URL插入到隊列中作為下一次爬取的起點。這樣不斷地循環(huán),一直到獲得你想得到的所有的信息爬蟲的任務就算結束了。我們通過一張圖片來看一下。

  好的 下面進入正題,來講解下程序的實現。

  首先要分析一下電影天堂網站的首頁結構。

  從上面的菜單欄中我們可以看到整個網站資源的總體分類情況。剛剛好我們可以利用到它的這個分類,將每一個分類地址作為爬蟲的起點。

  ①解析首頁地址 提取分類信息

#解析首頁
def CrawIndexPage(starturl):
print "正在爬取首頁"
page = __getpage(starturl)
if page=="error":
return
page = page.decode('gbk', 'ignore')
tree = etree.HTML(page)
Nodes = tree.xpath("http://div[@id='menu']//a")
print "首頁解析出地址",len(Nodes),"條"
for node in Nodes:
CrawledURLs = []
CrawledURLs.append(starturl)
url=node.xpath("@href")[0]
if re.match(r'/html/[A-Za-z0-9_/]+/index.html', url):
if __isexit(host + url,CrawledURLs):
pass
else:
try:
catalog = node.xpath("text()")[0].encode("utf-8")
newdir = "E:/電影資源/" + catalog
os.makedirs(newdir.decode("utf-8"))
print "創(chuàng)建分類目錄成功------"+newdir
thread = myThread(host + url, newdir,CrawledURLs)
thread.start()
except:
pass 

在這個函數中,首先將網頁的源碼下載下來,通過XPath解析出其中的菜單分類信息。并創(chuàng)建相應的文件目錄。有一個需要注意的地方就是編碼問題,但是也是被這個編碼糾纏了好久,通過查看網頁的源代碼,我們可以發(fā)現,網頁的編碼采用的是GB2312,這里通過XPath構造Tree對象是需要對文本信息進行解碼操作,將gb2312變成Unicode編碼,這樣DOM樹結構才是正確的,要不然在后面解析的時候就會出現問題。

  ②解析每個分類的主頁

# 解析分類文件
def CrawListPage(indexurl,filedir,CrawledURLs):
print "正在解析分類主頁資源"
print indexurl
page = __getpage(indexurl)
if page=="error":
return
CrawledURLs.append(indexurl)
page = page.decode('gbk', 'ignore')
tree = etree.HTML(page)
Nodes = tree.xpath("http://div[@class='co_content8']//a")
for node in Nodes:
url=node.xpath("@href")[0]
if re.match(r'/', url):
# 非分頁地址 可以從中解析出視頻資源地址
if __isexit(host + url,CrawledURLs):
pass
else:
#文件命名是不能出現以下特殊符號
filename=node.xpath("text()")[0].encode("utf-8").replace("/"," ")\
.replace("\\"," ")\
.replace(":"," ")\
.replace("*"," ")\
.replace("?"," ")\
.replace("\""," ")\
.replace("<", " ") \
.replace(">", " ")\
.replace("|", " ")
CrawlSourcePage(host + url,filedir,filename,CrawledURLs)
pass
else:
# 分頁地址 從中嵌套再次解析
print "分頁地址 從中嵌套再次解析",url
index = indexurl.rfind("/")
baseurl = indexurl[0:index + 1]
pageurl = baseurl + url
if __isexit(pageurl,CrawledURLs):
pass
else:
print "分頁地址 從中嵌套再次解析", pageurl
CrawListPage(pageurl,filedir,CrawledURLs)
pass
pass 

打開每一個分類的首頁會發(fā)現都有一個相同的結構(點擊打開示例)首先解析出包含資源URL的節(jié)點,然后將名稱和URL提取出來。這一部分有兩個需要注意的地方。一是因為最終想要把資源保存到一個txt文件中,但是在命名時不能出現一些特殊符號,所以需要處理掉。二是一定要對分頁進行處理,網站中的數據都是通過分頁這種形式展示的,所以如何識別并抓取分頁也是很重要的。通過觀察發(fā)現,分頁的地址前面沒有“/”,所以只需要通過正則表達式找出分頁地址鏈接,然后嵌套調用即可解決分頁問題。

③解析資源地址保存到文件中

#處理資源頁面 爬取資源地址
def CrawlSourcePage(url,filedir,filename,CrawledURLs):
print url
page = __getpage(url)
if page=="error":
return
CrawledURLs.append(url)
page = page.decode('gbk', 'ignore')
tree = etree.HTML(page)
Nodes = tree.xpath("http://div[@align='left']//table//a")
try:
source = filedir + "/" + filename + ".txt"
f = open(source.decode("utf-8"), 'w')
for node in Nodes:
sourceurl = node.xpath("text()")[0]
f.write(sourceurl.encode("utf-8")+"\n")
f.close()
except:
print "!!!!!!!!!!!!!!!!!" 

這段就比較簡單了,將提取出來的內容寫到一個文件中就行了

  為了能夠提高程序的運行效率,使用了多線程進行抓取,在這里我是為每一個分類的主頁都開辟了一個線程,這樣極大地加快了爬蟲的效率。想當初,只是用單線程去跑,結果等了一下午最后因為一個異常沒處理到結果一下午都白跑了?。。?!心累

class myThread (threading.Thread): #繼承父類threading.Thread
def __init__(self, url, newdir,CrawledURLs):
threading.Thread.__init__(self)
self.url = url
self.newdir = newdir
self.CrawledURLs=CrawledURLs
def run(self): #把要執(zhí)行的代碼寫到run函數里面 線程在創(chuàng)建后會直接運行run函數
CrawListPage(self.url, self.newdir,self.CrawledURLs) 

以上只是部分代碼,全部代碼可以到GitHub上面去下載(點我跳轉

最后爬取的結果如下。

以上所述是小編給大家介紹的使用Python多線程爬蟲爬取電影天堂資源 ,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

相關文章

  • 分數霸榜! python助你微信跳一跳拿高分

    分數霸榜! python助你微信跳一跳拿高分

    分數霸榜!這篇文章主要為大家詳細介紹了python助你微信跳一跳拿高分的秘籍,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • 淺析Python中正則表達式函數search()和match()的使用

    淺析Python中正則表達式函數search()和match()的使用

    在Python中,正則表達式是處理字符串的強大工具,search()和match()是Python標準庫中re模塊中兩個常用的正則表達式方法,本文將詳細講解這兩個方法的使用,需要的可以參考一下
    2023-08-08
  • python寫一個md5解密器示例

    python寫一個md5解密器示例

    這篇文章主要介紹了python寫一個md5解密器示例,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • Python pip安裝模塊提示錯誤解決方案

    Python pip安裝模塊提示錯誤解決方案

    這篇文章主要介紹了Python pip安裝模塊提示錯誤解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-05-05
  • Python做智能家居溫濕度報警系統(tǒng)

    Python做智能家居溫濕度報警系統(tǒng)

    本文為大家?guī)砹薖ython通過HTTP協(xié)議做一個廉價的溫濕度報警系統(tǒng)。感興趣的朋友跟隨小編一起看看吧
    2018-09-09
  • 使用Python繪制三種概率曲線詳解

    使用Python繪制三種概率曲線詳解

    這篇文章主要為大家分享了如何利用Python實現概率曲線的繪制,文中繪制了正態(tài)分布的曲線和指數分布的曲線,感興趣的可以了解一下
    2022-03-03
  • Python簡單實現TCP包發(fā)送十六進制數據的方法

    Python簡單實現TCP包發(fā)送十六進制數據的方法

    這篇文章主要介紹了Python簡單實現TCP包發(fā)送十六進制數據的方法,結合實例形式簡單分析了Python實現TCP數據傳輸及發(fā)送十六進制數據包的相關技巧,需要的朋友可以參考下
    2016-04-04
  • Appium+Python+pytest自動化測試框架的實戰(zhàn)

    Appium+Python+pytest自動化測試框架的實戰(zhàn)

    本文主要介紹了Appium+Python+pytest自動化測試框架的實戰(zhàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • Python讀寫文件方法總結

    Python讀寫文件方法總結

    這篇文章主要介紹了Python讀寫文件方法,實例分析了Python讀寫文件常用的方法與使用技巧,需要的朋友可以參考下
    2015-06-06
  • python 判斷一組數據是否符合正態(tài)分布

    python 判斷一組數據是否符合正態(tài)分布

    這篇文章主要介紹了python 如何判斷一組數據是否符合正態(tài)分布,幫助大家更好的利用python分析數據,感興趣的朋友可以了解下
    2020-09-09

最新評論