Golang 網路爬蟲架構gocolly/colly 一

來源:互聯網
上載者:User
這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。

Golang 網路爬蟲架構gocolly/colly 一

gocolly是用go實現的網路爬蟲架構,目前在github上具有3400+星,名列go版爬蟲程式榜首。gocolly快速優雅,在單核上每秒可以發起1K以上請求;以回呼函數的形式提供了一組介面,可以實現任意類型的爬蟲;依賴goquery庫可以像jquery一樣選擇web元素。

gocolly的官方網站是http://go-colly.org/,提供了詳細的文檔和範例程式碼。安裝colly:

 

go get -u github.com/gocolly/colly/...

  

 

在代碼中匯入包:

import "github.com/gocolly/colly"

  

colly的主體是Collector對象,管理網路通訊和負責在作業運行時執行附加的回掉函數。使用colly需要先初始化Collector:

c := colly.NewCollector()

   

可以向colly附加各種不同類型的回掉函數,來控制收集作業或擷取資訊。增加回掉函數:

 

c.OnRequest(func(r *colly.Request) {    fmt.Println("Visiting", r.URL)})c.OnError(func(_ *colly.Response, err error) {    log.Println("Something went wrong:", err)})c.OnResponse(func(r *colly.Response) {    fmt.Println("Visited", r.URL)})c.OnHTML("a[href]", func(e *colly.HTMLElement) {    e.Request.Visit(e.Attr("href"))})c.OnHTML("tr td:nth-of-type(1)", func(e *colly.HTMLElement) {    fmt.Println("First column of a table row:", e.Text)})c.OnScraped(func(r *colly.Response) {    fmt.Println("Finished", r.URL)})

  

 

回掉函數的調用順序如下:

1. OnRequest

在發起請求前被調用

2. OnError

請求過程中如果發生錯誤被調用

3. OnResponse

收到回複後被調用

4. OnHTML

在OnResponse之後被調用,如果收到的內容是HTML

5. OnScraped

在OnHTML之後被調用

 

官方提供的Basic範例程式碼:

 

package main import (    "fmt"     "github.com/gocolly/colly") func main() {    // Instantiate default collector    c := colly.NewCollector()     // Visit only domains: hackerspaces.org, wiki.hackerspaces.org    c.AllowedDomains = []string{"hackerspaces.org", "wiki.hackerspaces.org"}     // On every a element which has href attribute call callback    c.OnHTML("a[href]", func(e *colly.HTMLElement) {        link := e.Attr("href")        // Print link        fmt.Printf("Link found: %q -> %s\n", e.Text, link)        // Visit link found on page        // Only those links are visited which are in AllowedDomains        c.Visit(e.Request.AbsoluteURL(link))    })     // Before making a request print "Visiting ..."    c.OnRequest(func(r *colly.Request) {        fmt.Println("Visiting", r.URL.String())    })     // Start scraping on https://hackerspaces.org    c.Visit("https://hackerspaces.org/")}

  

 

 

該執行個體程式僅訪問hackerspaces.org域內的連結,OnHTML回掉函數的選取器為a[href],選擇頁面內具有href屬性的a類型元素,找到連結後繼續抓取。 啟動並執行部分結果如下:

PS E:\mygo\src\github.com\gocolly\colly\_examples\basic> .\basic.exeVisiting https://hackerspaces.org/Link found: "navigation" -> #column-oneLink found: "search" -> #searchInputLink found: "" -> /File:Cbase07.jpgVisiting https://hackerspaces.org/File:Cbase07.jpgLink found: "navigation" -> #column-oneLink found: "search" -> #searchInputLink found: "File" -> #fileLink found: "File history" -> #filehistoryLink found: "File usage" -> #filelinksLink found: "" -> /images/e/ec/Cbase07.jpgVisiting https://hackerspaces.org/images/e/ec/Cbase07.jpgLink found: "800 × 600 pixels" -> /images/thumb/e/ec/Cbase07.jpg/800px-Cbase07.jpgVisiting https://hackerspaces.org/images/thumb/e/ec/Cbase07.jpg/800px-Cbase07.jpg

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.