2019独角兽企业重金招聘Python工程师标准>>>

Scrapy 框架

  • Scrapy是用纯Python实现一个为了爬取网站数据、提取结构性数据而编写的应用框架,用途非常广泛。

  • 框架的力量,用户只需要定制开发几个模块就可以轻松的实现一个爬虫,用来抓取网页内容以及各种图片,非常之方便。

  • Scrapy 使用了 Twisted['twɪstɪd](其主要对手是Tornado)异步网络框架来处理网络通讯,可以加快我们的下载速度,不用自己去实现异步框架,并且包含了各种中间件接口,可以灵活的完成各种需求。

Scrapy架构图(绿线是数据流向):

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

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

  • Downloader(下载器):负责下载Scrapy Engine(引擎)发送的所有Requests请求,并将其获取到的Responses交还给Scrapy Engine(引擎),由引擎交给Spider来处理,

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

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

  • Downloader Middlewares(下载中间件):你可以当作是一个可以自定义扩展下载功能的组件。

  • Spider Middlewares(Spider中间件):你可以理解为是一个可以自定扩展和操作引擎和Spider中间通信的功能组件(比如进入Spider的Responses;和从Spider出去的Requests)

如果你在学习Python的过程中遇见了很多疑问和难题,可以加-q-u-n   227 -435-450里面有软件视频资料免费

Scrapy的运作流程

代码写好,程序开始运行...

  • 引擎:Hi!Spider, 你要处理哪一个网站?

  • Spider:老大要我处理xxxx.com。

  • 引擎:你把第一个需要处理的URL给我吧。

  • Spider:给你,第一个URL是xxxxxxx.com。

  • 引擎:Hi!调度器,我这有request请求你帮我排序入队一下。

  • 调度器:好的,正在处理你等一下。

  • 引擎:Hi!调度器,把你处理好的request请求给我。

  • 调度器:给你,这是我处理好的request

  • 引擎:Hi!下载器,你按照老大的下载中间件的设置帮我下载一下这个request请求

  • 下载器:好的!给你,这是下载好的东西。(如果失败:sorry,这个request下载失败了。然后引擎告诉调度器,这个request下载失败了,你记录一下,我们待会儿再下载)

  • 引擎:Hi!Spider,这是下载好的东西,并且已经按照老大的下载中间件处理过了,你自己处理一下(注意!这儿responses默认是交给def parse()这个函数处理的)

  • Spider:(处理完毕数据之后对于需要跟进的URL),Hi!引擎,我这里有两个结果,这个是我需要跟进的URL,还有这个是我获取到的Item数据。

  • 引擎:Hi !管道 我这儿有个item你帮我处理一下!调度器!这是需要跟进URL你帮我处理下。然后从第四步开始循环,直到获取完老大需要全部信息。

  • 管道``调度器:好的,现在就做!

注意!只有当调度器中不存在任何request了,整个程序才会停止,(也就是说,对于下载失败的URL,Scrapy也会重新下载。)

制作 Scrapy 爬虫 一共需要4步:

  • 新建项目 (scrapy startproject xxx):新建一个新的爬虫项目

  • 明确目标 (编写items.py):明确你想要抓取的目标

  • 制作爬虫 (spiders/xxspider.py):制作爬虫开始爬取网页

  • 存储内容 (pipelines.py):设计管道存储爬取内容

转载于:https://my.oschina.net/u/3849396/blog/1973387

Python高级爬虫框架Scrapy简介相关推荐

  1. Python网络爬虫框架 Scrapy简介

    Scrapy 网络爬虫框架 Scrapy的安装 cmd 执行: pip install scrapy测试安装: scrapy -h Scrapy介绍 Scrapy不是一个函数功能库,而是一个爬虫框架. ...

  2. 开源 Python网络爬虫框架 Scrapy

    开源 Python 网络爬虫框架 Scrapy:http://blog.csdn.net/zbyufei/article/details/7554322 介绍 所谓网络爬虫,就是一个在网上到处或定向抓 ...

  3. 网络爬虫框架Scrapy简介

    作者: 黄进(QQ:7149101) 一. 网络爬虫 网络爬虫(又被称为网页蜘蛛,网络机器人),是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本:它是一个自动提取网页的程序,它为搜索引擎从万维 ...

  4. 【Python学习系列五】Python网络爬虫框架Scrapy环境搭建

    1.网络爬虫库Scrapy 网络爬虫,是在网上进行数据抓取的程序,使用它能够抓取特定网页的HTML数据.Scrapy是一个使用Python编写的,轻量级的,简单轻巧,并且使用起来非常的方便.Scrap ...

  5. scrapy安装_爬虫框架Scrapy简介与安装

    Scrapy 框架 Scrapy是用纯Python实现一个为了爬取网站数据.提取结构性数据而编写的应用框架,用途非常广泛. 框架的力量,用户只需要定制开发几个模块就可以轻松的实现一个爬虫,用来抓取网页 ...

  6. Python分布式爬虫框架Scrapy实战

    TIOBE 更新了 2021 年 10 月份编程语言指数排行榜. 榜单中共对 100 种编程语言进行了评级排名,其中 Python 成为 "20 多年来的新语言霸主",以 11.2 ...

  7. 精通python爬虫框架-精通Python爬虫框架Scrapy PDF 中文清晰版

    给大家带来的一篇关于Python爬虫相关的电子书资源,介绍了关于Python.爬虫.框架.Scrapy方面的内容,本书是由人民邮电出版社出版,格式为PDF,资源大小8.6 MB,迪米特里奥斯编写,目前 ...

  8. Python爬虫框架Scrapy安装使用步骤

    一.爬虫框架Scarpy简介 Scrapy 是一个快速的高层次的屏幕抓取和网页爬虫框架,爬取网站,从网站页面得到结构化的数据,它有着广泛的用途,从数据挖掘到监测和自动测试,Scrapy完全用Pytho ...

  9. 用 Python 爬虫框架 Scrapy 爬取心目中的女神

    From :http://www.cnblogs.com/wanghzh/p/5824181.html 本博文将带领你从入门到精通爬虫框架 Scrapy,最终具备爬取任何网页的数据的能力. 本文以校花 ...

最新文章

  1. C++实现读取指定文件夹下的所有文件
  2. php写入记录日志,【转】PHP错误处理写入日志记录
  3. 白盒测试有哪些方法_QA测试开发常考的面试题+答案汇总(持续更新)
  4. android bootloader阶段GPIO的控制
  5. android中关于点击屏幕,实现破碎的效果的实现
  6. unity 实现调用Windows窗口/对话框交互
  7. mysql 不通过关联查询表_mysql中多表不关联查询的实现方法详解
  8. C#中主窗体Panel中加载其他多个窗体Panel控件
  9. php 查询数据是否大于,怎么实现从数据查询数据的时候判断如果数据大于N条分次查询 递归吗?...
  10. elasticsearch全局analyzer声明
  11. c++ mfc 曲线图像的实现资料网址
  12. DOTA 2血虐人类的OpenAI,原来靠的是作弊?
  13. 表达式求值(from leetcode 241)
  14. 在Unity中实现屏幕空间反射Screen Space Reflection(2)
  15. UNIX环境高级编程之第5章:标准I/O库-习题
  16. Starship Troopers
  17. php并发访问排队_使用xdebug对php做性能分析调优
  18. 商旅业务知识-航信(ETERM)系统
  19. 《认知盈余》——阅读感受与体会
  20. Xilinx FPGA PTP IEEE1588使用

热门文章

  1. 数据库升级后,准备使用原有数据文件启动数据库
  2. android 变量Map集合
  3. AccountManagment
  4. 从open系统调用的源码看文件的打开过程
  5. Android Volley完全解析(四),带你从源码的角度理解Volley
  6. Android魔法(第四弹)—— 一步步实现百叶窗效果
  7. SpringBoot专栏(一) -- SpringBoot简介
  8. auth复习和BBS项目的登录(1)
  9. 《Linux命令行与shell脚本编程大全 第3版》Linux命令行---10
  10. MySQL缓存之Qcache与buffer pool对比