博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python爬虫实战(1):爬取Drupal论坛帖子列表
阅读量:6990 次
发布时间:2019-06-27

本文共 1012 字,大约阅读时间需要 3 分钟。

hot3.png

1,引言

在《》一文我们定义了一个通用的python网络爬虫类,期望通过这个项目节省程序员一半以上的时间。本文将用一个实例讲解怎样使用这个爬虫类。我们将爬集搜客老版论坛,是一个用Drupal做的论坛。
2,技术要点
我们在多个文章都在说:节省程序员的时间。关键是省去编写提取规则的时间,尤其是调试规则的正确性很花时间。在《》演示了怎样快速生成提取规则,接下来我们再通过GooSeeker的api接口实时获得提取规则,对网页进行抓取。本示例主要有如下两个技术要点:

  • 通过GooSeeker API实时获取用于页面提取的xslt
  • 使用GooSeeker提取器gsExtractor从网页上一次提取多个字段内容。

3,python源代码

# _*_coding:utf8_*_# crawler_gooseeker_bbs.py# 版本: V1.0from urllib import requestfrom lxml import etreefrom gooseeker import gsExtractor# 访问并读取网页内容url = "http://www.gooseeker.com/cn/forum/7"conn = request.urlopen(url)doc = etree.HTML(conn.read())bbsExtra = gsExtractor()   bbsExtra.setXsltFromAPI("98adf83ksdf0slrwaerwersdkfjsa" , "gooseeker_bbs_xslt")   # 设置xslt抓取规则,第一个参数是app key,请到会员中心申请result = bbsExtra.extract(doc)   # 调用extract方法提取所需内容print(str(result))

源代码下载位置请看文章末尾的GitHub源。

4,抓取结果
运行上节的代码,即可在控制台打印出提取结果,是一个xml文件,如果加上换行缩进,内容如下图:

151026slrvor88nr2r1u2v.png

5,相关文档
1, 
6,集搜客GooSeeker开源代码下载源
1, 
7,文档修改历史
1,2016-06-07:V1.0
2,2016-06-07:V2.0
3,2016-06-07:V2.1,增加GitHub下载源

转载于:https://my.oschina.net/gooseeker/blog/688082

你可能感兴趣的文章
Spring动态调用
查看>>
Linux字符设备驱动之异步通知
查看>>
八月,整理一些无聊的资料,以便无聊的时候看
查看>>
javaScript:块级作用域学习笔记
查看>>
快来,你想要的koa知识几乎都在这里了!
查看>>
文本分类中的一些小问题
查看>>
wepy 使用中...
查看>>
时序数据异常检测(2)指数平滑方法
查看>>
Redis持久化存储详解(一)
查看>>
AQS同步组件--ReentrantLock与锁
查看>>
Android工程集成flutter
查看>>
人工智慧也能作曲?使用人工智能算法做出来的重金属音乐
查看>>
VUE 执行流程 个人笔记
查看>>
实现简单的正则表达式引擎
查看>>
吴颖二:12.8 午评 1239点位非农夜或会到达的下点位
查看>>
快速理解JavaScript中call和apply原理
查看>>
JavaScript深入之从原型到原型链
查看>>
HongHu云架构 - maven的构建
查看>>
基于 HTML5 的 WebGL 3D 档案馆可视化管理系统
查看>>
Spring webflux 函数式编程web框架
查看>>