requests+正则表达式爬取猫眼电影TOP100!

前言

 

本文主要讲述使用python爬取猫眼TOP100榜的电影名称,评分,以及电影图片等,爬取的URL是:http://maoyan.com/bard/4。

 

安装类库

pip install requests

分析目标URL

 

打开http://maoyan.com/bard/4,观察页面规律。

 

requests+正则表达式爬取猫眼电影TOP100!_第1张图片

可以看到页面上链接已经变为http://maoyan.com/board/4?offset=10,可以看的出来第二页链接新增了offset=10这个参数,这时可以看到排名20到30的电影信息,我们手动更改这个参数,就可以看到TOP100的全部电影信息了。

 

抓取单个页面

 

将url=http://maoyan.com/board/4,传入get_one_page()函数,可以获取目标地址的源代码。

 

requests+正则表达式爬取猫眼电影TOP100!_第2张图片

 

正则解析

requests+正则表达式爬取猫眼电影TOP100!_第3张图片

 

打开浏览器调试页面可以发现我们要抓取的所有信息被

标签包含,所以我们只要把
中所有要抓取的信息都用正则表达式匹配出来就可以了。

 

表达式如下:

排名:

.*?board-index.*?>(.*?)

图片:

.*?board-index.*?>(.*?).*?src="(.*?)"

 

电影名称:

.*?board-index.*?>(.*?).*?src="(.*?)".*?name.*?a.*?>(.*?)

 

最后解析全部字段解析如下,同时我们还要对解析出来的数据进行结构化处理:

 

requests+正则表达式爬取猫眼电影TOP100!_第4张图片

 

写入文件

 

写入文件,我们在上面结构化处理后的文件是构建的字典格式,我们可以通过JSON库,序列化输出到本地文件中。

 

 

构建分页链接

 

因为猫眼的偏移量是10,20,,,100,所以在构建的时候可以构建一个生成式传入到mian()函数当中。代码块如下:

 

requests+正则表达式爬取猫眼电影TOP100!_第5张图片

 

脚下留心

 

请求的时候带上header,减小被服务器识别为爬虫的概率,算是反反爬的一种。

 

写在最后

 

1、之前写爬虫的时候往往一个函数涵盖全部的功能,之后维护起来自己都想抽自己,之后看了几个大佬的代码之后也学习到函数式编程的好处,把功能写成一个个函数方便之后维护,别人也能看的懂你在写什么。

 

2、还有就是多加注释,实习的时候实习的师傅告诉我最好在写代码的时候注释的量能占到总的百分20%,虽然并没有写到那么多,但是还是养成写注释的习惯,方便自己方便他人。

你可能感兴趣的:(Python,Python)