返回顶部
首页 > 资讯 > 后端开发 > Python >python3 scrapy框架的执行流程
  • 778
分享到

python3 scrapy框架的执行流程

2024-04-02 19:04:59 778人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

scrapy框架概述:Scrapy,python开发的一个快速,高层次的屏幕抓取和WEB抓取框架,用于抓取web站点并从页面中提取结构化的数据。Scrapy用途广泛,可以用于数据挖掘

scrapy框架概述:Scrapy,python开发的一个快速,高层次的屏幕抓取和WEB抓取框架,用于抓取web站点并从页面中提取结构化的数据。Scrapy用途广泛,可以用于数据挖掘、监测和自动化测试

创建项目

由于PyCharm不能直接创建scrapy项目,必须通过命令行创建,所以相关操作在pycharm的终端进行:
1、安装scrapy模块:
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple scrapy
2、创建一个scrapy项目:scrapy startproject test_scrapy
4、生成一个爬虫:scrapy genspider itcast "itcast.cn”
5、提取数据:完善spider,使用xpath等方法
6、保存数据:pipeline中保存数据

常用的命令

创建项目:scrapy startproject xxx
进入项目:cd xxx #进入某个文件夹下
创建爬虫:scrapy genspider xxx(爬虫名) xxx.com (爬取域)
生成文件:scrapy crawl xxx -o xxx.JSON (生成某种类型的文件)
运行爬虫:scrapy crawl XXX
列出所有爬虫:scrapy list
获得配置信息:scrapy settings [options]

Scrapy项目下文件

scrapy.cfg: 项目的配置文件
test_scrapy/: 该项目的python模块。在此放入代码(核心)
test_scrapy/items.py: 项目中的item文件.(这是创建容器的地方,爬取的信息分别放到不同容器里)
test_scrapy/pipelines.py: 项目中的pipelines文件.
test_scrapy/settings.py: 项目的设置文件.(我用到的设置一下基础参数,比如加个文件头,设置一个编码)
test_scrapy/spiders/: 放置spider代码的目录. (放爬虫的地方)

scrapy

scrapy框架的整体执行流程

1.spider的yeild将request发送给engine
2.engine对request不做任何处理发送给scheduler
3.scheduler,生成request交给engine
4.engine拿到request,通过middleware发送给downloader
5.downloader在\获取到response之后,又经过middleware发送给engine
6.engine获取到response之后,返回给spider,spider的parse()方法对获取到的response进行处理,解析出items或者requests
7.将解析出来的items或者requests发送给engine
8.engine获取到items或者requests,将items发送给ItemPipeline,将requests发送给scheduler(ps,只有调度器中不存在request时,程序才停止,及时请求失败scrapy也会重新进行请求)

关于yeild函数介绍

简单地讲,yield 的作用就是把一个函数变成一个 generator(生成器),带有 yield 的函数不再是一个普通函数,Python 解释器会将其视为一个 generator,带有yeild的函数遇到yeild的时候就返回一个迭代值,下次迭代时, 代码从 yield 的下一条语句继续执行,而函数的本地变量看起来和上次中断执行前是完全一样的,于是函数继续执行, 直到再次遇到 yield。

通俗的讲就是:在一个函数中,程序执行到yield语句的时候,程序暂停,返回yield后面表达式的值,在下一次调用的时候,从yield语句暂停的地方继续执行,如此循环,直到函数执行完。

到此这篇关于python3 scrapy框架的执行流程的文章就介绍到这了,更多相关python3 scrapy框架内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: python3 scrapy框架的执行流程

