欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python爬蟲Scrapy框架CrawlSpider原理及使用案例

 更新時間:2020年11月20日 10:17:57   作者:迎風(fēng)而來  
這篇文章主要介紹了Python爬蟲Scrapy框架(CrawlSpider),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下

提問:如果想要通過爬蟲程序去爬取”糗百“全站數(shù)據(jù)新聞數(shù)據(jù)的話,有幾種實現(xiàn)方法?

方法一:基于Scrapy框架中的Spider的遞歸爬去進行實現(xiàn)的(Request模塊回調(diào))

方法二:基于CrawlSpider的自動爬去進行實現(xiàn)(更加簡潔和高效)

一、簡單介紹CrawlSpider

  CrawlSpider其實是Spider的一個子類,除了繼承到Spider的特性和功能外,還派生除了其自己獨有的更加強大的特性和功能。其中最顯著的功能就是”LinkExtractors鏈接提取器“。Spider是所有爬蟲的基類,其設(shè)計原則只是為了爬取start_url列表中網(wǎng)頁,而從爬取到的網(wǎng)頁中提取出的url進行繼續(xù)的爬取工作使用CrawlSpider更合適。

二、使用

  1.創(chuàng)建scrapy工程(cmd切換到要創(chuàng)建項目的文件夾下執(zhí)行):scrapy startproject projectName (如:scrapy startproject crawlPro)

  2.創(chuàng)建爬蟲文件(cmd切換到創(chuàng)建的項目下執(zhí)行):scrapy genspider -t crawl spiderName www.xxx.com (如:scrapy genspider -t crawl crawlDemo www.qiushibaike.com)

    --此指令對比以前的指令多了 "-t crawl",表示創(chuàng)建的爬蟲文件是基于CrawlSpider這個類的,而不再是Spider這個基類。

  3.啟動爬蟲文件(cmd基于步驟二的路徑執(zhí)行):scrapy crawl crawlDemo (啟動的一定是name對應(yīng)的值,如果爬蟲文件與name的值不一致,任然以name的值進行啟動)

觀察生成的爬蟲文件

crawlDemo.py

# -*- coding: utf-8 -*-
import scrapy
# 導(dǎo)入CrawlSpider相關(guān)模塊
from scrapy.linkextractors import LinkExtractor
from scrapy.spiders import CrawlSpider, Rule

# 表示該爬蟲程序是基于CrawlSpider類的
class CrawldemoSpider(CrawlSpider):
  name = 'crawlDemo'  #爬蟲文件名稱
  #allowed_domains = ['www.qiushibaike.com']
  start_urls = ['http://www.qiushibaike.com/']
  
  #連接提取器:會去起始url響應(yīng)回來的頁面中提取指定的url
  link = LinkExtractor(allow=r'/8hr/page/\d+')
  #rules元組中存放的是不同的規(guī)則解析器(封裝好了某種解析規(guī)則)
  rules = (
    #規(guī)則解析器:可以將連接提取器提取到的所有連接表示的頁面進行指定規(guī)則(回調(diào)函數(shù))的解析
    Rule(link, callback='parse_item', follow=True),
  )
  # 解析方法
  def parse_item(self, response):
    #print(response.url)
    divs = response.xpath('//div[@id="content-left"]/div')
    for div in divs:
      author = div.xpath('./div[@class="author clearfix"]/a[2]/h2/text()').extract_first()
      print(author)

  CrawlSpider類和Spider類的最大不同是CrawlSpider多了一個rules屬性,其作用是定義”提取動作“。在rules中可以包含一個或多個Rule對象,在Rule對象中包含了LinkExtractor對象。 

三、生成的爬蟲文件參數(shù)介紹

3.1 LinkExtractor:顧名思義,鏈接提取器。

    LinkExtractor(

        allow=r'Items/',# 滿足括號中“正則表達式”的值會被提取,如果為空,則全部匹配。

         deny=xxx, # 滿足正則表達式的則不會被提取。

         restrict_xpaths=xxx, # 滿足xpath表達式的值會被提取

         restrict_css=xxx, # 滿足css表達式的值會被提取

         deny_domains=xxx, # 不會被提取的鏈接的domains。 

   )

    - 作用:提取response中符合規(guī)則的鏈接?!?/p>

3.2 Rule : 規(guī)則解析器。根據(jù)鏈接提取器中提取到的鏈接,根據(jù)指定規(guī)則提取解析器鏈接網(wǎng)頁中的內(nèi)容。

     Rule(LinkExtractor(allow=r'Items/'), callback='parse_item', follow=True)

    - 參數(shù)介紹:

      參數(shù)1:指定鏈接提取器

      參數(shù)2:指定規(guī)則解析器解析數(shù)據(jù)的規(guī)則(回調(diào)函數(shù))

      參數(shù)3:是否將鏈接提取器繼續(xù)作用到鏈接提取器提取出的鏈接網(wǎng)頁中。當(dāng)callback為None,參數(shù)3的默認值為true。

3.3 rules=( ):指定不同規(guī)則解析器。一個Rule對象表示一種提取規(guī)則。

3.4 CrawlSpider整體爬取流程:

    a)爬蟲文件首先根據(jù)起始url,獲取該url的網(wǎng)頁內(nèi)容

    b)鏈接提取器會根據(jù)指定提取規(guī)則將步驟a中網(wǎng)頁內(nèi)容中的鏈接進行提取

    c)規(guī)則解析器會根據(jù)指定解析規(guī)則將鏈接提取器中提取到的鏈接中的網(wǎng)頁內(nèi)容根據(jù)指定的規(guī)則進行解析

    d)將解析數(shù)據(jù)封裝到item中,然后提交給管道進行持久化存儲

