如何利用Scrapy爬虫框架抓取网页全部文章信息(上篇)
共 2735字,需浏览 6分钟
·
2020-11-12 18:33
回复“书籍”即可获赠Python从入门到进阶共10本电子书
/前言/
前一段时间小编给大家分享了Xpath和CSS选择器的具体用法,感兴趣的小伙伴可以戳这几篇文章温习一下,网页结构的简介和Xpath语法的入门教程,在Scrapy中如何利用Xpath选择器从HTML中提取目标信息(两种方式),在Scrapy中如何利用CSS选择器从网页中采集目标数据——详细教程(上篇)、在Scrapy中如何利用CSS选择器从网页中采集目标数据——详细教程(下篇)、在Scrapy中如何利用Xpath选择器从网页中采集目标数据——详细教程(下篇)、在Scrapy中如何利用Xpath选择器从网页中采集目标数据——详细教程(上篇),学会选择器的具体使用方法,可以帮助自己更好的利用Scrapy爬虫框架。在接下来的几篇文章中,小编将给大家讲解爬虫主体文件的具体代码实现过程,最终实现网页所有内容的抓取。
前一阶段我们已经实现了通过Scrapy抓取某一具体网页页面的具体信息,关于Scrapy爬虫框架中meta参数的使用示例演示(上)、关于Scrapy爬虫框架中meta参数的使用示例演示(下),但是未实现对所有页面的依次提取。首先我们理一下爬取思路,大致思想是:当获取到第一个页面的URL之后,尔后将第二页的URL发送给Scrapy,让Scrapy去自动下载该网页的信息,之后通过第二页的URL继续获取第三页的URL,由于每一页的网页结构是一致的,所以通过这种方式如此反复进行迭代,便可以实现整个网页中的信息提取。其具体的实现过程将通过Scrapy框架来进行实现,具体的教程如下。
/具体实现/
1、首先URL不再是某一篇具体文章的URL了,而是所有文章列表的URL,如下图所示,将链接放到start_urls里边,如下图所示。
2、接下来我们将需要更改parse()函数,在这个函数中我们需要实现两件事情。
其一是获取某一页面所有文章的URL并对其进行解析,获取每一篇文章里的具体网页内容,其二是获取下一个网页的URL并交给Scrapy进行下载,下载完成之后再交给parse()函数。
有了之前的Xpath和CSS选择器基础知识之后,获取网页链接URL就变得相对简单了。
3、分析网页结构,使用网页交互工具,我们可以很快的发现每一个网页有20篇文章,即20个URL,而且文章列表都存在于id="archive"这个标签下面,之后像剥洋葱一样去获取我们想要的URL链接。
4、点开下拉三角,不难发现文章详情页的链接藏的不深,如下图圈圈中所示。
5、根据标签我们按图索骥,加上选择器利器,获取URL犹如探囊取物。在cmd中输入下图命令,以进入shell调试窗口,事半功倍。再次强调,这个URL是所有文章的网址,而不是某一篇文章的URL,不然后面你调试半天都不会有结果的。
6、根据第四步的网页结构分析,我们在shell中写入CSS表达式,并进行输出,如下图所示。其中a::attr(href)的用法很巧妙,也是个提取标签信息的小技巧,建议小伙伴们在提取网页信息的时候可以经常使用,十分方便。
至此,第一页的所有文章列表的URL已经获取到了。提取到URL之后,如何将其交给Scrapy去进行下载呢?下载完成之后又如何调用我们自己定义的解析函数呢?
欲知后事如何,且听下一篇文章分解。
/小结/
本文主要介绍了Scrapy爬虫框架抓取其中某个网页数据的理论,为后面抓取全网数据埋下伏笔,更精彩的操作在下篇文章奉上,希望对大家的学习有帮助。
想学习更多关于Python的知识,可以参考学习网址:http://pdcfighting.com/,点击阅读原文,可以直达噢~
------------------- End -------------------
往期精彩文章推荐:
欢迎大家点赞,留言,转发,转载,感谢大家的相伴与支持
想加入Python学习群请在后台回复【入群】
万水千山总是情,点个【在看】行不行
/今日留言主题/
随便说一两句吧~~