goquery初试-房价信息爬取

  这次准备试试goquery库,来爬取我房网的房价信息。首先要安装goquery,参考当go get遇到墙时,安装好库就可以开始。
  比较重要的就是观察页面布局,元素特征。

观察整体页面布局
楼盘名称
楼盘位置

  本次爬虫只要有房价的楼盘信息,代码如下:

package main

import (
    "fmt"
    "strconv"
    "time"
    "github.com/PuerkitoBio/goquery"
    "log"
    "bytes"
    "encoding/csv"
    "os"
)
func p() {
    a:=0
    fileName := "wofang.csv"
    buf := new(bytes.Buffer)
    r2 := csv.NewWriter(buf)
    for i := 1; i <=202; i++ {
        fmt.Println("正在抓取第" + strconv.Itoa(i) + "页......")
        url := "http://www.wofang.com/building/p/" + strconv.Itoa(i) + "/"
        if i==1{
            url= "http://www.wofang.com/building/"
        }
        doc, err := goquery.NewDocument(url)
        if err != nil {
            log.Fatal(err)
        }
        doc.Find(".m ul li").Each(func(i int, s *goquery.Selection) {
                name:= s.Find(".title a").Text()
                location:= s.Find(".time").Text()
                price:=s.Find(".sale-price font").Text()
                if price!="" {
                    a++
                    s := make([]string,3)
                    s[0] = name
                    s[1] = price
                    s[2] = location
                    r2.Write(s)
                    r2.Flush()
                    fmt.Printf("%s,%s,%s\n", name,price, location)
                }
        })
    }
    fout,err := os.Create(fileName)
    defer fout.Close()
    if err != nil {
        fmt.Println(fileName,err)
        return
    }
    fout.WriteString(buf.String())
    fmt.Print(a)
}
func main() {
    t1 := time.Now() // get current time
    p()
    elapsed := time.Since(t1)
    fmt.Println("")
    fmt.Println("爬虫结束,总共耗时: ", elapsed)
}

爬取效果

  最后根据链接规律(大致就是:http://www.wofang.com/building/" + 地市键值+ "-te_住宅/",键值用的比较笨的方法手动一个个点出来的)爬一下各地市的信息并用echart做可视化。(本文仅供参考)
s数据可视化效果

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,786评论 25 709
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,868评论 1 92
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,281评论 19 139
  • ​ 吾日三省吾身:白吗?富吗?美吗? 答曰:否。 01 北上广好像并没有那么喜欢我们,每到月底穷的都是刚刚好,说这...
    出版编辑王蕾阅读 294评论 0 0
  • 能力越大,责任越大。这话是没错的。拥有的越多,越要为你所拥有的负责。家庭、事业、财富、友谊……每一样都要花能量去打...
    鲤溯阅读 418评论 0 0