Scrapy简单上手 —— 安装与流程
一.安装scrapy
由于scrapy依赖较多,建议使用虚拟环境
windows下pip安装(不推荐)
1.安装virtualenv
pip install virtualenv
2.在你开始项目的文件中创建虚拟环境
virtualenv --no-site-packages venv #这个是创建一个比较纯净的环境,与全局的packages隔绝,即原版环境。
3.进入虚拟环境
#linux环境
source venv/bin/activate #windows
.\venv\Scripts\activate
4.安装scrapy
pip install scrapy
大概率这里会报错,提示Twisted没有安装
解决办法是,先确定python的版本与32位还是64位,到这个网站https://www.lfd.uci.edu/~gohlke/pythonlibs/#twisted下载Twisted的whl安装
比如我python 3.6 64位就是Twisted‑19.2.1‑cp36‑cp36m‑win_amd64.whl
pip install Twisted‑19.2.1‑cp36‑cp36m‑win_amd64.whl
安装Twisted成功后再pip install scrapy,一般就会成功,但是这里仅仅是安装成功了而已,实际运行的时候各种报错,所以不建议win环境下这种方式安装
Anaconda安装
Anaconda本体安装略
1.创建Anaconda的虚拟环境(创建的虚拟环境都在Anaconda安装目录env下)
#查看当前虚拟环境
conda env list #创建虚拟环境
conda create -n your_env_name python=X.X(2.7、3.6等) #激活虚拟环境
Linux: source activate your_env_name(虚拟环境名称)
Windows: activate your_env_name(虚拟环境名称) #进入虚拟环境后提示符前有(your_env_name),此时安装包都是在虚拟环境中安装
conda install [package]或pip install #没进入虚拟环境可以这样装
conda install -n your_env_name [package]即可安装package到your_env_name中 #退出环境
Linux: source deactivate
Windows: deactivate
2.使用Anaconda Navigator管理库与虚拟环境
Anaconda自带的界面管理

这个软件实际就是上面那些命令的可视化
3.安装scrapy
conda install scrapy
或者在Navigator中直接搜索scrapy安装

Ubuntu安装scrapy
#安装pip sudo apt-get install python3-pip #安装依赖 sudo apt-get install python3 python3-dev python-pip libxml2-dev libxslt1-dev zlib1g-dev libffi-dev libssl-dev #安装scrapy sudo pip3 install scrapy
二.Scrapy流程
1.创建项目
scrapy startproject tutorial
创建后的目录结构如下
tutorial/
scrapy.cfg #部署配置文件
tutorial/ #项目的目录
__init__.py
items.py #item文件,数据的容器,有点类似ORM的model
middlewares.py #中间件
pipelines.py #pipelines文件,用来操作处理数据
settings.py #项目的设置文件
spiders/ #放置spider代码的目录
__init__.py
2.在创建spiders文件下创建个xxx_spider.py 文件(文件名字可以写清楚点),这里以官网文档的测试网址为例http://quotes.toscrape.com
spiders/quotes_spider.py import scrapy class QuotesSpider(scrapy.Spider):
name = "quotes" def start_requests(self):
urls = [
'http://quotes.toscrape.com/page/1/',
'http://quotes.toscrape.com/page/2/',
]
for url in urls:
yield scrapy.Request(url=url, callback=self.parse) def parse(self, response):
quotes = response.css('span.text::text').getall()
for quote in quotes:
print(quote)
(1)首先导入scrapy库
(2)创建类继承scrapy.Spider
(3)类属性name是指在运行scrapy时需要指定的名字,必须是唯一的
(4)定义start_requests()方法,表示需要抓取得网页,返回给scrapy.Request去请求
(5)scrapy.Request在处理完请求后,会将Response对象传给回调函数处理
(6)parse()定义的一个解析函数,是scrapy.Request中指定的回调函数,传入的Response对象在这里面处理
(7)response对象css方法使用css选择器来选择元素,返回一个列表的对象SelectorList,对象Selector可以继续查找,跟BS4中的元素对象类似(span.text表示class为text的span标签)
(8)::text不是规范的css选择器,是scrapy中特有的,用于提取标签里面的数据
(9).getall()是对象Selector的方法,用于返回所有结果的列表
3.运行爬虫
scrapy crawl quotes
这里quotes就是刚刚我们爬虫文件的name
4.scrapy框架的简单流程

