大数据人|大数据第一社区

 找回密码
 注册会员

扫一扫,访问微社区

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

2016-7-18 09:59| 发布者: 集搜客GooSeeker| 查看: 864| 评论: 0|原作者: 集搜客GooSeeker|来自: 集搜客社区

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

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

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


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

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

  • 运行环境:Windows10

2.1,安装Python3.5.2


2.2,Lxml 3.6.0
  • Lxml官网地址: http://lxml.de/
  • Windows版安装包下载: http://www.lfd.uci.edu/~gohlke/pythonlibs/#lxml
  • 对应windows下python3.5的安装文件为 lxml-3.6.0-cp35-cp35m-win32.whl
  • 下载完成后,在windows下打开一个命令窗口,,切换到刚下载的whl文件的存放目录,运行pip install lxml-3.6.0-cp35-cp35m-win32.whl

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


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

2.4,安装selenium
  • pip install selenium

2.5,PhantomJS下载
  • 下载地址 http://phantomjs.org/download.html
  • 把下载得到的phantomjs-2.1.1-windows.zip解压到本机的某个文件夹下
  • 把解压后的文件夹中的phantomjs.exe的完整路径加文件名记录下来,用来替换下面代码的 browser = webdriver.PhantomJS(executable_path='C:\\phantomjs-2.1.1-windows\\bin\\phantomjs.exe') 这一行中的两个单引号之间的内容。

3,网络爬虫的源代码
  1. # _*_coding:utf8_*_
  2. # douban.py
  3. # 爬取豆瓣小组讨论话题

  4. from urllib import request
  5. from lxml import etree
  6. from gooseeker import GsExtractor
  7. from selenium import webdriver

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

  16.     def saveContent(self, filepath, content):
  17.         file_obj = open(filepath, 'w', encoding='UTF-8')
  18.         file_obj.write(content)
  19.         file_obj.close()

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

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

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

  36. print("爬取结束")

运行过程如下:
  • 将上面的代码保存到douban.py中,和前面2.3步下载的提取器类gooseeker.py放在同一个文件夹中
  • 打开Windows CMD窗口,切换当前目录到存放douban.py的路径(cd \xxxx\xxx)
  • 运行 python douban.py
请注意:为了让源代码更整洁,也为了让爬虫程序更有通用性,抓取规则是通过api注入到内容提取器bbsExtra中的,这样还有另外一个好处:如果目标网页结构变化了,只需通过MS谋数台重新编辑抓取规则,而本例的网络爬虫代码不用修改。为内容提取器下载采集规则的方法参看《Python即时网络爬虫:API说明》。

4,爬虫结果

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

 

5,总结

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

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

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

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

鲜花

握手

雷人

路过

鸡蛋

相关阅读

最新评论

关闭

站长推荐上一条 /2 下一条


id="mn_portal" >首页Portalid="mn_P18" onmouseover="navShow('P18')">应用id="mn_P15" onmouseover="navShow('P15')">技术id="mn_P37" onmouseover="showMenu({'ctrlid':this.id,'ctrlclass':'hover','duration':2})">前沿id="mn_P36" onmouseover="navShow('P36')">宝箱id="mn_P61" onmouseover="showMenu({'ctrlid':this.id,'ctrlclass':'hover','duration':2})">专栏id="mn_P65" >企业id="mn_Nd633" >导航 折叠导航 关注微信 关注微博 关注我们

QQ|广告服务|关于我们|Archiver|手机版|小黑屋|大数据人 ( 鄂ICP备14012176号-2  

GMT+8, 2024-5-4 02:49 , Processed in 0.187506 second(s), 22 queries .

Powered by 小雄! X3.2

© 2014-2020 bigdataer Inc.

返回顶部