本篇介绍监测网站数据变化的增量式爬虫。
概述
概念:监测
核心技术:去重
- 基于 redis 的一个去重
适合使用增量式的网站:
- 基于深度爬取的
- 对爬取过的页面url进行一个记录(记录表)
- 基于非深度爬取的
- 记录表:爬取过的数据对应的数据指纹
- 数据指纹:原始数据的一组唯一标识
- 数据 –> 数据指纹 –> 库中查询
- hashlib
- 记录表:爬取过的数据对应的数据指纹
所谓的记录表是以怎样的形式存在于哪?
- redis的set充当记录表
例子
爬取4567电影网中影片名称以及简介,当网站有更新时爬取增加的了数据。
- 地址为:
https://www.4567tv.tv/frim/index1.html
- 该例为基于深度爬取的。
scrapy startproject zlsPro
scrapy genspider zls www.xxx.com
①
- 使用手动传参进行深度的爬取
- 使用
self.conn.sadd('movie_url', detail_url)
的返回值来判断是否爬取过该电影。
1 | # zls.py |
②
- 定义Item
1 | # items.py |
③
- 定义pipeline
- 传入redis
1 | # pipelines.py |