0
点赞
收藏
分享

微信扫一扫

go语言学习-爬虫案例

go语言学习,两个简单的爬虫案例

爬取QQ邮箱

package main

/*
明确目标
爬-爬下内容
取-筛选想要
处理数据
*/

import (
"fmt"
"io/ioutil"
"net/http"
"regexp"
)

//获取QQ邮箱,简单版本,没有封装,爬出的数据也没有去重

var (
// \d 正则 ,代表数字
ReQQEamil = `(\d+)@qq.com`
)

//爬取邮箱
func GetEmail() {
//网站拿取数据
resp, err := http.Get("https://tieba.baidu.com/p/6051076813?red_tag=1573533731")
HandleError(err, "http.Get url")
//延迟关闭
defer resp.Body.Close()

//读取页面内容
PageBytes, err := ioutil.ReadAll(resp.Body)
HandleError(err, "ioutil.ReadAll")

//字节转换字符串
PageStr := string(PageBytes)

//过滤数据,过滤qq邮箱
re := regexp.MustCompile(ReQQEamil)

// -1代表取出全部

results := re.FindAllStringSubmatch(PageStr, -1)
//遍历结果

for _, result := range results {
fmt.Println("email:", result[0])
fmt.Println("qq:", result[1])
}

}

//自定义异常处理函数
func HandleError(err error, why string) {
if err != nil {
fmt.Println(why, err)
}
}

//主程序入口
func main() {
GetEmail()
}

爬取连接,图片

package main

/*
re := regexp.MustCompile(reStr),传入正则表达式,得到正则表达式对象
ret := re.FindAllStringSubmatch(srcStr,-1):用正则对象,获取页面页面,srcStr是页面内容,-1代表取全部
*/

import (
"fmt"
"io/ioutil"
"net/http"
"regexp"
)

var (
// w代表大小写字母+数字+下划线
reEmail = `\w+@\w+\.\w+`
// s?有或者没有s
// +代表出1次或多次
//\s\S各种字符
// +?代表贪婪模式
reLinke = `href="(https?://[\s\S]+?)"`
rePhone = `1[3456789]\d\s?\d{4}\s?\d{4}`
reIdcard = `[123456789]\d{5}((19\d{2})|(20[01]\d))((0[1-9])|(1[012]))((0[1-9])|([12]\d)|(3[01]))\d{3}[\dXx]`
reImg = `https?://[^"]+?(\.((jpg)|(png)|(jpeg)|(gif)|(bmp)))`
)

// 处理异常
func HandleError(err error, why string) {
if err != nil {
fmt.Println(why, err)
}
}

func GetEmail2(url string) {
pageStr := GetPageStr(url)
re := regexp.MustCompile(reEmail)
results := re.FindAllStringSubmatch(pageStr, -1)
for _, result := range results {
fmt.Println(result)
}
}

// 抽取根据url获取内容
func GetPageStr(url string) (pageStr string) {
resp, err := http.Get(url)
HandleError(err, "http.Get url")
defer resp.Body.Close()
// 2.读取页面内容
pageBytes, err := ioutil.ReadAll(resp.Body)
HandleError(err, "ioutil.ReadAll")
// 字节转字符串
pageStr = string(pageBytes)
return pageStr
}

func GetIdCard(url string) {
pageStr := GetPageStr(url)
re := regexp.MustCompile(reIdcard)
results := re.FindAllStringSubmatch(pageStr, -1)
for _, result := range results {
fmt.Println(result)
}
}

// 爬链接
func GetLink(url string) {
pageStr := GetPageStr(url)
re := regexp.MustCompile(reLinke)
results := re.FindAllStringSubmatch(pageStr, -1)
for _, result := range results {
fmt.Println(result[1])
}
}

//爬手机号
func GetPhone(url string) {
pageStr := GetPageStr(url)
re := regexp.MustCompile(rePhone)
results := re.FindAllStringSubmatch(pageStr, -1)
for _, result := range results {
fmt.Println(result)
}
}

func GetImg(url string) {
pageStr := GetPageStr(url)
re := regexp.MustCompile(reImg)
results := re.FindAllStringSubmatch(pageStr, -1)
for _, result := range results {
fmt.Println(result[0])
}
}

func main() {
//2.抽取的爬邮箱
GetEmail2("https://tieba.baidu.com/p/6051076813?red_tag=1573533731")
//3.爬链接
GetLink("http://www.baidu.com/s?wd=%E8%B4%B4%E5%90%A7%20%E7%95%99%E4%B8%8B%E9%82%AE%E7%AE%B1&rsv_spt=1&rsv_iqid=0x98ace53400003985&issp=1&f=8&rsv_bp=1&rsv_idx=2&ie=utf-8&tn=baiduhome_pg&rsv_enter=1&rsv_dl=ib&rsv_sug2=0&inputT=5197&rsv_sug4=6345")
//4.爬手机号
GetPhone("https://www.zhaohaowang.com/")
//5.爬身份证号
GetIdCard("https://henan.qq.com/a/20171107/069413.htm")
//6.爬图片
GetImg("http://image.baidu.com/search/index?tn=baiduimage&ps=1&ct=201326592&lm=-1&cl=2&nc=1&ie=utf-8&word=%E7%BE%8E%E5%A5%B3")
}

举报

相关推荐

0 条评论