(1)开始爬虫,Scrapy引擎从spiders中获取请求(即URL通过spiders 中间件处理过的请求)
(2)Scrapy引擎将获取的请求通过调度器中间件存入调度器
(3)调度器决定需要下载的请求,告知引擎,Scrapy引擎获取这些待下载请求
(4)Scrapy引擎将待下载请求通过下载中间件发给下载器,由下载器处理
(5)下载器下载完毕后生成响应对象又通过下载中间件传给引擎,然后引擎再通过爬虫中间件将响应传给spiders处理
(6)以上从发出请求到收到响应实际就是示例中yield scrapy.Request(url=url, callback=self.parse)的实现
(7)spiders收到响应后,使用回调函数处理响应,如果结果不需要再请求,可以将数据传至Item Pipeline处理;如果还有新的请求就会重复以上步骤直至无请求
三.高级一点点
1.start_requests简写
scrapy中默认使用parse回调函数,所以也提供了简写方法,只需要给类属性start_urls赋值URL列表即可
2.sub url的爬取
从响应中获取了sub url后,按如上scrapy流程,只需将sub url传入scrapy.Request即可,官网实例如下:
import scrapy class QuotesSpider(scrapy.Spider):
name = "quotes"
start_urls = [
'http://quotes.toscrape.com/page/1/',
] def parse(self, response):
for quote in response.css('div.quote'):
yield {
'text': quote.css('span.text::text').get(),
'author': quote.css('small.author::text').get(),
'tags': quote.css('div.tags a.tag::text').getall(),
} next_page = response.css('li.next a::attr(href)').get()
if next_page is not None:
next_page = response.urljoin(next_page)
yield scrapy.Request(next_page, callback=self.parse)
(1)parse中yield一个字典是可以返回给pipelines处理
(2)li.next a::attr(href) 选择表示<li class="next">标签下子元素<a>的href属性值,这里::attr与::text类似,不同是筛选元素属性的值
(3)response.urljoin()是构建完整URL的一个方法
(4)将next page的url传给scrapy.Request继续处理,得到response后,继续调用self.parse直到没有下一页
(5)yield是一个类似return 的关键字,迭代一次遇到yield的时候就返回yield后面或者右面的值。而且下一次迭代的时候,从上一次迭代遇到的yield后面的代码开始执行
3.response.follow方法
上面处理sub url使用的是先提取URL,再进行传递
response.follow()则是简化提取URL流程的方法,可以自动获取URL,比如上面可以优化为
#传入相对url
next_page = response.css('li.next a::attr(href)').get()
if next_page is not None:
yield response.follow(next_page, callback=self.parse) #传入href的selector对象
for href in response.css('li.next a::attr(href)'):
yield response.follow(href, callback=self.parse) #传入a的selector对象
for a in response.css('li.next a'):
yield response.follow(a, callback=self.parse)
四.小实战
爬取dytt最新的电影以及下载地址,spiders代码如下
import scrapy class DyttSpider(scrapy.Spider):
name = "dytt"
start_urls = [
'https://www.dytt8.net/',
] def parse(self, response):
movies = response.css('div.co_content8')[0].css('td.inddline[height="22"]')[1:]
for movie in movies:
movie_href = movie.css("a::attr(href)")[1].get()
yield response.follow(movie_href,callback = self.movieparse) def movieparse(self,response):
yield {
'movie_name':response.css("div.title_all font::text").get(),
'download_link':response.css('table td[bgcolor="#fdfddf"] a::text').get()
}
运行以及保存数据为csv
scrapy crawl dytt -o dytt.csv
Scrapy简单上手 —— 安装与流程的更多相关文章
- Python之Scrapy爬虫框架安装及简单使用
题记:早已听闻python爬虫框架的大名.近些天学习了下其中的Scrapy爬虫框架,将自己理解的跟大家分享.有表述不当之处,望大神们斧正. 一.初窥Scrapy Scrapy是一个为了爬取网站数据,提 ...
- 超简单Windows安装Scrapy (仅需一步)
网上很多关于windows安装Scrapy的教程都非常的繁琐,请看我给大家分享的教程,非常简单 一步完成. 超简单的安装方法: 下载地址: https://www.continuum.io/downl ...
- [转]Scrapy简单入门及实例讲解
Scrapy简单入门及实例讲解 中文文档: http://scrapy-chs.readthedocs.io/zh_CN/0.24/ Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用 ...
- 在Centos上安装RabbitMQ流程(转)
在Centos上安装RabbitMQ流程------------------------ 1. 需求 由于项目中要用到消息队列,经过ActiveMQ与RabbitMQ的比较,最终选择了RabbbitM ...
- OpenStack Keystone安装部署流程
之前介绍了OpenStack Swift的安装部署,采用的都是tempauth认证模式,今天就来介绍一个新的组件,名为Keystone. 1. 简介 本文将详细描述Keystone的安装部署流程,并给 ...
- scrapy爬虫学习系列二:scrapy简单爬虫样例学习
系列文章列表: scrapy爬虫学习系列一:scrapy爬虫环境的准备: http://www.cnblogs.com/zhaojiedi1992/p/zhaojiedi_python_00 ...
- scrapy简单入门及选择器(xpath\css)
简介 scrapy被认为是比较简单的爬虫框架,资料比较齐全,网上也有很多教程.官网上介绍了它的四种安装方法,PyPI.Conda.APT.Source,我们只介绍最简单的安装方法. 安装 Window ...
- 我的第一个activiti实例 (代码方式) ctiviti入门列子一个简单的activiti请假流程
转: (activiti入门列子一个简单的activiti请假流程) 我的第一个activiti实例 2017年05月31日 14:29:45 chf_mixueer 阅读数:1223 整个项目的 ...
- 浅析Scrapy框架运行的基本流程
本篇博客将从Twisted的下载任务基本流程开始介绍,然后再一步步过渡到Scrapy框架的基本运行流程,其中还会需要我们自定义一个Low版的Scrapy框架.但内容不会涉及太多具体细节,而且需要注意的 ...
随机推荐
- Huffman树及其编解码
Huffman树--编解码 介绍: Huffman树可以根据输入的字符串中某个字符出现的次数来给某个字符设定一个权值,然后可以根据权值的大小给一个给定的字符串编码,或者对一串编码进行解码,可以用于 ...
- 就个人银行账户管理程序谈谈C++和Java的异同
4_9 同: Java和C++都是面向对象的语言.都有数据成员,方法,访问权限的概念. 异: 访问权限上,非private时Java的默认访问权限是包.而C++的默认访问权限是private.Java ...
- Bran的内核开发教程(bkerndev)-03 内核初步
目录 内核初步 内核入口 链接脚本 汇编和链接 PS: 下面是我自己写的 64位Linux下的编译脚本 内核初步 在这节教程, 我们将深入研究一些汇编程序, 学习创建链接脚本的基础知识以及使用它的 ...
- Vue核心之数据劫持
前瞻 当前前端界空前繁荣,各种框架横空出世,包括各类mvvm框架横行霸道,比如Anglar,Regular,Vue,React等等,它们最大的优点就是可以实现数据绑定,再也不需要手动进行DOM操作了, ...
- 关于用gulp合并压缩seaJs模块
现在很多人都在用seaJs来开发项目,seaJs上手容易,操作简单.但在后期做合并压缩的时候却中了个巨大无比的坑,但坑也总得有人来填.于是花了将近一个星期的时间来填了这坑,现将填坑的一些心得与大家分享 ...
- Cocos2d-x 学习笔记(11.8) DelayTime ReverseTime TargetedAction ActionFloat Blink TintTo TintBy ResizeTo ResizeBy
1. DelayTime 通过create方法create(float d)设置时长,update方法没有任何操作.可以用于动作之间的延迟. 2. ReverseTime create方法create ...
- Go语言系列开发之延迟调用和作用域
Hello,各位小伙伴大家好,我是小栈君,最近一段时间我们将继续分享关于go语言基础系列,当然后期小栈君已经在筹划关于java.Python,数据分析.人工智能和大数据等相关系列文章.希望能和大家一起 ...
- 记因git规范导致的提测和发布延迟
号外 最近因为换工作的原因,我的博客和Github没有像之前那样频繁的更新了.一方面原因是投递简历和准备面试,由于之前的基础没有很扎实,需要把平时的知识点都整理一遍.这个时间段持续了20多天的样子,因 ...
- Apache常见配置
一.yum安装与配置 1.1安装: [root@apache ~]# yum install http\* -y [root@apache ~]# echo "test01" ...
- 使用zrender.js绘制体温单(2)
今天我们来画折线图 效果图 以下为模拟数据 [{"time":19,"text":"入\n院\n19\n时\n11\n分","po ...