Scrapy使用的基本流程与实例讲解

作者:回忆不说话 时间:2022-08-15 17:51:19 

前面已经介绍过如何创建scrapy的项目,和对项目中的文件功能的基本介绍。

这次,就来谈谈使用的基本流程:

(1)首先第一点,打开终端,找到自己想要把scrapy工程创建的路径。这里,我是建立在桌面上的。打开终端,输入:
cd Desktop 就进入了桌面文件存储位置。

Scrapy使用的基本流程与实例讲解

(2)创建scrapy工程。终端输入:scrapy startproject image

Scrapy使用的基本流程与实例讲解

终端输入:cd image

继续输入:scrapy genspider imageSpider pic.netbian.com

Scrapy使用的基本流程与实例讲解

(3)在pycharm中打开刚才桌面的文件,进入settings.py设置爬虫规则。可以将规则直接注释掉,或者改为False

Scrapy使用的基本流程与实例讲解

(4) 回到爬虫文件。

Scrapy使用的基本流程与实例讲解

更改start_url,将爬虫默认的第一个网址更改为需要爬取的网站网址即可。

(5)下面就可以爬取数据了,这里选择了下载图片。

爬取完数据之后,要在存储数据的items.py文件中传输给管道

接下来在爬虫文件中引入管道模型。

from ..items import ImageItem

在爬虫文件中的parse函数中使用在items.py文件中创建的数据模型。

item = ImageItem()

注意点:

有时候在终端输出的时候,如果返回内容是scrapy.selector ,如果对象类型是scrapy.selector,那么这个对象可以被继续迭代,也可以用xpath继续寻找里面的内容。

如果终端遇到这个问题:

# ValueError:Missing scheme in request url:h

那么就需要使用extract()将xpath对象转化成列表对象。而列表对象,可以继续被迭代,但是不可以使用xpath来寻找里面的对象。

在下载之前还需要在settings.py文件中,对图片下载的路径和存储位置进行设置。

Scrapy使用的基本流程与实例讲解

下面附代码如下。仅有爬虫文件的代码:


# -*- coding: utf-8 -*-
import scrapy
from ..items import ImageItem
class ImagespiderSpider(scrapy.Spider):
 name = 'imageSpider'
 allowed_domains = ['pic.netbian.com']
 start_urls = ['http://pic.netbian.com/4kmeinv/']

def parse(self, response):
   img_list = response.xpath('//ul[@class="clearfix"]/li/a/img/@src')
   # 找到了很多src属性值,现在进行遍历,分别使用每一个
   for img in img_list:
     # 使用在items.py中创建的数据模型item
     item = ImageItem()
     print('--------------------')
     img = img.extract()
     # 拼接图片的url,得到完整的下载地址
     src = 'http://pic.netbian.com' +img
     # 将得到的数据放入到模型中
     # 因为是下载地址,所以要用列表包起来,否则会报错。
     item['src'] = [src]
     yield item
   next_url = response.xpath('//div[@class="page"]/a[text()="下一页"]/@href').extract()
   print('*****************************************************************')
   if len(next_url)!=0:
     url = 'http://pic.netbian.com'+next_url[0]
     # 将url传给scrapy.Request 得到的结果继续用self.parse进行处理
     yield scrapy.Request(url=url,callback=self.parse)

来源:https://blog.csdn.net/qq_39138295/article/details/81365941

标签:python,scrapy
0
投稿

猜你喜欢

  • Django开发中的日志输出的方法

    2023-02-24 07:37:17
  • Go语言使用sort包对任意类型元素的集合进行排序的方法

    2023-09-02 03:55:18
  • 浅谈Python中带_的变量或函数命名

    2023-08-30 15:44:08
  • 基于php socket(fsockopen)的应用实例分析

    2023-11-18 21:38:32
  • python matplotlib绘图,修改坐标轴刻度为文字的实例

    2023-09-29 12:27:57
  • URL编码与SQL注入

    2007-09-26 12:41:00
  • 浅谈Python pygame绘制机制

    2021-12-03 20:39:02
  • Python神经网络TensorFlow基于CNN卷积识别手写数字

    2022-06-18 20:23:00
  • Python基础知识方法重写+文件处理+异常处理

    2022-09-20 06:43:43
  • Python代理抓取并验证使用多线程实现

    2022-07-10 07:04:19
  • Python中装饰器的基本功能理解

    2021-05-26 05:17:56
  • Django项目中表的查询的操作

    2023-04-23 10:22:23
  • 前端优化,让你的网页显示的更快更流畅

    2009-06-08 13:09:00
  • Python装饰器的练习题

    2023-12-07 13:11:48
  • python非标准时间的转换

    2022-04-12 17:37:52
  • Python爬虫框架NewSpaper使用详解

    2022-06-03 06:20:26
  • 深入分析python中整型不会溢出问题

    2022-11-20 01:19:13
  • Kears+Opencv实现简单人脸识别

    2022-06-22 05:42:06
  • tensorflow创建变量以及根据名称查找变量

    2023-08-13 10:13:06
  • 彻底弄懂CSS盒子模式之二(导航栏实例)

    2007-05-11 16:52:00
  • asp之家 网络编程 m.aspxhome.com