Golang 網路爬蟲框架gocolly/colly

犀牛小牛發表於2019-01-15

Golang 實現的網路爬蟲框架,名列 go 版爬蟲程式榜首。

安裝

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

例子

import (    "fmt"    "github.com/gocolly/colly")func main() {    c := colly.NewCollector()    c.OnResponse(func(r *colly.Response) {        fmt.Println("IP:", string(r.Body))    })    //c.SetProxy(")    c.Visit(")}

SetProxy 函式可以用來配置 HTTP 代理。

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

c := colly.NewCollector()

vgo

vgo Go 語言推出的第三方庫管理工具,在 Go 語言新版本中使用。

常用的命令列:

·  go help mod  檢視幫助。

·  go mod init < 專案模組名稱 > 初始化模組,會在專案根目錄下生成   go.mod   檔案,是可以自己手動編輯的。

依賴包大多在 Github 上,安裝依賴可能會出現連線超時等問題,可以配置全域性 git 代理:

git config --global http.proxy config --global https.proxy 取消代理: git config --global --unset http.proxygit config --global --unset https.proxy

cmd shadowsocks 代理:

set http_proxy=127.0.0.1:1080set https_proxy=127.0.0.1:1080curl cip.ccIP    : 140.206.97.42 地址     :  中國    上海資料二     :  上海市  聯通 URL    :

Linux 使用 export 設定環境變數,程式碼同上。

回掉函式的呼叫順序

1.  OnRequest  在發起請求前被呼叫。

2.  OnError  請求過程中如果發生錯誤被呼叫。

3.  OnResponse  收到回覆後被呼叫。

4.  OnHTML  OnResponse 之後被呼叫,如果收到的內容是 HTML 

5.  OnScraped  OnHTML 之後被呼叫。

官方提供的 程式碼:

package mainimport (    "fmt"    "github.com/gocolly/colly")func main() {    // Instantiate default collector    c := colly.NewCollector(        // Visit only domains: hackerspaces.org, wiki.hackerspaces.org        colly.AllowedDomains("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  c.Visit(")}

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

Visiting found: "navigation" -> #column-oneLink found: "search" -> #searchInputLink found: "" -> /File:Cbase07.jpgVisiting 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

 

本文轉載自:

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31555707/viewspace-2558361/,如需轉載,請註明出處,否則將追究法律責任。

相關文章