Scrapy框架的基本使用及注意事項(xiàng)

創(chuàng)建一個(gè)工程和Spider模板

我們先用命令行創(chuàng)建一個(gè)Scrapy工程:

  $ scrapy startproject soudu

接著,我們進(jìn)入到工程目錄:

  $ cd soudu

我們來(lái)看一下目錄結(jié)構(gòu):

tree
# OUT:
 ├── soudu                  #外層目錄
│   ├── __init__.py         #初始化腳本    
│   ├── __pycache__         #Python緩存文件。暫時(shí)無(wú)視
│   ├── items.py            #Items代碼模板,繼承類自scrapy.Item
│   ├── middlewares.py      #Middlewares代碼模板(繼承類)
│   ├── pipelines.py        #Pipelines代碼模板(繼承類)
│   ├── settings.py         #Scrapy爬蟲(chóng)的配置文件
│   └── spiders             #Spiders代碼模板目錄 我們寫(xiě)爬蟲(chóng)的地方
│       ├── __init__.py
│       └── __pycache__
└── scrapy.cfg              #部署爬蟲(chóng)的配置文件

4 directories, 7 files

最后,我們用命令行創(chuàng)建第一個(gè)Spider:

$ scrapy genspider right www.sodu.cc

這樣我們就創(chuàng)建了一個(gè)名為right的爬蟲(chóng)了

步驟二:編寫(xiě)Spider

我們來(lái)著手定制我們的爬蟲(chóng)吧:

看一下詳細(xì)的注釋

# -*- coding: utf-8 -*-
import scrapy
# 將我們需要爬的項(xiàng)目引入進(jìn)來(lái)
from soudu.items import SouduItem

class DemoSpider(scrapy.Spider):
  
    #該爬蟲(chóng)的名字
    name = "title"

    #規(guī)定爬蟲(chóng)爬取網(wǎng)頁(yè)的域名   
    allowed_domains = ['www.sodu.cc']

    #開(kāi)始爬取的url鏈接
    start_urls = ['http://www.sodu.cc/']

    def parse(self, response):
      ''' 
        parse()函數(shù)接收Response參數(shù),就是網(wǎng)頁(yè)爬取后返回的數(shù)據(jù) 用于處理響應(yīng),
        他負(fù)責(zé)解析爬取的內(nèi)容 生成解析結(jié)果的字典,并返回新的需要爬取的請(qǐng)求
      ''' 
    #由于是demo 我們不做完全的功能, #只要求爬取出第一部小說(shuō)的名字 
      #xpath規(guī)則可以通過(guò)查看網(wǎng)頁(yè)源文件得出,chrome右鍵檢查定位到所要爬取的內(nèi)容

      name = response.xpath('//a[@onclick="getpage(this)"]/text()').extract()[0] 
      #建立一個(gè)items字典,用于保存我們爬到的結(jié)果,并返回給pipline處理
     items = {} 
     items['第一部小說(shuō)名']= name
     return items

步驟三:編寫(xiě)Item Pipeline

首先我們編寫(xiě)itmes.py來(lái)定義這個(gè)爬蟲(chóng)框架需要爬哪些內(nèi)容:

import scrapy
class SouduItem(scrapy.Item):
    # define the fields for your item here like:
    # name = scrapy.Field()
    name = scrapy.Field() 

接著我們編寫(xiě) piplines.py來(lái)處理spider爬到的內(nèi)容:

  class ZimukuPipeline(object):

       def process_item(self, item, spider):

    # 因?yàn)槭亲詈?jiǎn)單的,所以我們把爬到的結(jié)果打印一下

       print(item)

       return item

步驟四:優(yōu)化配置Settings.py

BOT_NAME = 'soudu'

SPIDER_MODULES = ['soudu.spiders']
NEWSPIDER_MODULE = 'soudu.spiders'

# Obey robots.txt rules
ROBOTSTXT_OBEY = True

#只增加了這一行,通過(guò)配置告訴Scrapy明白是誰(shuí)來(lái)處理結(jié)果
ITEM_PIPELINES = {
 'soudu.pipelines.SouduPipeline': 300,
}

首先我們通過(guò)命令來(lái)執(zhí)行爬蟲(chóng):

$ scrapy crawl title

我只截取部分我們需要的內(nèi)容:

2018-08-03 19:31:53 [scrapy.core.scraper] DEBUG: Scraped from <200 http://www.sodu.cc/>
{'第一部小說(shuō)名': '圣墟'}

注意事項(xiàng):

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • https://www.lfd.uci.edu/~gohlke/pythonlibs/#lxml 下載即可。 安裝...
    慫恿的大腦閱讀 1,403評(píng)論 0 7
  • scrapy學(xué)習(xí)筆記(有示例版) 我的博客 scrapy學(xué)習(xí)筆記1.使用scrapy1.1創(chuàng)建工程1.2創(chuàng)建爬蟲(chóng)模...
    陳思煜閱讀 13,067評(píng)論 4 46
  • 精減版內(nèi)容 2018年4月22日,“前哨大會(huì)2018——全球科技創(chuàng)新地圖” 在深圳舉行。王煜全就十大未來(lái)趨勢(shì)與這些...
    沉落的星星閱讀 2,569評(píng)論 0 1
  • 親愛(ài)的,我怕 怕一轉(zhuǎn)身,我就找不到方向 在也看不見(jiàn)你堅(jiān)毅的目光 帶我走出迷茫 親愛(ài)的,我怕 怕一轉(zhuǎn)念,我就點(diǎn)不了激...
    東方晨曦2016閱讀 299評(píng)論 0 0
  • 因?yàn)樵谂_(tái)灣時(shí)的自殺行為驚動(dòng)了媽媽,所以今日在她的強(qiáng)烈要求下我去安定醫(yī)院看了抑郁門(mén)診。結(jié)果自然是重度抑郁、有再次自殺...
    葉凝惋瀟閱讀 418評(píng)論 0 0

友情鏈接更多精彩內(nèi)容