Python scrapy框架爬蟲(chóng)簡(jiǎn)單demo

環(huán)境:

Ubuntu 18.04
Python 3.6.9

scrapy的安裝

準(zhǔn)備工作,需要pip呼巷、python-dev

sudo apt-get install python3-pip //指定安裝python3的pip
sudo apt-get install python3-dev //指定安裝python3最新的

因?yàn)楸救颂摂M機(jī)上同時(shí)擁有python2和python3的版本囱修,這里在安裝時(shí)需要指定是python3的版本,如果不指定朵逝,默認(rèn)安裝python2的版本蔚袍。
安裝scrapy

sudo pip3 install Scrapy

網(wǎng)上的教程中說(shuō)需要安裝一些依賴(lài),這里提供下命令配名,如果環(huán)境依賴(lài)缺少啤咽,自行安裝下

sudo apt-get install build-essential
sudo apt-get install libxml2-dev
sudo apt-get install libxslt1-dev
sudo apt-get install python-setuptools

最后使用命令 scrapy --version ,若顯示scrapy版本渠脉,則安裝成功

創(chuàng)建項(xiàng)目

在你需要?jiǎng)?chuàng)建項(xiàng)目的目錄執(zhí)行

scrapy startproject xiaomiapp

scrapy startproject 項(xiàng)目名 這里演示的爬蟲(chóng)網(wǎng)站為小米應(yīng)用商城宇整,項(xiàng)目名設(shè)為xiaomiapp
新建的項(xiàng)目目錄為:

xiaomiapp/
├── scrapy.cfg
└── xiaomiapp
    ├── __init__.py
    ├── items.py
    ├── middlewares.py
    ├── pipelines.py
    ├── __pycache__
    ├── settings.py
    └── spiders
        ├── __init__.py
        └── __pycache__

scrapy.cfg:項(xiàng)目配置文件
items.py:項(xiàng)目的數(shù)據(jù)容器文件,用來(lái)定義獲取的數(shù)據(jù)
middlewares.py:項(xiàng)目的中間件文件
pipelines.py:項(xiàng)目管道文件芋膘,用于對(duì)items中的數(shù)據(jù)進(jìn)行進(jìn)一步的處理
settings.py:設(shè)置文件鳞青,包含了爬蟲(chóng)項(xiàng)目的設(shè)置信息
spiders :存放自定義爬蟲(chóng)文件的目錄

進(jìn)入spiders目錄,執(zhí)行

scrapy genspider xiaomiapp app.mi.com/hotCatApp/10

scrapy genspider 文件名 爬取網(wǎng)站域名为朋,創(chuàng)建自定義爬蟲(chóng)文件臂拓,修改其內(nèi)容:

# -*- coding: utf-8 -*-
import scrapy
from xiaomiapp.items import XiaomiappItem

class XiaomiappPySpider(scrapy.Spider):
    name = 'xiaomiapp.py'
    allowed_domains = ['app.mi.com/hotCatApp/10']
    start_urls = ['http://app.mi.com/hotCatApp/10/']

    def parse(self, response):
        lies = response.css('.applist li')
        for li in lies:
            item = XiaomiappItem()
            item['appname'] = li.css('h5 a::text').extract()
            item['appdesc'] = li.css('.app-desc a::text').extract()
            yield item
        pass

說(shuō)明:
name:文件名
allowed_domains:允許的域名
start_urls:請(qǐng)求的地址
結(jié)合網(wǎng)站的實(shí)際內(nèi)容,使用response.css()來(lái)獲取網(wǎng)站內(nèi)容习寸,除了CSS選擇器之外胶惰,Scrapy還支持使用re方法以正則表達(dá)式提取內(nèi)容,以及xpath方法以XPATH語(yǔ)法提取內(nèi)容霞溪。.extract()可直接獲取包含在標(biāo)簽內(nèi)的文本

修改items.py內(nèi)容:

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

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

import scrapy

class XiaomiappItem(scrapy.Item):
    # define the fields for your item here like:
    # name = scrapy.Field()
    appname = scrapy.Field()
    appdesc = scrapy.Field()
    pass

item是保存爬取數(shù)據(jù)的容器孵滞,將可將獲取的數(shù)據(jù)放到item中中捆,類(lèi)似于字典。

運(yùn)行

在項(xiàng)目目錄執(zhí)行

scrapy crawl xiaomiapp

結(jié)果如下:

爬取網(wǎng)站
爬取結(jié)果
數(shù)據(jù)保存

將數(shù)據(jù)保存為csv坊饶、xml泄伪、json格式,可以直接使用命令:

scrapy crawl xiaomiapp -o xiaomiapp.csv
scrapy crawl xiaomiapp -o xiaomiapp.xml
scrapy crawl xiaomiapp -o xiaomiapp.json

運(yùn)行后目錄中會(huì)出現(xiàn)csv匿级、xml蟋滴、json格式文件,如果中文輸出亂碼痘绎,在settings.py中配置

FEED_EXPORT_ENCODING = 'utf-8'

再次運(yùn)行脓杉,結(jié)果:

json數(shù)據(jù)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市简逮,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌尿赚,老刑警劉巖散庶,帶你破解...
    沈念sama閱讀 211,348評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異凌净,居然都是意外死亡悲龟,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,122評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門(mén)冰寻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)须教,“玉大人,你說(shuō)我怎么就攤上這事斩芭∏嵯伲” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,936評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵划乖,是天一觀的道長(zhǎng)贬养。 經(jīng)常有香客問(wèn)我,道長(zhǎng)琴庵,這世上最難降的妖魔是什么误算? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,427評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮迷殿,結(jié)果婚禮上儿礼,老公的妹妹穿的比我還像新娘。我一直安慰自己庆寺,他們只是感情好蚊夫,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,467評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著止邮,像睡著了一般这橙。 火紅的嫁衣襯著肌膚如雪奏窑。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,785評(píng)論 1 290
  • 那天屈扎,我揣著相機(jī)與錄音埃唯,去河邊找鬼。 笑死鹰晨,一個(gè)胖子當(dāng)著我的面吹牛墨叛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播模蜡,決...
    沈念sama閱讀 38,931評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼漠趁,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了忍疾?” 一聲冷哼從身側(cè)響起闯传,我...
    開(kāi)封第一講書(shū)人閱讀 37,696評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎卤妒,沒(méi)想到半個(gè)月后甥绿,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,141評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡则披,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,483評(píng)論 2 327
  • 正文 我和宋清朗相戀三年共缕,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片士复。...
    茶點(diǎn)故事閱讀 38,625評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡图谷,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出阱洪,到底是詐尸還是另有隱情便贵,我是刑警寧澤,帶...
    沈念sama閱讀 34,291評(píng)論 4 329
  • 正文 年R本政府宣布冗荸,位于F島的核電站嫉沽,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏俏竞。R本人自食惡果不足惜绸硕,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,892評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望魂毁。 院中可真熱鬧玻佩,春花似錦、人聲如沸席楚。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至垮斯,卻和暖如春郎仆,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背兜蠕。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工扰肌, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人熊杨。 一個(gè)月前我還...
    沈念sama閱讀 46,324評(píng)論 2 360
  • 正文 我出身青樓曙旭,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親晶府。 傳聞我的和親對(duì)象是個(gè)殘疾皇子桂躏,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,492評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容