python基于 Scrapy 的爬虫自动登录(内附python教程分享)

起步

首先我们使用Scrapy的命令行创建一个新的项目

scrapy startproject douban

运行后,我们就有了下面这样的目录结构

python基于 Scrapy 的爬虫自动登录(内附python教程分享)

Scrapy为我们生成了已经组织好的目录结构,上面的注释部分解释了每个文件及目录的作用。

建立目标

本篇我们来建立两个目标,这两个目标都是基于豆瓣网:

目标一:抓取豆瓣TOP250的图书信息并保存成csv文件

目标二:抓取我的第一页豆邮标题(需要登录),并保存成csv文件

分析目标一

目标一是豆瓣的TOP250图书信息,首先我们进入到TOP250的列表(https://book.douban.com/top250) ,我用图示圈出我们这次要爬取的内容,具体请看图示:

python基于 Scrapy 的爬虫自动登录(内附python教程分享)

从图上的框线中我们主要圈出了书名、价格、出版年份、出版社、评分,其中出版年份,出版社以及价格是在一行中,这个我们需要进一步处理。

分页的处理:总记录是250条,每页是25条图书信息,共分了10页。

实现目标一

需要用到的概念:

Item

Item Pipeline

首先建立Scrapy的Item, Scrapy的Item就是我们需要存储的数据结构,先修改items, 然后在spiders目录中新建一个名为bookspider.py的Python文件,由于我们需要在一堆字符串中提取出出版社和价格等信息所以我们这里需要对抓取的内容进一步处理, 在这之前还需要修改settings.py文件:

加入faker的模拟USER_AGENT数据防止被豆瓣屏蔽,

也可以设置DEFAULT_REQUEST_HEADERS参数。

修改ITEM_PIPELINES

代码如下所示:

items.py

python基于 Scrapy 的爬虫自动登录(内附python教程分享)

bookspider.py

python基于 Scrapy 的爬虫自动登录(内附python教程分享)

pipelines.py

python基于 Scrapy 的爬虫自动登录(内附python教程分享)

最后我们到douban的根目录中执行以下命令来运行爬虫来执行并导出数据到csv文件

scrapy crawl douban-book -o douban_book_top250.csv

csv文件截图如下:

python基于 Scrapy 的爬虫自动登录(内附python教程分享)

分析目标二

目标二是建立在理解了目标一的基础上进行的,因为豆瓣登录次数过多会有验证码出现,这里提供一种手工填写验证码的方式,暂时不讨论如何去识别验证码,目标二的核心概念是如何提交POST表单和登录成功后带Cookie的请求。首先我们可以看到页面结构如下图所示:

python基于 Scrapy 的爬虫自动登录(内附python教程分享)

实现目标二

定义Item

python基于 Scrapy 的爬虫自动登录(内附python教程分享)

定义doumailspider

python基于 Scrapy 的爬虫自动登录(内附python教程分享)

这里需要注意的有三个地方:

第一个是meta中的cookiejar

Scrapy 通过使用 cookiejar Request meta key来支持单spider追踪多cookie session。默认情况下其使用一个cookie jar(session),不过您可以传递一个标示符来使用多个。

start_requests 我们这里重写了爬虫爬取得第一个页面,这里一开始就进去到登录页面

当执行爬虫的时候,我们需要把打印出来的验证码地址粘贴到浏览器中,手动输入到控制上完成验证。

同目标一一样需要设置settings中的相关参数,唯一不同的是ITEM_PIPELINES。

最后我们使用以下命令来启动爬虫

scrapy crawl douban-mail -o douban_mail_page1.csv

csv文件截图如下:

python基于 Scrapy 的爬虫自动登录(内附python教程分享)

最后,想学习Python的小伙伴们!

请关注+私信回复:“学习”就可以拿到一份我为大家准备的Python学习资料!

python基于 Scrapy 的爬虫自动登录(内附python教程分享)

pytyhon学习资料

python基于 Scrapy 的爬虫自动登录(内附python教程分享)

python学习资料

相关推荐