设为首页 收藏本站
查看: 1128|回复: 0

[经验分享] Golang 网络爬虫框架gocolly/colly 一

[复制链接]

尚未签到

发表于 2018-9-20 10:44:54 | 显示全部楼层 |阅读模式
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.exe  

  
Visiting https:
//hackerspaces.org/  

  
Link found: "navigation" -> #column-one
  

  
Link found: "search" -> #searchInput
  

  
Link found: "" -> /File:Cbase07.jpg
  

  
Visiting https://hackerspaces.org/File:Cbase07.jpg
  

  
Link found: "navigation" -> #column-one
  

  
Link found: "search" -> #searchInput
  

  
Link found: "File" -> #file
  

  
Link found: "File history" -> #filehistory
  

  
Link found: "File usage" -> #filelinks
  

  
Link found: "" -> /images/e/ec/Cbase07.jpg
  

  
Visiting https://hackerspaces.org/images/e/ec/Cbase07.jpg
  

  
Link found: "800 × 600 pixels" -> /images/thumb/e/ec/Cbase07.jpg/800px-Cbase07.jpg
  

  
Visiting https://hackerspaces.org/images/thumb/e/ec/Cbase07.jpg/800px-Cbase07.jpg
  




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-598758-1-1.html 上篇帖子: golang 自定义封包协议(转的) 下篇帖子: 一个有关Golang变量作用域的坑
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表