
用Python爬蟲獲取自己感興趣的博客文章
在CSDN上有很多精彩的技術(shù)博客文章,我們可以把它爬取下來,保存在本地磁盤,可以很方便以后閱讀和學(xué)習(xí),現(xiàn)在我們就用python編寫一段爬蟲代碼,來實(shí)現(xiàn)這個目的。
我們想要做的事情:自動讀取博客文章,記錄標(biāo)題,把心儀的文章保存到個人電腦硬盤里供以后學(xué)習(xí)參考。
過程大體分為以下幾步:
1. 找到爬取的目標(biāo)網(wǎng)址;
2. 分析網(wǎng)頁,找到自已想要保存的信息,這里我們主要保存是博客的文章內(nèi)容;
3. 清洗整理爬取下來的信息,保存在本地磁盤。
打開csdn的網(wǎng)頁,作為一個示例,我們隨機(jī)打開一個網(wǎng)頁:
http://blog.csdn.net/u013088062/article/list/1。
可以看到,博主對《C++卷積神經(jīng)網(wǎng)絡(luò)》和其它有關(guān)機(jī)計(jì)算機(jī)方面的文章都寫得不錯。
爬蟲代碼按思路分為三個類(class),下面3個帶“#”的分別給出了每一個類的開頭(具體代碼附后,供大家實(shí)際運(yùn)行實(shí)現(xiàn)):
采用“類(class)”的方式屬于Python的面向?qū)ο缶幊蹋谀承r候比我們通常使用的面向過程的編程方便,在大型工程中經(jīng)常使用面向?qū)ο缶幊?。對于初學(xué)者來說,面向?qū)ο缶幊滩灰渍莆?,但是?jīng)過學(xué)習(xí)習(xí)慣之后,會逐步慢慢從面向過程到面向?qū)ο缶幊踢^渡。
特別注意的是,RePage類主要用正則表達(dá)式處理從網(wǎng)頁中獲取的信息,正則表達(dá)式設(shè)置字符串樣式如下:
用正則表達(dá)式去匹配所要爬取的內(nèi)容,用Python和其它軟件工具都可以實(shí)現(xiàn)。正則表達(dá)式有許多規(guī)則,各個軟件使用起來大同小異。用好正則表達(dá)式是爬蟲和文本挖掘的一個重要內(nèi)容。
SaveText類則是把信息保存在本地,效果如下:
用python編寫爬蟲代碼,簡潔高效。這篇文章僅從爬蟲最基本的用法做了講解,有興趣的朋友可以下載代碼看看,希望大家從中有收獲。
附相關(guān)Python代碼:
1#-*-coding:UTF-8-*-
2import re
3import urllib2
4import sys
5#目的:讀取博客文章,記錄標(biāo)題,用Htnl格式保存存文章內(nèi)容
6#版本:python2.7.13
7#功能:讀取網(wǎng)頁內(nèi)容
8class GetHtmlPage():
9 #注意大小寫
10 def __init__(self,strPage):
11 self.strPapge = strPage
12 #獲取網(wǎng)頁
13 def GetPage(self):
14 req = urllib2.Request(self.strPapge) # 建立頁面請求
15 rep = req.add_header("User-Agent","Mozilla/5.0
(Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko)
Chrome/38.0.2125.122 Safari/537.36 SE 2.X MetaSr 1.0")
16 try:
17 cn = urllib2.urlopen(req) #網(wǎng)頁請求
18 page = cn.read() #讀網(wǎng)頁
19 uPage = page.decode("utf-8") #網(wǎng)頁編碼
20 cn.close()
21 return uPage
22 except urllib2.URLError, e: #捕獲異常
23 print 'URLError:', e.code
24 return
25 except urllib2.HTTPError, e: #捕獲異常
26 print 'HTTP Error:' + e.reason
27 return
28 return rePage
29#正則表達(dá)式,獲取想要的內(nèi)容
30class RePage():
31#正則表達(dá)式提取內(nèi)容,返回鏈表
32 def GetReText(self,page,recode):
33 rePage = re.findall(recode,page,re.S)
34 return rePage
35#保存文本
36class SaveText():
37 def Save(self,text,tilte):
38 try:
39 t="blog\\"+tilte+".html"
40 f = file(t,"a")
41 f.write(text)
42 f.close()
43 except IOError,e:
44 print e.message
45if __name__ == "__main__":
46 s = SaveText()
47 #文件編碼
48 #字符正確解碼
49 reload(sys)
50 sys.setdefaultencoding( "utf-8" ) #獲得系統(tǒng)的默認(rèn)編碼
51 #獲取網(wǎng)頁
52 page = GetHtmlPage("http://blog.csdn.net/u013088062/article/list/1")
53 htmlPage = page.GetPage()
54 #提取內(nèi)容
55 reServer = RePage()
56 reBlog = reServer.GetReText(htmlPage,r'<span
class="link_title"><a
href="(.+?)">.*?(\s.+?)</a></span>') #獲取網(wǎng)址鏈接和標(biāo)題
57 #再向下獲取正文
58 for ref in reBlog:
59 pageHeard = "http://blog.csdn.net/" #加鏈接頭
60 strPage = pageHeard+ref[0]
61 tilte=ref[1].replace('<font color="red">[置頂]</font>', "") #用替換的功能去除雜的英文
62 tilte=tilte.replace("\r\n","").lstrip().rstrip()
63 #獲取正文
64 htmlPage = GetHtmlPage(strPage)
65 htmlPageData = htmlPage.GetPage()
66 reBlogText = reServer.GetReText(htmlPageData,'<div
id="article_content" class="article_content">(.+?)</div>')
67 #保存文件
68 for s1 in reBlogText:
69 s1='<meta charset="UTF-8">\n'+s1
70 s.Save(s1,tilte)
根據(jù)上期學(xué)員的反饋和優(yōu)化,接下來覃老師主講Python數(shù)據(jù)挖掘課程變成4天,跟著覃老師一起領(lǐng)悟數(shù)據(jù)挖掘算法在行業(yè)應(yīng)用。強(qiáng)化的培訓(xùn),應(yīng)該讓你可以學(xué)完后很自信,學(xué)以致用,快速上手解決工作中的問題。
4天課程內(nèi)容足夠豐富,想學(xué)習(xí)的朋友報名從速,點(diǎn)擊閱讀原文,查看課程詳情,繳費(fèi)后獲得預(yù)習(xí)視頻和資料。
在線咨詢:
張老師
座機(jī):010-68456523
QQ:2881989712
掃碼添加微信
數(shù)據(jù)分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
LSTM 模型輸入長度選擇技巧:提升序列建模效能的關(guān)鍵? 在循環(huán)神經(jīng)網(wǎng)絡(luò)(RNN)家族中,長短期記憶網(wǎng)絡(luò)(LSTM)憑借其解決長序列 ...
2025-07-11CDA 數(shù)據(jù)分析師報考條件詳解與準(zhǔn)備指南? ? 在數(shù)據(jù)驅(qū)動決策的時代浪潮下,CDA 數(shù)據(jù)分析師認(rèn)證愈發(fā)受到矚目,成為眾多有志投身數(shù) ...
2025-07-11數(shù)據(jù)透視表中兩列相乘合計(jì)的實(shí)用指南? 在數(shù)據(jù)分析的日常工作中,數(shù)據(jù)透視表憑借其強(qiáng)大的數(shù)據(jù)匯總和分析功能,成為了 Excel 用戶 ...
2025-07-11尊敬的考生: 您好! 我們誠摯通知您,CDA Level I和 Level II考試大綱將于 2025年7月25日 實(shí)施重大更新。 此次更新旨在確保認(rèn) ...
2025-07-10BI 大數(shù)據(jù)分析師:連接數(shù)據(jù)與業(yè)務(wù)的價值轉(zhuǎn)化者? ? 在大數(shù)據(jù)與商業(yè)智能(Business Intelligence,簡稱 BI)深度融合的時代,BI ...
2025-07-10SQL 在預(yù)測分析中的應(yīng)用:從數(shù)據(jù)查詢到趨勢預(yù)判? ? 在數(shù)據(jù)驅(qū)動決策的時代,預(yù)測分析作為挖掘數(shù)據(jù)潛在價值的核心手段,正被廣泛 ...
2025-07-10數(shù)據(jù)查詢結(jié)束后:分析師的收尾工作與價值深化? ? 在數(shù)據(jù)分析的全流程中,“query end”(查詢結(jié)束)并非工作的終點(diǎn),而是將數(shù) ...
2025-07-10CDA 數(shù)據(jù)分析師考試:從報考到取證的全攻略? 在數(shù)字經(jīng)濟(jì)蓬勃發(fā)展的今天,數(shù)據(jù)分析師已成為各行業(yè)爭搶的核心人才,而 CDA(Certi ...
2025-07-09【CDA干貨】單樣本趨勢性檢驗(yàn):捕捉數(shù)據(jù)背后的時間軌跡? 在數(shù)據(jù)分析的版圖中,單樣本趨勢性檢驗(yàn)如同一位耐心的偵探,專注于從單 ...
2025-07-09year_month數(shù)據(jù)類型:時間維度的精準(zhǔn)切片? ? 在數(shù)據(jù)的世界里,時間是最不可或缺的維度之一,而year_month數(shù)據(jù)類型就像一把精準(zhǔn) ...
2025-07-09CDA 備考干貨:Python 在數(shù)據(jù)分析中的核心應(yīng)用與實(shí)戰(zhàn)技巧? ? 在 CDA 數(shù)據(jù)分析師認(rèn)證考試中,Python 作為數(shù)據(jù)處理與分析的核心 ...
2025-07-08SPSS 中的 Mann-Kendall 檢驗(yàn):數(shù)據(jù)趨勢與突變分析的有力工具? ? ? 在數(shù)據(jù)分析的廣袤領(lǐng)域中,準(zhǔn)確捕捉數(shù)據(jù)的趨勢變化以及識別 ...
2025-07-08備戰(zhàn) CDA 數(shù)據(jù)分析師考試:需要多久?如何規(guī)劃? CDA(Certified Data Analyst)數(shù)據(jù)分析師認(rèn)證作為國內(nèi)權(quán)威的數(shù)據(jù)分析能力認(rèn)證 ...
2025-07-08LSTM 輸出不確定的成因、影響與應(yīng)對策略? 長短期記憶網(wǎng)絡(luò)(LSTM)作為循環(huán)神經(jīng)網(wǎng)絡(luò)(RNN)的一種變體,憑借獨(dú)特的門控機(jī)制,在 ...
2025-07-07統(tǒng)計(jì)學(xué)方法在市場調(diào)研數(shù)據(jù)中的深度應(yīng)用? 市場調(diào)研是企業(yè)洞察市場動態(tài)、了解消費(fèi)者需求的重要途徑,而統(tǒng)計(jì)學(xué)方法則是市場調(diào)研數(shù) ...
2025-07-07CDA數(shù)據(jù)分析師證書考試全攻略? 在數(shù)字化浪潮席卷全球的當(dāng)下,數(shù)據(jù)已成為企業(yè)決策、行業(yè)發(fā)展的核心驅(qū)動力,數(shù)據(jù)分析師也因此成為 ...
2025-07-07剖析 CDA 數(shù)據(jù)分析師考試題型:解鎖高效備考與答題策略? CDA(Certified Data Analyst)數(shù)據(jù)分析師考試作為衡量數(shù)據(jù)專業(yè)能力的 ...
2025-07-04SQL Server 字符串截取轉(zhuǎn)日期:解鎖數(shù)據(jù)處理的關(guān)鍵技能? 在數(shù)據(jù)處理與分析工作中,數(shù)據(jù)格式的規(guī)范性是保證后續(xù)分析準(zhǔn)確性的基礎(chǔ) ...
2025-07-04CDA 數(shù)據(jù)分析師視角:從數(shù)據(jù)迷霧中探尋商業(yè)真相? 在數(shù)字化浪潮席卷全球的今天,數(shù)據(jù)已成為企業(yè)決策的核心驅(qū)動力,CDA(Certifie ...
2025-07-04CDA 數(shù)據(jù)分析師:開啟數(shù)據(jù)職業(yè)發(fā)展新征程? ? 在數(shù)據(jù)成為核心生產(chǎn)要素的今天,數(shù)據(jù)分析師的職業(yè)價值愈發(fā)凸顯。CDA(Certified D ...
2025-07-03