文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

scrapy入门学习(原理)

2023-01-30 21:55

关注

什么是网络爬虫?

网络爬虫又称网页蜘蛛,网络机器人,是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本。如果有兴趣可查看百度百科网络爬虫

网络蜘蛛(web spider)也叫网络爬虫,是一种'自动化浏览网络'的程序,或者说是一种网络机器人,它们被广泛用于互联网搜索引擎或其他类似网站,以获取或者更新这些网站的内容和检索方式,它们可以自动采集所有能够访问到的页面内容,以供搜索引擎做进一步处理(分检整理下载的页面),而使得用户能更快的检索到他们需要的信息


Scrapy使用Twisted这个异步网络库来处理网络通讯,架构清晰,并且包含了各种中间件接口,可以灵活的完成各种需求

整体架构

图片.png

引擎(Scrapy Engine),用来处理整个系统的数据流处理,触发事务

调度器(Scheduler),用来接受引擎发过来的请求,压入队列中,并在引擎再次请求的时候返回

下载器(Downloader),用于下载网页内容,并将网页内容返回给蜘蛛

蜘蛛(Spiders),蜘蛛是主要干活的,用它来制定特定域名或者网页的解析规则,编写用于分析response并提取item(需要获取的内容item)或需要额外跟进的URL的类,每个spider负责处理一个特定(或一些)网站

项目管道(item pipline),负责处理有蜘蛛从网页中提取的项目,它的主要任务是清晰,验证和存储数据,当页面被蜘蛛解析后,将被发送到项目管道,并经过几个特定的次序处理数据

下载器中间件(Downloader Middlewares),位于Scrapy引擎和下载器之间的钩子框架,主要是处理Scrapy引擎与下载器之间的请求及响应

蜘蛛中间件(Spider Middlewares),介于Scrapy引擎和蜘蛛之间的钩子框架,主要工作是处理蜘蛛的响应输入和请求输出

调度中间件(Scheduler Middlewares),介于Scrapy引擎和调度之间的中间件,从Scrapy引起发送到调度的请求和响应


爬取流程

先从起始URL开始,调度程序会将其交给Downloader进行下载,下载之后会交给Spider进行分析,Spider分析出来的结果有两种:一种是需要跟进抓取的链接,例如之前分析的"下一页"的链接,这些东西会被传回给调度程序;另一种是需要保存的数据,它们则被送到Item Pipeline那里,那是对数据进行后期处理(详细分析,分析,过滤,存储等)的地方,另外,在数据流动的通道里还可以安装各种中间件,进行必要的处理


数据流

Scrapy中的数据流由执行引擎控制,其过程如下:

1 引擎打开一个网站,找到处理该网站的Spider并向该spider请求第一个要爬取的URL

2 引擎从Spider中获取到第一个要爬取的URL并在调度器(Scheduler)以Request调度

3 引擎向调度器请求下一个要爬取的URL

4 调度器返回下一个要爬取的URL给引擎,引擎将URL通过下载中间件(请求(request)方向)转发给下载器(Downloader)

5 一旦页面下载完毕,下载器生成一个该页面的Response,并将其通过下载中间件(返回response)发给引擎

6 引擎从下载器中接收到Response并通过Sipder中间件(输入方向)发送给Spider处理

7 Spider处理Response并返回爬取到的Item及(跟进的)新的Request给引擎

8 引擎将(Spider返回的)爬取到的Item给 Item Pipline,将Spider返回的Request给调度器

9 (从第二步)重复直到调度器中没有request(请求),引擎关闭该网站


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