Python+Pycharm +Scrapy搭建爬虫项目

                                                                       Python+Pycharm +Scrapy搭建爬虫项目

 

  Scrapy简介

  Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架。 可以应用在包括数据挖掘,信息处理或存储历史数据等一系列的程序中

  Scrapy框架的工作流程图如下:

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

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

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

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

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

 Downloader Middlewares(下载中间件):自定义扩展下载功能组件,可以进行服务器代理等设置

 Spider Middlewares(Spider中间件):可以自定义扩展和操作engine和Spider中间 通信的功能组件(比如进入Spider 的Responses,和从Spider出去的Requests)

 

一、准备工作

1.安装python3.x

2.下载PyCharm Community

3.安装Scrapy:安装好Python后,在cmd中输入以下命令   pip install scrapy 

 

二、搭建步骤

1.创建一个爬虫项目:通过scrapy startproject命令创建 

在cmd中运行命令:scrapy, 出现下图命令说明

执行 scrapy startproject [项目名],会在当前目录创建一个Scrapy项目

 

查看创建的scrapy项目的目录结构如下(拿以下项目举例):

①WebScraping项目根目录下包括一个同名的WebScraping包和一个scrapy.cfg配置文件;其中scrapy.cfg配置文件内容如下:

    指定该scrapy项目的setting文件为WebScraping包下的settings.py文件

②scrapTest模块下又包含了items、middlewares、pipelines、settings模块以及spider包

    (1) items模块中定义了items类,各items类必须继承scrapy.Item;通过scrapy.Field()定义各Item类中的类变量

import scrapy

class StockQuotationItem(scrapy.Item):
    '''

    '''
    order=scrapy.Field()
    symbol = scrapy.Field()
    instrument_name = scrapy.Field()
    price=scrapy.Field()
    pchg = scrapy.Field()
    chg = scrapy.Field()
    speed_up = scrapy.Field()
    turnover = scrapy.Field()
    QR = scrapy.Field()
    swing = scrapy.Field()
    vol = scrapy.Field()
    floating_shares = scrapy.Field()
    floating__net_value=scrapy.Field()
    PE = scrapy.Field()

 

    (2) middlewares模块中定义了各中间件类,包括SpiderMiddleWares、DownloadMiddleWares等

    (3) pipelines模块,用于处理spider中获取的items(将获取的items保存至文件或者数据库等):

        Pipeline类必须实现process_item()方法

# -*- coding: utf-8 -*-

# Define your item pipelines here
#
# Don't forget to add your pipeline to the ITEM_PIPELINES setting
# See: https://doc.scrapy.org/en/latest/topics/item-pipeline.html

import json

class WebScrapingPipeline(object):
    def __init__(self):
        self.f= open('spiderResult.json','wb')

    def process_item(self, item, spider):
        result=json.dumps(dict(item), ensure_ascii=False)+', \n'
        self.f.write(result.encode('utf-8'))

        #将Item返回至引擎,告知该item已经处理完成,你可以给我下一个item
        return item

    def close_spider(self,spider):
        self.f.close()

    (4) settings模块中包含了项目相关配置信息,包括指定S

  • 5
    点赞
  • 59
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值