本文链接: https://lsjlt.com/news/130096.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • python3 scrapy框架的执行流程
    scrapy框架概述:Scrapy,Python开发的一个快速,高层次的屏幕抓取和web抓取框架,用于抓取web站点并从页面中提取结构化的数据。Scrapy用途广泛,可以用于数据挖掘...
    99+
    2024-04-02
  • python3 scrapy框架的执行流程是什么
    这篇文章主要讲解了“python3 scrapy框架的执行流程是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“python3 scrapy框架的执行流程是什么”吧!scrapy框架概述:...
    99+
    2023-06-20
  • python3安装scrapy框架
    方法一: 1.执行pip install scrapy命令 2.这时肯定会报错,由于scrapy依赖的包比较多,执行上述操作,已经将大部分的依赖包安装好 3.安装Twisted:下载网址 4.下载完成后,可以进入下载文件的目录执行pip ...
    99+
    2023-01-30
    框架 scrapy
  • Python3 爬虫 scrapy框架
    上次用requests写的爬虫速度很感人,今天打算用scrapy框架来实现,看看速度如何。 第一步,安装scrapy,执行一下命令 pip install Scrapy 第二步,创建项目,执行一下命令 scrapy startproje...
    99+
    2023-01-31
    爬虫 框架 scrapy
  • Scrapy 框架流程详解
    Scrapy 使用了 Twisted 异步非阻塞网络库来处理网络通讯,整体架构大致如下(绿线是数据流向):     简单叙述一下每层图的含义吧: Spiders(爬虫):它负责处理所有Responses,从中分析提取数据,获取Ite...
    99+
    2023-01-30
    详解 框架 流程
  • mybatis框架的执行流程是什么
    MyBatis框架的执行流程大致如下: 加载MyBatis配置文件:MyBatis会读取并解析mybatis-config.xm...
    99+
    2024-04-02
  • ​thinkphp框架执行流程的示例分析
    这篇文章给大家分享的是有关thinkphp框架执行流程的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。thinkphp框架执行流程 首先总结一下,框架执行的大致流程: index.php->载入框架...
    99+
    2023-06-06
  • SpringMvc框架的简介与执行流程详解
    目录一、SpringMvc框架简介 1、Mvc设计理念2、SpringMvc简介 二、SpringMvc执行流程 1、流程图解2、步骤描述 3、核心组件 三、整合Spring框架配置...
    99+
    2024-04-02
  • MySQL架构与执行流程
    前言:   MySQL数据库自己用了也有两三年了,基本上只是掌握增删改查的sql语句,从没有思考过MySQL的内部到底是怎么根据sql查询数据的,包括索引的原理,只知道加了索引查的就快,不知道为什么加上索引效率就会提升,包括索引的限制和优化...
    99+
    2020-05-27
    MySQL架构与执行流程 数据库入门 数据库基础教程 数据库 mysql
  • Mysql 架构及执行流程
    1. mysql 架构 1.1 简化版架构 客户端+ 核心服务 + 存储引擎 ⬇︎ ⬆︎(客户端)⬇︎⬆︎ =====【连接/线程处理】====} ⬇︎ ⬇︎ ...
    99+
    2016-09-17
    Mysql 架构及执行流程
  • MySQL基础架构的执行流程
    本篇内容介绍了“MySQL基础架构的执行流程”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!MySQL的架构...
    99+
    2024-04-02
  • Python抓取框架 Scrapy的架构
    最近在学Python,同时也在学如何使用python抓取数据,于是就被我发现了这个非常受欢迎的Python抓取框架Scrapy,下面一起学习下Scrapy的架构,便于更好的使用这个工具。 一、概述 下图显示...
    99+
    2022-06-04
    架构 框架 Python
  • scrapy框架ItemPipeline的使用
    目录Item Pipeline简介功能:一、一个自己的Pipeline类二、启用一个Item Pipeline组件将item写入JSON文件将item写入MongoDBItem Pi...
    99+
    2024-04-02
  • Python的Scrapy框架解析
    目录一.为什么使用Scrapy框架?二.Scrapy框架每个组件介绍三.Scrapy框架工作原理总结一.为什么使用Scrapy框架? Scrapy是一个快速、高层次的...
    99+
    2024-04-02
  • django框架的运行流程是什么
    Django框架的运行流程主要包括以下几个步骤:1. 客户端发送请求:用户在浏览器中输入URL地址或点击链接,向服务器发送HTTP请...
    99+
    2023-10-07
    django
  • 深入剖析Python的爬虫框架Scrapy的结构与运作流程
    网络爬虫(Web Crawler, Spider)就是一个在网络上乱爬的机器人。当然它通常并不是一个实体的机器人,因为网络本身也是虚拟的东西,所以这个“机器人”其实也就是一段程序,并且它也不是乱爬,而是有一...
    99+
    2022-06-04
    爬虫 框架 流程
  • scrapy框架的简单介绍
    这篇文章主要介绍“scrapy框架的简单介绍”,在日常操作中,相信很多人在scrapy框架的简单介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”scrapy框架的简单介绍”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-06-02
  • laravel框架是如何执行的
    这篇“laravel框架是如何执行的”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“laravel框架是如何执行的”文章吧。一...
    99+
    2023-07-06
  • 10个流行的PHP框架
    10个流行的PHP框架 在Web开发中,PHP是一个非常流行的编程语言,因为它具有广泛的应用范围、易于学习和使用、稳定性强等诸多优点。PHP框架是一种Web开发工具,它为开发人员提供了一些常用的功能和工具,例如路由、模板引擎、ORM等等,使...
    99+
    2023-08-31
    php 数据库 前端
  • golang框架与其他流行框架的比较?
    go 框架因出色的性能和可扩展性而脱颖而出。它们比解释语言执行速度更快,内存消耗更低。与 django 和 express.js 相比,go 框架在这些方面更胜一筹。虽然 django ...
    99+
    2024-05-24
    对比 go框架 python git golang
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作