Scrapy001-框架初窥
Scrapy001-框架初窥
@(Spider)[POSTS]
1.Scrapy简介
Scrapy
是一个应用于抓取、提取、处理、存储等网站数据的框架(类似Django
)。
应用:
- 数据挖掘
- 信息处理
- 存储历史数据
- 监测
- 自动化测试
- 。。。
还有很多,详细参考:http://scrapy-chs.readthedocs.io/zh_CN/0.24/intro/overview.html
2.Scrapy架构
Scrapy
使用了Twisted
异步网络库来处理网络通讯。结构如下:
Scrapy
的核心组件:
引擎(
Scrapy Engine
)
用来处理整个系统的数据流,触发事务(框架核心),负责控制和调度各个组件调度器(
Scheduler
)
用来接受引擎发过来的请求,压入队列中,并在引擎再次请求的时候返回,如:要抓取的链接(URL
)的优先队列,由它来决定下一个要抓取的URL
是什么,并进行去重。下载器(
Downloader
)
用于下载网页内容,并将网页内容返回给Spiders
(自己编写的虫子
)--下载器建立在Twisted
模型上爬虫(
Spider
)
干活的虫子
,从特定的网页中提取自己需要的信息,即:实体Item
,用户也可以提取下级链接,继续抓取页面内容。项目管道(
Pipline
)
负责处理爬虫从网页中抽取的实体,主要的功能是持久化实体(Item
)、验证实体的有效性、清除垃圾信息。当页面被爬虫解析后,解析后内容将会发送到项目管理通道,经过几个特定的次序处理。下载器中间件(
Downloader Middlewares
)
位于Scrapy
引擎和下载器之间的框架,主要是处理Scrapy
引擎和下载器之间的请求与响应。爬虫中间件(
Spider Middlewares
)
介于Scrapy
引擎和Spider
之间的框架,处理爬虫的响应输入和请求输出。调度中间件(Scheduler Middlewares)
介于Scrapy
引擎和调度之间的中间件,从Scrapy
引擎发送到调度的请求和响应。
从上面可以看出,
Scrapy
的耦合性很低,扩展性更灵活,自定义性好
3.Scrapy执行流程
如下图:
此图来自大神的文章
按照上图的序号,数据的执行流程如下:
引擎
从自定义爬虫
中获取初始化请求(种子URL--自定义爬虫
文件中的start_urls
)- 引擎将该请求放入
调度器
中,同时引擎从调度器获取一个待下载的请求
(二者异步执行) - 调度器返回给引擎一个
待下载请求
- 引擎将
待下载请求
发送给下载器
,中间会经过一系列下载器中间件
- 该
待下载请求
经过下载器处理之后,会生成一个响应对象(response)
,返回给引擎,中间会再次经过一系列下载器中间件
- 引擎接收到下载器返回的
响应对象(response)
后,将其发送给自定义爬虫
,执行自定义逻辑
,中间会经过一系列爬虫中间件
响应对象(response)
经过内部的选择器
筛选并调用回调函数
处理后,完成逻辑,生成结果对象
或新的请求对象
给引擎,再次经过一系列爬虫中间件
- 引擎将返回的
结果对象
交给结果处理器
处理,将新的请求对象
交给调度器
新的请求对象
重复上述过程,直到没有新的请求处理
新的请求对象:
多层URL的筛选中的下一层URL
==> 详细组件关系,待解读完源码后继续跟上。
4.支持特性
上面介绍的仅仅是冰上一角,Scrapy提供了很多强大的特性是爬虫更加高效,例如:
- HTML, XML源数据 选择及提取 的内置支持
- 提供了一系列在spider之间共享的可复用的过滤器(即 Item Loaders),对智能处理爬取数据提供了内置支持。
- 通过 feed导出 提供了多格式(JSON、CSV、XML),多存储后端(FTP、S3、本地文件系统)的内置支持
- 提供了media pipeline,可以 自动下载 爬取到的数据中的图片(或者其他资源)。
- 高扩展性。您可以通过使用 signals ,设计好的API(中间件, extensions, pipelines)来定制实现您的功能。
- 内置的中间件及扩展为下列功能提供了支持:
- cookies and session 处理
- HTTP 压缩
- HTTP 认证
- HTTP 缓存
- user-agent模拟
- robots.txt
- 爬取深度限制
- 其他
- 针对非英语语系中不标准或者错误的编码声明, 提供了自动检测以及健壮的编码支持。
- 支持根据模板生成爬虫。在加速爬虫创建的同时,保持在大型项目中的代码更为一致。详细内容请参阅 genspider 命令。
针对多爬虫下性能评估、失败检测,提供了可扩展的 状态收集工具 。 - 提供 交互式shell终端 , 为您测试XPath表达式,编写和调试爬虫提供了极大的方便
- 提供 System service, 简化在生产环境的部署及运行
- 内置 Web service, 使您可以监视及控制您的机器
- 内置 Telnet终端 ,通过在Scrapy进程中钩入Python终端,使您可以查看并且调试爬虫
- Logging 为您在爬取过程中捕捉错误提供了方便
- 支持 Sitemaps 爬取
- 具有缓存的DNS解析器
Scrapy001-框架初窥的更多相关文章
- APP界面框架初窥---标签导航
标签导航是十大界面框架设计里最常用的界面框架设计,也是被业界之内公认的一种普遍使用的页面框架设计.那么这种页面框架设计在作业方面对一个用户来说也是最常见的一种页面框架设计,比如说微博.微信.手机百度. ...
- scrapy2_初窥Scrapy
递归知识:oop,xpath,jsp,items,pipline等专业网络知识,初级水平并不是很scrapy,可以从简单模块自己写. 初窥Scrapy Scrapy是一个为了爬取网站数据,提取结构性数 ...
- WWDC15 Session笔记 - Xcode 7 UI 测试初窥
https://onevcat.com/2015/09/ui-testing/ WWDC15 Session笔记 - Xcode 7 UI 测试初窥 Unit Test 在 iOS 开发中已经有足够多 ...
- 网页3D效果库Three.js初窥
网页3D效果库Three.js初窥 背景 一直想研究下web页面的3D效果,最后选择了一个比较的成熟的框架Three.js下手 ThreeJs官网 ThreeJs-github; 接下来我会陆续翻译 ...
- iOS视频直播初窥:高仿<喵播APP>
视频直播初窥 视频直播,可以分为 采集,前处理,编码,传输, 服务器处理,解码,渲染 采集: iOS系统因为软硬件种类不多, 硬件适配性比较好, 所以比较简单. 而Android端市面上机型众多, 要 ...
- 初窥Flask
初窥Flask Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是Socket服务端,其用于接收http请求并对请求 ...
- Scrapy 1.4 文档 01 初窥 Scrapy
初窥 Scrapy Scrapy 是用于抓取网站并提取结构化数据的应用程序框架,其应用非常广泛,如数据挖掘,信息处理或历史存档. 尽管 Scrapy 最初设计用于网络数据采集(web scraping ...
- python爬虫 scrapy2_初窥Scrapy
sklearn实战-乳腺癌细胞数据挖掘 https://study.163.com/course/introduction.htm?courseId=1005269003&utm_campai ...
- 初窥Kaggle竞赛
初窥Kaggle竞赛 原文地址: https://www.dataquest.io/mission/74/getting-started-with-kaggle 1: Kaggle竞赛 我们接下来将要 ...
随机推荐
- .bat文件和Jar包的生成及运行
.bat文件和Jar包的生成及运行 1.Jar包简单介绍 Jar包是Java中所特有的一种压缩文档,有点类似于zip包,区别在于Jar包中有一个META-INF\MANIFEST.MF文件(在生成Ja ...
- C#反射在ADO中的巧用
在C#原生开发网站的时候,经常会碰到一个问题,后台用原生查出来的数据一般是DataReader或者是DataTable,这样就把数据从数据库中拿到了,然后就是把数据绑定到前台页面进行输出,这是最原生态 ...
- ModernUI教程:如何使用你自己的导航框架
Modern UI for WPF带有一个内置的页面导航框架,易于使用和可扩展的.但这并不是必须的,你也可以自己来自定义一个导航框架. 默认的ModernWindow控件模板包括标 ...
- Android Studio22-NDK-LLDB调试
Android Studio2.2更好的支持NDK开发,并可以像开发java一样的DEBUG程序,不需要添加gradle-experimental插件,就可调试代码! 一,下载 NDK 和构建工具 要 ...
- session过期返回登录页面跳出frame
session 过期返回登录页面 方法1, HttpSession session = request.getSession(); String LOGIN_ID = (String) session ...
- Thinking in java学习笔记之String的不可变性
为了提高效率,可以使用StringBuffer或StringBuilder 1. 在执行速度方面的比较:StringBuilder > StringBuffer 2. StringBuffer与 ...
- jsp如何自定义tag的标签库?
虽然和上一次的使用自定义的tld标签简化jsp的繁琐操作的有点不同,但是目的也是一致的.自定义tag比较简单. 1.新建tag标签 在WEB-INF目录下新建一个tags的文件夹,是自定义tag标签的 ...
- 初步搭建RocketMQ环境
1. 去官网https://github.com/alibaba/RocketMQ/releases下载alibaba-rocketmq-3.2.6.tar.gz,这个是已经maven install ...
- 【bzoj3505】 Cqoi2014—数三角形
http://www.lydsy.com/JudgeOnline/problem.php?id=3505 (题目链接) 题意 给定一个n*m的网格,请计算三点都在格点上的三角形共有多少个. Solut ...
- git版本控制?
git是一个分布式的版本控制系统,版本控制系统,类似于保险箱,而我们的代码就是资产:通过对代码的有效管理可以更好的提高我们的生产效率:maven是主要是一个项目构建工具,解决的是我们个人在开发过程中的 ...