文章目录

  • scrapy框架
    • 安装
    • 创建一个scrapy项目
    • 终端工具命令

scrapy框架

安装

pip install scrapy

创建一个scrapy项目

scrapy startproject tutorial

创建一个tutorial包含以下内容的目录:

tutorial/scrapy.cfg            # 项目的配置文件tutorial/             # python模块,在这里添加你的爬虫项目__init__.pyitems.py          # 项目的字段定义文件middlewares.py    # 项目的中间件文件pipelines.py      # 项目的管道文件,一般用于保存数据settings.py       # 项目的设置文件spiders/          # 一个爬虫目录,用于存放爬虫文件__init__.py

  • Scrapy Engine(引擎): 负责Spider、ItemPipeline、Downloader、Scheduler中间的通讯,信号、数据传递等。

  • Scheduler(调度器): 它负责接受引擎发送过来的Request请求,并按照一定的方式进行整理排列,入队,当引擎需要时,交还给引擎。

  • Downloader(下载器):负责下载Scrapy Engine(引擎)发送的所有Requests请求,并将其获取到的Responses交还给Scrapy Engine(引擎),由引擎交给Spider来处理,

  • Spider(爬虫):它负责处理所有Responses,从中分析提取数据,获取Item字段需要的数据,并将需要跟进的URL提交给引擎,再次进入Scheduler(调度器),

  • Item Pipeline(管道):它负责处理Spider中获取到的Item,并进行进行后期处理(详细分析、过滤、存储等)的地方.

  • Downloader Middlewares(下载中间件):你可以当作是一个可以自定义扩展下载功能的组件。

  • Spider Middlewares(Spider中间件):你可以理解为是一个可以自定扩展和操作引擎和Spider中间通信的功能组件(比如进入Spider的Responses;和从Spider出去的Requests)

制作 Scrapy 爬虫 一共需要4步:

  • 新建项目 (scrapy startproject xxx):新建一个新的爬虫项目
  • 明确目标 (编写items.py):明确你想要抓取的目标
  • 制作爬虫 (spiders/xxspider.py):制作爬虫开始爬取网页
  • 存储内容 (pipelines.py):设计管道存储爬取内容

终端工具命令

查看命令的相关信息
scrapy <command> -h

查看所有可用命令
scrapy -h

全局命令:
startproject
genspider
settings
runspider
shell
fetch
view
version

项目专用命令:
crawl
check
list
edit
parse
bench

1、创建项目
语法:scrapy startproject <project_name> [project_dir]
是否需要项目:否

在project_dir 目录下创建一个名为 project_name的新 Scrapy 项目。如果project_dir未指定,project_dir将与project_name同名.例如:scrapy startproject myproject

2、创建爬虫项目
语法:scrapy genspider [-t template] <name> <domain>
是否需要项目:否

spiders如果从项目内部调用,则在当前文件夹或当前项目的文件夹中创建一个新爬虫。该<name>参数设置为爬虫的name,而<domain>用于生成allowed_domains和start_urls爬虫的属性。例如:scrapy genspider -l 列出可用的模板scrapy genspider -t crawl scrapyorg scrapy.org

3、启动爬虫
语法:scrapy crawl <spider>
是否需要项目:是

开始爬虫启动例如:scrapy crawl myspider

4、查看
语法:scrapy check [-l] <spider>
是否需要项目:是

运行合同检查例如:scrapy check -lscrapy check

5、列表
语法:scrapy list
是否需要项目:是

列出当前所有可用的爬虫。

6、编辑
语法:scrapy edit <spider>
是否需要项目:是

使用EDITOR环境变量中定义的编辑器或(如果未设置)EDITOR设置编辑给定的蜘蛛。

7、查看某个网址内容
语法:scrapy fetch <url>
是否需要项目:否

使用scrapy下载器下载给定的url并将内容标准输出。支持的选项:--spider=SPIDER:绕过蜘蛛自动检测并强制使用特定蜘蛛--headers: 打印响应的 HTTP 标头而不是响应的正文--no-redirect:不遵循 HTTP 3xx 重定向(默认是遵循它们)--nolog:不打印日志例如:scrapy fetch --nolog http://www.example.com/some/page.htmlscrapy fetch --nolog --headers http://www.example.com/

8、查看view
语法:scrapy view <url>
是否需要项目:否

