Python 即时网络爬虫项目: 内容提取器的定义
【推荐】2019 Java 开发者跳槽指南.pdf(吐血整理) >>> 1. 项目背景 在 python 即时网络爬虫项目启动说明 中我们讨论一个数字:程序员浪费在调测内容提取规则上的时间,从而我们发起了这个项目,把程序员从繁琐的调测规则中解放出来,投入到更高端的数据处理工作中。 2. 解决方案 为了解决这个问题,我们把影响通用性和工作效率的提取器隔离出来,描述了如下的数据处理流程图: 图中“可插拔提取器”必须很强的模块化,那么关键的接口有: 标准化的输入:以标准的HTML DOM对象为输入 标准化的内容提取:使用标准的xslt模板提取网页内容 标准化的输出:以标准的XML格式输出从网页上提取到的内容 明确的提取器插拔接口:提取器是一个明确定义的类,通过类方法与爬虫引擎模块交互 3. 提取器代码 可插拔提取器是即时网络爬虫项目的核心组件,定义成一个类: gsExtractor python源代码文件及其说明文档请从 github 下载 使用模式是这样的: 实例化一个gsExtractor对象 为这个对象设定xslt提取器,相当于把这个对象配置好(使用三类setXXX()方法) 把html dom输入给它,就能获得xml输出(使用extract()方法) 下面是这个gsExtractor类的源代码 #!/usr/bin/python # -*- coding: utf-8 -*- #