四、基于CrawlSpider示例

創(chuàng)建爬蟲項目和啟動爬蟲項目以及settings中配置自行完成,在這里不在追贅述

4.1爬蟲文件

# -*- coding: utf-8 -*-
import scrapy
from scrapy.linkextractors import LinkExtractor
from scrapy.spiders import CrawlSpider, Rule
from qiubaiBycrawl.items import QiubaibycrawlItem
import re
class QiubaitestSpider(CrawlSpider):
  name = 'qiubaiTest'
  #起始url
  start_urls = ['http://www.qiushibaike.com/']

  #定義鏈接提取器,且指定其提取規(guī)則
  page_link = LinkExtractor(allow=r'/8hr/page/\d+/')
  
  rules = (
    #定義規(guī)則解析器,且指定解析規(guī)則通過callback回調(diào)函數(shù)
    Rule(page_link, callback='parse_item', follow=True),
  )

  #自定義規(guī)則解析器的解析規(guī)則函數(shù)
  def parse_item(self, response):
    div_list = response.xpath('//div[@id="content-left"]/div')
    
    for div in div_list:
      #定義item
      item = QiubaibycrawlItem()
      #根據(jù)xpath表達式提取糗百中段子的作者
      item['author'] = div.xpath('./div/a[2]/h2/text()').extract_first().strip('\n')
      #根據(jù)xpath表達式提取糗百中段子的內(nèi)容
      item['content'] = div.xpath('.//div[@class="content"]/span/text()').extract_first().strip('\n')

      yield item #將item提交至管道

4.2items文件

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

# Define here the models for your scraped items
#
# See documentation in:
# https://doc.scrapy.org/en/latest/topics/items.html

import scrapy


class QiubaibycrawlItem(scrapy.Item):
  # define the fields for your item here like:
  # name = scrapy.Field()
  author = scrapy.Field() #作者
  content = scrapy.Field() #內(nèi)容

4.3管道文件

# -*- 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

class QiubaibycrawlPipeline(object):
  
  def __init__(self):
    self.fp = None
    
  def open_spider(self,spider):
    print('開始爬蟲')
    self.fp = open('./data.txt','w')
    
  def process_item(self, item, spider):
    #將爬蟲文件提交的item寫入文件進行持久化存儲
    self.fp.write(item['author']+':'+item['content']+'\n')
    return item
  
  def close_spider(self,spider):
    print('結(jié)束爬蟲')
    self.fp.close()

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • python爬蟲實現(xiàn)獲取下一頁代碼

    python爬蟲實現(xiàn)獲取下一頁代碼

    在本篇文章里小編給大家整理了關(guān)于python爬蟲實現(xiàn)獲取下一頁代碼內(nèi)容,需要的朋友們可以參考學(xué)習(xí)下。
    2020-03-03
  • Django的分頁器實例(paginator)

    Django的分頁器實例(paginator)

    下面小編就為大家分享一篇Django的分頁器實例(paginator),具有很好的參考價值,希望對大家有所幫助
    2017-12-12
  • Python編程之多態(tài)用法實例詳解

    Python編程之多態(tài)用法實例詳解

    這篇文章主要介紹了Python編程之多態(tài)用法,以實例形式詳細分析了Python中多態(tài)的使用技巧,需要的朋友可以參考下
    2015-05-05
  • python進階教程之循環(huán)對象

    python進階教程之循環(huán)對象

    這篇文章主要介紹了python進階教程之循環(huán)對象,循環(huán)對象是這樣一個對象,它包含有一個next()方法,這個方法的目的是進行到下一個結(jié)果,需要的朋友可以參考下
    2014-08-08
  • 中秋快到了利用 python 繪制中秋禮物

    中秋快到了利用 python 繪制中秋禮物

    眼看中秋又快到了,中秋回家,帶什么禮物更讓家人歡心?今天小編就利用python幫你帶個對象回家,感興趣的小伙伴趕快來看,要記得收藏起來以免迷路
    2021-09-09
  • Python3從零開始搭建一個語音對話機器人的實現(xiàn)

    Python3從零開始搭建一個語音對話機器人的實現(xiàn)

    這篇文章主要介紹了Python3從零開始搭建一個語音對話機器人的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • Python逐行讀取文件內(nèi)容的方法總結(jié)

    Python逐行讀取文件內(nèi)容的方法總結(jié)

    在本篇文章里小編給大家整理的是關(guān)于Python四種逐行讀取文件內(nèi)容的方法,有興趣的朋友們可以學(xué)習(xí)下。
    2020-02-02
  • Python實現(xiàn)從百度API獲取天氣的方法

    Python實現(xiàn)從百度API獲取天氣的方法

    這篇文章主要介紹了Python實現(xiàn)從百度API獲取天氣的方法,實例分析了Python操作百度API的技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-03-03
  • python實現(xiàn)有效的括號判斷實例代碼

    python實現(xiàn)有效的括號判斷實例代碼

    這篇文章主要給大家介紹了關(guān)于python實現(xiàn)有效的括號判斷的相關(guān)資料,文中通過實例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2022-01-01
  • Python  中的pass語句語法詳析

    Python  中的pass語句語法詳析

    這篇文章主要介紹了Python 中的pass語句語法詳析,pass是一種空操作(null operation),解釋器執(zhí)行到它的時候,除了檢查語法是否合法,什么也不做就直接跳過
    2022-07-07

最新評論