在浏览器中打开给定的 URL,因为你的 Scrapy 蜘蛛会“看到”它。有时蜘蛛看到的页面与普通用户不同,因此这可用于检查蜘蛛“看到”的内容并确认它是您所期望的。支持的选项:--spider=SPIDER:绕过蜘蛛自动检测并强制使用特定蜘蛛--no-redirect:不遵循 HTTP 3xx 重定向(默认是遵循它们)例如:scrapy view http://www.example.com/some/page.html

9、shell
语法:scrapy shell [url]
是否需要项目:否

为给定的 URL(如果给定)启动 Scrapy shell,如果没有给定 URL,则为空。还支持 UNIX 风格的本地文件路径,可以是相对的 ./或../前缀或绝对文件路径。支持的选项:--spider=SPIDER:绕过蜘蛛自动检测并强制使用特定蜘蛛-c code: 在 shell 中评估代码,打印结果并退出--no-redirect:不遵循 HTTP 3xx 重定向(默认是遵循它们);这只会影响您可以在命令行上作为参数传递的 URL;一旦进入 shell,fetch(url)默认情况下仍将遵循 HTTP 重定向。例如:scrapy shell http://www.example.com/some/page.htmlscrapy shell --nolog http://www.example.com/ -c (response.status,response.url)

10、解析parse
语法:scrapy parse <url> [options]
是否需要项目:是

获取给定的 URL 并使用处理它的蜘蛛解析它,使用与--callback选项一起传递的方法支持的选项:--spider=SPIDER:绕过蜘蛛自动检测并强制使用特定蜘蛛--a NAME=VALUE: 设置蜘蛛参数(可能会重复)--callback或-c:用作解析响应的回调的蜘蛛方法--meta或-m:将传递给回调请求的附加请求元。这必须是有效的 json 字符串。示例:–meta='{“foo” : “bar”}'--cbkwargs:将传递给回调的附加关键字参数。这必须是有效的 json 字符串。示例:–cbkwargs='{“foo” : “bar”}'--pipelines:通过管道处理项目--rules或-r:使用CrawlSpider 规则来发现用于解析响应的回调(即蜘蛛方法)--noitems: 不显示被刮掉的物品--nolinks: 不显示提取的链接--nocolour: 避免使用 pygments 为输出着色--depth或-d:应递归跟踪请求的深度级别(默认值:1)--verbose或-v: 显示每个深度级别的信息--output或-o:将抓取的项目转储到文件中例如:scrapy parse http://www.example.com/ -c parse_item

11、设置
语法:scrapy settings [options]
是否需要项目:是

获取scrapy设置的值
如果在项目中使用,它将显示项目设置值,否则将显示该设置的默认 Scrapy 值。例如:scrapy settings --get BOT_NAMEtutoscrapy settings --get DOWNLOAD_DELAY0

12、运行spider
语法:scrapy runspider <spider_file.py>
是否需要项目:否

在 Python 文件中运行spider,而无需创建项目。例如:scrapy runspider myspider.py

13、版本
语法:scrapy version [-v]
是否需要项目:否

打印 Scrapy 版本。如果与-v它一起使用,还会打印 Python、Twisted 和平台信息,这对错误报告很有用。

14、bench
语法:scrapy bench
是否需要项目:否

测试scrapy运行的速

