iT邦幫忙

第 11 屆 iThome 鐵人賽

DAY 23
1

寫了好幾天的爬蟲,不知道大家有沒有感覺同一支程式中要關注的事情太多。目前我們爬蟲的流程大概是這樣:

  1. 發送請求,取得網頁 HTML 原始碼
    • 可能需要額外的重試或錯誤處理機制,以免請求失敗
    • 需要控制請求間隔,避免同時發送大量請求而被封鎖
    • 也許還有非同步或多執行緒的設計來提高爬取速度
  2. 載入 HTML 剖析器(例如 BeautifulSoup)
  3. 在網頁中定位並取得目標資料
  4. 找出其他目標連結網址
    • 可能需要額外處理相對路徑
  5. 儲存資料
    • 可能需要對資料做前處理(例如正規化、trimming)

每支爬蟲程式都包含了上述的邏輯,但不同目標網站的爬蟲,差異都只有在 3 和 4 兩個步驟,其他部分基本上都是相同的。隨著爬蟲數量增加,相同的程式片段會越來越多,雖然可以用封裝的方式將相同邏輯都提取到父類別中,但父類別可能也會越來越龐大。如果可以用 AOP 的方式,把不同功能的程式碼都隔離開,未來維護擴充都會方便許多。

藉由類似 Scrapy 的爬蟲框架,可以節省不少開發成本,接下來幾天就會跟大家一起了解 Scrapy 的功能。

Scrapy 架構

Scrapy 框架的架構如下圖:

https://ithelp.ithome.com.tw/upload/images/20191007/20107875dz9S5phFE7.png

圖片來源:Architecture overview — Scrapy 1.7.3 documentation

資料流

Scrapy 中的資料流向都是由圖片正中央的 Scrapy Engine 來控制,一次完整的流程會是:

  1. Engine 收到 Spider 發來的首次請求
  2. Engine 把剛剛收到的請求加進 Scheduler 的排程中,同時要求其提供接下來要爬取的請求
  3. Scheduler 回傳下次要爬取的請求Engine
  4. Engine請求發送給 Downloader,發送的過程可能會經過數個 Downloader Middlewares
  5. 網頁原始碼下載完成後,由 Downloader 產生一個回應並送回 Engine,過程也可能會經過數個 Downloader Middlewares
  6. Engine 收到 Download 傳來的回應後,傳給 Spider 做處理,過程可能會經過數個 Spider Middlewares
  7. Spider 處理回應後,將爬取到的項目和新的請求回傳給 Engine,過程也可能會經過數個 Spider Middlewares
  8. Engine項目傳給 Item Pipelines,同時告知 Scheduler 已處理完這個請求並要求其提供下一個請求
  9. 重複步驟 1~8,直到 Scheduler 中沒有新的請求

元件

  • Scrapy Engine:負責控制整個框架中的資料流和事件
  • Scheduler:將 Engine 送過來的請求加到佇列中;決定下一個要提供給 Engine 的請求
  • Downloader:負責發送請求和接收回應,並將回應傳回給 Engine
  • Spiders:實際在處理網站爬取邏輯的類別,會回傳爬取出的項目或新的請求給 Engine
  • Item Pipeline:一系列處理爬取項目的邏輯,例如資料清理、驗證或儲存
  • Downloader middlewares:處理 Engine 和 Downloader 之間傳遞的輸入輸出
  • Spider middlewares:處理 Engine 和 Spider 之間傳遞的輸入輸出

以 Scrapy 的架構來說,「爬蟲」只要專注在爬取時定位取得資料的邏輯就可以了,其他的邏輯都提取到 middlewarespipeline 中,或者由 Scrapy 自動完成。明天我們就可以來建立第一個 Scrapy 專案囉!

參考資料


上一篇
【Day 21】反反爬蟲 (2/2)
下一篇
【Day 23】準備 Scrapy 開發環境
系列文
爬蟲在手、資料我有 - 30 天 Scrapy 爬蟲實戰33
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

尚未有邦友留言

立即登入留言