scrapy知识补充--scrapy shell 及Spider

什么是scrapy shell?

Scrapy终端是一个交互终端,我们可以在未启动spider的情况下尝试及调试代码,也可以用来测试xpath或css表达是,来查看他们的工作方式,方便爬取页面中的数据。

selector选择器(scrapy内置)

Selecctor有四个基本方法,最常用的还是xpath:

  • xpath():传入xpath表达式,返回该列表所对应的所有节点的selector的list
  • extract():序列化该节点为Unicode字符串,并返回list
  • css():传入css表达式,返回该表达式的所对应的所有节点的list列表,语法同BeautifulSoup4
  • re():根据传入的正则表达式对数据进行提取,返回Unicode字符串列表

Spider是做什么的?

什么是Spider?

Spider类定义了如何爬取某个(某些)网站。包括爬取动作(例如:是否跟进链接)以及如何从昂也中提取结构化数据(爬取的item)。换句话说,spider就是已经定义的爬取动作以及分析某个网页的地方。

Spider的属性和方法

主要属性和方法:

name:定义spider名字的字符串。例如,如果spider爬取website.com,该spider通常会被命名为website

allowed_domains:包含了允许爬取的域名(domain)的列表,可选。

start_url:初始URL的元祖或列表。当没有给定特定的url时,spider将从该列表中开始进行爬取。

start_requests(self):该方法返回一个可迭代对象(iterable)。该对象包含了spider用于爬取(默认实现是用start_url中的url)的第一个Request。

parse(self, response):当请求url返回网页没有指定回调函数时,默认的Request对象回调函数。用来处理网页返回的response,以及生成的item或Request对象。

怎样编写Spider爬取数据?

参见:

原文地址:https://www.cnblogs.com/pythoner6833/p/9017815.html