python爬虫之Scrapy(一)相关推荐

  1. python爬虫之Scrapy框架的post请求和核心组件的工作 流程

    python爬虫之Scrapy框架的post请求和核心组件的工作 流程 一 Scrapy的post请求的实现 在爬虫文件中的爬虫类继承了Spider父类中的start_urls,该方法就可以对star ...

  2. python 爬虫实例-Python 爬虫:Scrapy 实例(二)

    原标题:Python 爬虫:Scrapy 实例(二) 稍微增加点难度,做个所需项目多一点的,并将的结果以多种形式保存起来.我们就从网络天气预报开始. 首先要做的是确定网络天气数据的来源.打开百度,搜索 ...

  3. 精通python爬虫框架-精通Python爬虫从Scrapy到移动应用(文末福利)

    原标题:精通Python爬虫从Scrapy到移动应用(文末福利) 我能够听到人们的尖叫声:"Appery.io是什么,一个手机应用的专用平台,它和Scrapy有什么关系?"那么,眼 ...

  4. python常用命令汇总-Python爬虫框架Scrapy常用命令总结

    本文实例讲述了Python爬虫框架Scrapy常用命令.分享给大家供大家参考,具体如下: 在Scrapy中,工具命令分为两种,一种为全局命令,一种为项目命令. 全局命令不需要依靠Scrapy项目就可以 ...

  5. 精通python爬虫框架-精通Python爬虫框架Scrapy.pdf

    作 者 :(美)迪米特里奥斯·考奇斯·劳卡斯(Dimitrios Kouzis Loukas)著:李斌译 出版发行 : 北京:人民邮电出版社 , 2018.02 ISBN号 :978-7-115-47 ...

  6. 阅读《精通Python爬虫框架Scrapy》

    精通Python爬虫框架Scrapy 精通Python爬虫框架Scrapy 2018年2月的书,居然代码用的是Python2 环境使用的是Vagrant,但是由于国内网络的问题,安装的太慢了. 书里内 ...

  7. python数据分析案例2-1:Python练习-Python爬虫框架Scrapy入门与实践

    本文建立在学习完大壮老师视频Python最火爬虫框架Scrapy入门与实践,自己一步一步操作后做一个记录(建议跟我一样的新手都一步一步进行操作). 主要介绍: 1.scrapy框架简介.数据在框架内如 ...

  8. python爬虫之Scrapy介绍八——Scrapy-分布式(以爬取京东读书为示例)

    Scrapy-分布式(scrapy-redis)介绍 1 Scrapy-分布式介绍 1.1 Scrapy-redis工作原理 1.2 Scrapy-redis 安装和基本使用 1.2.1 安装 1.2 ...

  9. [Python 爬虫] 使用 Scrapy 爬取新浪微博用户信息(四) —— 应对反爬技术(选取 User-Agent、添加 IP代理池以及Cookies池 )

    上一篇:[Python 爬虫] 使用 Scrapy 爬取新浪微博用户信息(三) -- 数据的持久化--使用MongoDB存储爬取的数据 最近项目有些忙,很多需求紧急上线,所以一直没能完善< 使用 ...

  10. Python爬虫之scrapy框架360全网图片爬取

    Python爬虫之scrapy框架360全网图片爬取 在这里先祝贺大家程序员节快乐,在此我也有一个好消息送给大家,本人已开通了微信公众号,我会把资源放在公众号上,还请大家小手动一动,关注过微信公众号, ...

最新文章

  1. TPC-W 一个实验结果和分析
  2. java io nio aio_Java IO、NIO、AIO知识总结
  3. ArcGIS 10.5专题地图制作自定义漂亮图框
  4. java 正则表达式 手机号 邮箱(转载)
  5. 卷积神经网络学习指南_卷积神经网络的直观指南
  6. kvm虚拟机块对齐问题研究
  7. 在Linux 安装Python3.5.6详细文档!!!!
  8. Centos8下nginx源码编译安装
  9. 从游击队到正规军(三):基于Go的马蜂窝旅游网分布式IM系统技术实践
  10. 32句期权交易的浓缩精华
  11. 3D打印中常见的7中材质分析
  12. 应用与系统稳定性第五篇---Watchdog原理和问题分析
  13. 白杨SEO:谈谈我理解的品牌,个人与企业品牌的区别
  14. 本科毕业生入户广州需要的材料清单
  15. 计算机网络另一方找不到,网络共享找不到对方电脑怎么办
  16. Qt QPushButton checked 时候颜色变浅不对
  17. 慕尼黑高等法院:脸书强制用户使用真实姓名合法
  18. JCJC错别字检测Windows客户端发布了
  19. html+css制作简易12306页面
  20. 【Eclipse】使用指南(6)添加新方法

热门文章

  1. Qt在手动执行xxx.exe时报错:由于找不到Qt5xxx.dll,无法继续执行代码。重新安装程序可能解决此问题。
  2. 云计算在未来生活中的霸主地位逐渐体现!
  3. ThinkPhp 表单提交数据
  4. 伯克利文理学院的计算机课程,加州大学伯克利分校计算机科学研究生Offer及录取要求...
  5. qt 容器组控件 Containers
  6. 云队友丨王兴的无限游戏:很多人误认为干掉对手,就胜利结束
  7. Android手机无法使用google地图的问题的解决方案
  8. Home Assistant 群里炸开锅了:涂鸦发布新插件啦! 赶紧冲!
  9. txt文档操作(导出和导入)【工具包系列】
  10. 常见面试问题之Verilog、SV(一)