集搜客GooSeeker网络爬虫

标题: Python爬虫实战(4):豆瓣小组话题数据采集---动态网页 [打印本页]

作者: shenzhenwan10    时间: 2016-7-11 14:58
标题: Python爬虫实战(4):豆瓣小组话题数据采集---动态网页
1, 引言

注释:上一篇《Python爬虫实战(3):安居客房产经纪人信息采集》,访问的网页是静态网页,有朋友模仿那个实战来采集动态加载豆瓣小组的网页,结果不成功。本篇是针对动态网页的数据采集编程实战。

Python开源网络爬虫项目启动之初,我们就把网络爬虫分成两类:即时爬虫和收割式网络爬虫。为了适应各种应用场景,GooSeeker的整个网络爬虫产品线包含了四类产品,如下图所示:


[attach]1085[/attach]


本实战是上图中的“独立python爬虫”的一个实例,以采集豆瓣小组讨论话题(https://www.douban.com/group/haixiuzu/discussion?start=0 )信息为例,记录整个采集流程,包括python和依赖库的安装,即便是python初学者,也可以跟着文章内容成功地完成运行。

2,Python和相关依赖库的安装


2.1,安装Python3.5.2


2.2,Lxml 3.6.0

2.3,下载网页内容提取器程序


网页内容提取器程序是GooSeeker为Python开源项目发布的一个类,使用这个类,可以大大减少数据采集规则的调试时间,具体参看《Python即时网络爬虫项目: 内容提取器的定义

2.4,安装selenium

2.5,PhantomJS下载

3,网络爬虫的源代码
  1. # _*_coding:utf8_*_
  2. # douban.py
  3. # 爬取豆瓣小组讨论话题
  4. # 2016-07-11 v1.0
  5. # 2017-08-03 v1.1

  6. from urllib import request
  7. from lxml import etree
  8. from gooseeker import GsExtractor
  9. from selenium import webdriver
  10. import time

  11. class PhantomSpider:
  12.     def getContent(self, url):
  13.         browser = webdriver.PhantomJS(executable_path='C:\\phantomjs-2.1.1-windows\\bin\\phantomjs.exe')
  14.         browser.get(url)
  15.         time.sleep(3)
  16.         html = browser.execute_script("return document.documentElement.outerHTML")
  17.         output = etree.HTML(html)
  18.         return output

  19.     def saveContent(self, filepath, content):
  20.         file_obj = open(filepath, 'w', encoding='UTF-8')
  21.         file_obj.write(content)
  22.         file_obj.close()

  23. doubanExtra = GsExtractor()   
  24. # 下面这句调用gooseeker的api来设置xslt抓取规则
  25. # 第一个参数是app key,请到GooSeeker会员中心申请
  26. # 第二个参数是规则名,是通过GooSeeker的图形化工具: 谋数台MS 来生成的
  27. doubanExtra.setXsltFromAPI("ffd5273e213036d812ea298922e2627b" , "豆瓣小组讨论话题")  

  28. url = "https://www.douban.com/group/haixiuzu/discussion?start="
  29. totalpages = 5
  30. doubanSpider = PhantomSpider()
  31. print("爬取开始")

  32. for pagenumber in range(1 , totalpages):
  33.     currenturl = url + str((pagenumber-1)*25)
  34.     print("正在爬取", currenturl)
  35.     content = doubanSpider.getContent(currenturl)
  36.     outputxml = doubanExtra.extract(content)
  37.     outputfile = "result" + str(pagenumber) +".xml"
  38.     doubanSpider.saveContent(outputfile , str(outputxml))

  39. print("爬取结束")
复制代码
运行过程如下:
请注意:为了让源代码更整洁,也为了让爬虫程序更有通用性,抓取规则是通过api注入到内容提取器bbsExtra中的,这样还有另外一个好处:如果目标网页结构变化了,只需通过MS谋数台重新编辑抓取规则,而本例的网络爬虫代码不用修改。为内容提取器下载采集规则的方法参看《GooSeeker API说明(1)--下载内容提取器》。

4,爬虫结果

在项目目录下可以看到多个result**.xml文件,文件内容如下图所示:

[attach]1086[/attach]

5,总结

因为信息采集规则是通过api下载下来的,所以,本案例的源代码显得十分简洁。同时,整个程序框架变得很通用,因为最影响通用性的采集规则是从外部注入的。

6,集搜客GooSeeker开源代码下载源

1. GooSeeker开源Python网络爬虫GitHub源

7,文档修改历史
2016--07-11:V1.0








作者: songgong    时间: 2016-11-9 10:30
这个教程我上个星期运行的时候是可以的,现在运行的话就提示错误了。
是这个模板资源不存在了吗?
作者: scraper    时间: 2016-11-9 10:52
这两天服务器在扩容升级,暂时把api接口关闭了。
上午刚刚扩容升级完成,api接口现在重新开放了,你可以再试试
作者: DK_MySoul    时间: 2016-11-9 11:46
这个api接口的思路,真的不错
作者: songgong    时间: 2016-11-9 15:36
哦。可以了。谢谢。
不过有个疑问,如果你们的api接口暂停了,我是不是就不能用了?
有没有离线运行的方式啊?
作者: Fuller    时间: 2016-11-9 16:00
songgong 发表于 2016-11-9 15:36
哦。可以了。谢谢。
不过有个疑问,如果你们的api接口暂停了,我是不是就不能用了?
有没有离线运行的方式 ...

离线方式就是把抓取规则拷贝下来写到程序中。api不会停的,昨天是因为系统升级,暂时停下了。

作者: mingdongtianxia    时间: 2017-7-27 20:22
[attach]7101[/attach]  我照教程做了,没抓到数据啊,提示如图,出现提示:SyntaxError: encoding problem: utf8_
作者: gz51837844    时间: 2017-7-27 23:00
你是在什么环境下运行的? 怎么报encoding problem: utf8_
可以把你实际运行的文件douban.py作为附件粘贴上来, 技术可以测试
作者: mingdongtianxia    时间: 2017-7-28 19:31
gz51837844 发表于 2017-7-27 23:00
你是在什么环境下运行的? 怎么报encoding problem: utf8_
可以把你实际运行的文件douban.py作为附件粘贴上 ...

encoding problem: utf8_对于编码错误已经解决了,现在又出现NameError: name 'time' is not defined这个错误,哎,耽误我这么时间,我把开源Python的教程从头到尾能试的几乎试遍了,能用只有第一篇first.py那个正常运行抓取数据外,其它都失败了,白白浪费我好多宝贵的时间!!不知道fuller大神是否还继续效力于贵公司?此开源项目被终止了么?也不见更新和继续完善,尤其各种问题和教程,运行时各种问题频出啊,我心疼我浪费了如此的精力和时间,现在我不得不说,宣布失败。如果项目还继续,看看新的问题截图吧,问题截图[attach]7106[/attach]




欢迎光临 集搜客GooSeeker网络爬虫 (https://www.gooseeker.com/doc/) Powered by Discuz! X3.2