Python爬蟲知識點梳理

来源:https://www.cnblogs.com/yuxiang1/archive/2020/07/14/13301062.html
-Advertisement-
Play Games

做數據分析和任何一門技術一樣,都應該帶著目標去學習,目標就像一座燈塔,指引你前進,很多人學著學著就學放棄了,很大部分原因是沒有明確目標,所以,一定要明確學習目的,在你準備學爬蟲前,先問問自己為什麼要學習爬蟲。有些人是為了一份工作,有些人是為了好玩,也有些人是為了實現某個黑科技功能。不過可以肯定的是,... ...


Python入門教程免費領取 https://www.cnblogs.com/yuxiang1/p/13301047.html   做數據分析和任何一門技術一樣,都應該帶著目標去學習,目標就像一座燈塔,指引你前進,很多人學著學著就學放棄了,很大部分原因是沒有明確目標,所以,一定要明確學習目的,在你準備學爬蟲前,先問問自己為什麼要學習爬蟲。有些人是為了一份工作,有些人是為了好玩,也有些人是為了實現某個黑科技功能。不過可以肯定的是,學會了爬蟲能給你的工作提供很多便利。   小白入門必讀 作為零基礎小白,大體上可分為三個階段去實現。 第一階段是入門,掌握必備基礎知識,比如Python基礎、網路請求的基本原理等; 第二階段是模仿,跟著別人的爬蟲代碼學,弄懂每一行代碼,熟悉主流的爬蟲工具, 第三階段是自己動手,到了這個階段你開始有自己的解題思路了,可以獨立設計爬蟲系統。   爬蟲涉及的技術包括但不限於熟練一門編程語言(這裡以 Python 為例) HTML 知識、HTTP 協議的基本知識、正則表達式、資料庫知識,常用抓包工具的使用、爬蟲框架的使用、涉及到大規模爬蟲,還需要瞭解分散式的概念、消息隊列、常用的數據結構和演算法、緩存,甚至還包括機器學習的應用,大規模的系統背後都是靠很多技術來支撐的。數據分析、挖掘、甚至是機器學習都離不開數據,而數據很多時候需要通過爬蟲來獲取,因此,即使把爬蟲作為一門專業來學也是有很大前途的。   那麼是不是一定要把上面的知識全學完了才可以開始寫爬蟲嗎?當然不是,學習是一輩子的事,只要你會寫 Python 代碼了,就直接上手爬蟲,好比學車,只要能開動了就上路吧,寫代碼可比開車安全多了。   用 Python 寫爬蟲 首先需要會 Python,把基礎語法搞懂,知道怎麼使用函數、類、list、dict 中的常用方法就算基本入門。接著你需要瞭解 HTML,HTML 就是一個文檔樹結構,網上有個 HTML 30分鐘入門教程 https://deerchao.net/tutorials/html/html.htm 夠用了。   關於 HTTP 的知識 爬蟲基本原理就是通過網路請求從遠程伺服器下載數據的過程,而這個網路請求背後的技術就是基於 HTTP 協議。作為入門爬蟲來說,你需要瞭解 HTTP協議的基本原理,雖然 HTTP 規範用一本書都寫不完,但深入的內容可以放以後慢慢去看,理論與實踐相結合。   網路請求框架都是對 HTTP 協議的實現,比如著名的網路請求庫 Requests 就是一個模擬瀏覽器發送 HTTP 請求的網路庫。瞭解 HTTP 協議之後,你就可以專門有針對性的學習和網路相關的模塊了,比如 Python 自帶有 urllib、urllib2(Python3中的urllib),httplib,Cookie等內容,當然你可以直接跳過這些,直接學習 Requests 怎麼用,前提是你熟悉了 HTTP協議的基本內容,數據爬下來,大部分情況是 HTML 文本,也有少數是基於 XML 格式或者 Json 格式的數據,要想正確處理這些數據,你要熟悉每種數據類型的解決方案,比如 JSON 數據可以直接使用 Python自帶的模塊 json,對於 HTML 數據,可以使用 BeautifulSoup、lxml 等庫去處理,對於 xml 數據,除了可以使用 untangle、xmltodict 等第三方庫。此外,在我的公眾號也總結了好幾篇爬蟲入門與實戰的文章 http://t.cn/RQrWESe , 可以當做練手   爬蟲工具 爬蟲工具裡面,學會使用 Chrome 或者 FireFox 瀏覽器去審查元素,跟蹤請求信息等等,現在大部分網站有配有APP和手機瀏覽器訪問的地址,優先使用這些介面,相對更容易。還有 Fiddler 等代理工具的使用。   入門爬蟲,學習正則表達式並不是必須的,你可以在你真正需要的時候再去學,比如你把數據爬取回來後,需要對數據進行清洗,當你發現使用常規的字元串操作方法根本沒法處理時,這時你可以嘗試瞭解一下正則表達式,往往它能起到事半功倍的效果。Python 的 re 模塊可用來處理正則表達式。這裡也推薦一個教程:Python正則表達式指南https://www.cnblogs.com/huxi/archive/2010/07/04/1771073.html   數據清洗 數據清洗完最終要進行持久化存儲,你可以用文件存儲,比如CSV文件,也可以用資料庫存儲,簡單的用 SQLite,專業點用 MySQL,或者是分散式的文檔資料庫 MongoDB,這些資料庫對Python都非常友好,有現成的庫支持,你要做的就是熟悉這些 API 怎麼使用。   進階之路 從數據的抓取到清洗再到存儲的基本流程都走完了,也算是基本入門了,接下來就是考驗內功的時候了,很多網站都設有反爬蟲策略,他們想方設法阻止你用非正常手段獲取數據,比如會有各種奇奇怪怪的驗證碼限制你的請求操作、對請求速度做限制,對IP做限制、甚至對數據進行加密操作,總之,就是為了提高獲取數據的成本。   這時你需要掌握的知識就要更多了,你需要深入理解 HTTP 協議,你需要理解常見的加解密演算法,你要理解 HTTP 中的 cookie,HTTP 代理,HTTP中的各種HEADER。爬蟲與反爬蟲就是相愛相殺的一對,道高一次魔高一丈。   如何應對反爬蟲沒有既定的統一的解決方案,靠的是你的經驗以及你所掌握的知識體系。這不是僅憑21天入門教程就能達到的高度。   進行大規模爬蟲,通常都是從一個URL開始爬,然後把頁面中解析的URL鏈接加入待爬的URL集合中,我們需要用到隊列或者優先隊列來區別對待有些網站優先爬,有些網站後面爬。   每爬去一個頁面,是使用深度優先還是廣度優先演算法爬取下一個鏈接。每次發起網路請求的時候,會涉及到一個DNS的解析過程(將網址轉換成IP)為了避免重覆地 DNS 解析,我們需要把解析好的 IP 緩存下來。URL那麼多,如何判斷哪些網址已經爬過,哪些沒有爬過,簡單點就是是使用字典結構來存儲已經爬過的的URL,但是如果碰過海量的URL時,字典占用的記憶體空間非常大,此時你需要考慮使用 Bloom Filter(布隆過濾器),用一個線程逐個地爬取數據,效率低得可憐,如果提高爬蟲效率,是使用多線程,多進程還是協程,還是分散式操作,都需要反覆實踐。  
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • C語言簡介 C 語言是一種通用的高級語言,最初是由丹尼斯·里奇在貝爾實驗室為開發 UNIX 操作系統而設計的。C 語言最開始是於 1972 年在 DEC PDP-11 電腦上被首次實現。 原文鏈接:https://juejin.im/post/5df8c917f265da339772a5d1#he ...
  • 字元串相關的類:String String類:代表字元串,Java 程式中的所有字元串字面值(如 "abc" )都作 為此類的實例實現。 String是一個final類,代表不可變的字元序列 當字元串重新賦值時,需要重新指定記憶體區域,不能使用原有的value進行賦值 當對現有的字元串進行連接操作時, ...
  • 基礎數據類型 在變數的定義中,我們講了每個變數是有類型的,類型在電腦中是用來約束數據的解釋。Go語言和其它電腦語言一樣,提供豐富了豐富的數據類型,我們就來看看到底有哪些類型,同時也可以比較一下它和其它語言的區別。 整型 整型就是用來表示變數是整數的類型。和C類似,Go整型分為兩個大類,無符號和有 ...
  • 作者: zyl910 一、緣由 現在zip類的文件越來越多了,例如jar、docx。 有時我們需批量處理這些文件中的數據,若都是手工操作的話就太麻煩了。於是考慮編程自動處理。 Java提供了ZipInputStream等zip的操作類。但是有些內容比較抽象,沒有代碼範例的話有點難以理解。例如zip中 ...
  • 前言 本文的文字及圖片來源於網路,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯繫我們以作處理。 首先,瞭解下什麼是JSON? JSON:JavaScript Object Notation 【JavaScript 對象表示法】 JSON 是一種輕量級的數據交換格式,完全 ...
  • 隨著時間的積累,應用的使用用戶不斷增加,數據規模也越來越大,往往資料庫查詢操作會成為影響用戶使用體驗的瓶頸,此時使用緩存往往是解決這一問題非常好的手段之一。Spring 3開始提供了強大的基於註解的緩存支持,可以通過註解配置方式低侵入的給原有Spring應用增加緩存功能,提高數據訪問性能。 在Spr ...
  • 告警 正在開會,突然釘釘告警聲響個不停,同時市場人員反饋客戶在投訴系統登不進了,報504錯誤。查看釘釘上的告警信息,幾台業務伺服器節點全部報CPU超過告警閾值,達100%。 趕緊從會上下來,SSH登錄伺服器,使用 top 命令查看,幾個Java進程CPU占用達到180%,190%,這幾個Java進程 ...
  • 前言 本文的文字及圖片來源於網路,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯繫我們以作處理。 環境: Win7系統,外網未連接,主機接有返聽音箱。 準備: 這裡明顯要用語音合成,既然是離線狀態,肯定沒法調用百度AI之類的介面。裝一個離線語音包又有點興師動眾,所以乾脆我 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...