简述python Scrapy框架


Posted in Python onAugust 17, 2020

一、Scrapy框架简介

Scrapy是用纯Python实现一个为了爬取网站数据,提取结构性数据而编写的应用框架,用途非常广泛。利用框架,用户只需要定制开发几个模块就可以轻松的实现一个爬虫,用来抓取网页内容以及各种图片,非常的方便。它使用Twisted这个异步网络库来处理网络通讯,架构清晰,并且包含了各种中间件接口,可以灵活的完成各种需求。Scrapy是Python世界里面最强大的爬虫框架,它比BeautifulSoup更加完善,BeautifulSoup可以说是轮子,而Scrapy则是车子,不需要关注太多的细节。

二、Scrapy原理

1.ScrapyEngine(引擎):负责Spider、ItemPipeline、Downloader、Scheduler中间的通讯,信号数据传递等。

2.Scheduler(调度器):它负责接受引擎发送过来的request请求,并按照定的方式进行整理排列,入队,当引擎需要时,交还给引擎。

3.Downloader(下载器):负责下载ScrapyEngine发送的所有requests请求,并将其获取到的responses交还给ScrapyEngine,由引擎交给Spider来处理。

4.Spider(爬虫):它负责处理所有Responses,从中分析提取数据,获取ltem字段需要的数据,并将需要跟进的URL提交给引擎,再次进入Scheduler。

5.ItemPipeline(管道):它负责处理Spider中获取到的ltem,并进行进行后期处理,详细分析,过滤,存储等的地方。

6.DownloaderMiddlewares(下载中间件):它是一个可以自定义扩展下载功能的组件。

7.SpiderMiddlewares(Spider中间件):它是一个可以自定扩展和操作引擎和Spider中间通信的功能组件比如进入Spider的Responses,和从Spider出去的Requests。

三、创建Scrapy项目

新建项目命令:

scrapy startproject xxx

在开始爬取之前,必须创建一个新的Scrapy项目。进入自定义的项目目录中,运行下列命令:

scrapy startproject xxx

其中,xxx为项目名称,可以看到将会创建一个xxx文件夹,目录结构大致如下:

简述python Scrapy框架

四、创建爬虫

创建爬虫的命令:

scrapy genspider 爬虫名字网站域名

应当注意的是爬虫名字不要和项目名字一-样,网站域名是允许爬虫采集的域名如,baidu. com,zhihu. com。创建后python文件如下:

简述python Scrapy框架

五、总结

Scrapy框架相当于一辆造好的车子,只要我们会开,我们就可以利用这辆车子去到任意想去的地方。通常我们使用的request的方法就相当于在出发前再去造一辆车子,这是相当麻烦的。学好Scrapy,对于网上80%的网站我们都可以进行爬取。

以上就是简述python Scrapy框架的详细内容,更多关于python Scrapy框架的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
跟老齐学Python之用while来循环
Oct 02 Python
Python随机数random模块使用指南
Sep 09 Python
Python自定义主从分布式架构实例分析
Sep 19 Python
python xlsxwriter库生成图表的应用示例
Mar 16 Python
利用Python批量提取Win10锁屏壁纸实战教程
Mar 27 Python
用python打印1~20的整数实例讲解
Jul 01 Python
django fernet fields字段加密实践详解
Aug 12 Python
Python基于WordCloud制作词云图
Nov 29 Python
浅析python标准库中的glob
Mar 13 Python
keras 解决加载lstm+crf模型出错的问题
Jun 10 Python
matplotlib更改窗口图标的方法示例
Feb 03 Python
tensorflow+k-means聚类简单实现猫狗图像分类的方法
Apr 28 Python
python使用多线程查询数据库的实现示例
Aug 17 #Python
python使用建议与技巧分享(一)
Aug 17 #Python
Python2.6版本pip安装步骤解析
Aug 17 #Python
python中pathlib模块的基本用法与总结
Aug 17 #Python
Pycharm无法打开双击没反应的问题及解决方案
Aug 17 #Python
详解python datetime模块
Aug 17 #Python
python实现梯度下降算法的实例详解
Aug 17 #Python
You might like
完美实现GIF动画缩略图的php代码
2011/01/02 PHP
PHP修改session_id示例代码
2014/01/08 PHP
采用thinkphp自带方法生成静态html文件详解
2014/06/13 PHP
详解WordPress中简码格式标签编写的基本方法
2015/12/22 PHP
CodeIgniter表单验证方法实例详解
2016/03/03 PHP
PHP中SQL查询语句的id=%d解释(推荐)
2016/12/10 PHP
iis 7下安装laravel 5.4环境的方法教程
2017/06/14 PHP
jQuery 1.9.1源码分析系列(十)事件系统之绑定事件
2015/11/19 Javascript
js实现字符串和数组之间相互转换操作
2016/01/12 Javascript
Angularjs实现多个页面共享数据的方式
2016/03/29 Javascript
javascript实现不同颜色Tab标签切换效果
2016/04/27 Javascript
bootstrap输入框组代码分享
2016/06/07 Javascript
JS遍历数组和对象的区别及递归遍历对象、数组、属性的方法详解
2016/06/14 Javascript
javascirpt实现2个iframe之间传值的方法
2016/06/30 Javascript
纯JS代码实现隔行变色鼠标移入高亮
2016/11/23 Javascript
BootStrap Datetimepicker 汉化的实现代码
2017/02/10 Javascript
JS中的多态实例详解
2017/10/15 Javascript
如何在vue中使用jointjs过程解析
2020/05/29 Javascript
[01:08]2014DOTA2展望TI 剑指西雅图LGD战队专访
2014/06/30 DOTA
Python实现对PPT文件进行截图操作的方法
2015/04/28 Python
python3实现ftp服务功能(服务端 For Linux)
2017/03/24 Python
Python在图片中添加文字的两种方法
2017/04/29 Python
详解Python中的分组函数groupby和itertools)
2018/07/11 Python
Python语法分析之字符串格式化
2019/06/13 Python
Python 仅获取响应头, 不获取实体的实例
2019/08/21 Python
Python 转换文本编码实现解析
2019/08/27 Python
Python列表切片常用操作实例解析
2019/12/16 Python
Python+OpenCV实现将图像转换为二进制格式
2020/01/09 Python
Python中的X[:,0]、X[:,1]、X[:,:,0]、X[:,:,1]、X[:,m:n]和X[:,:,m:n]
2020/02/13 Python
Pycharm激活码激活两种快速方式(附最新激活码和插件)
2020/03/12 Python
世界领先的高品质定制产品平台:Zazzle
2017/07/23 全球购物
英国最出名高街品牌:Forever Unique
2018/02/24 全球购物
国贸专业的职业规划范文
2014/01/23 职场文书
旅游管理毕业生自荐书
2014/02/02 职场文书
工作评语大全
2014/04/26 职场文书
离婚财产分隔协议书
2014/10/23 职场文书