Scrapy+Selenium+Phantomjs的Demo

前段時(shí)間學(xué)習(xí)了用Python寫爬蟲沧烈,使用Scrapy框架爬取京東的商品信息冲泥。商品詳情頁的價(jià)格是由js生成的辅搬,而通過Scrapy直接爬取的源文件中無價(jià)格信息。
  通過Selenium环鲤、Phantomjs便能實(shí)現(xiàn)攘轩。下面先介紹Phantomjs狂巢。
(我的博客原文地址:https://chaycao.github.io/2016/08/19/Scrapy-Selenium-Phantomjs/ 請多指教u锍稹)

Phantomjs

作為一個(gè)基于webkit內(nèi)核的沒有UI界面的瀏覽器,大家不必被這個(gè)名字嚇到恋腕,以為是很復(fù)雜的技術(shù)抹锄,其實(shí)只是一個(gè)瀏覽器啦。而其中的一些點(diǎn)擊荠藤、翻頁等操作則由代碼實(shí)現(xiàn)祈远。Phantomjs提供javascript API接口,即我們可以通過js與webkit內(nèi)核交互商源。
  只需通過Phantomjs test.js的命令就能成功訪問頁面,并將js生成后的內(nèi)容下載下來谋减。

// a phantomjs example
// test.js
var page = require('webpage').create();  //獲取操作dom或web網(wǎng)頁的對象
var fs = require('fs');                  //獲取文件系統(tǒng)對象牡彻,通過它可以操作操作系統(tǒng)的文件操作,包括read出爹、write庄吼、move、copy严就、delete等总寻。
phantom.outputEncoding="utf-8";
//通過page對象打開url鏈接,并可以回調(diào)其聲明的回調(diào)函數(shù)
page.open("http://chaycao.github.io", function(status) {   
if ( status === "success" ) {
    console.log("成功");
    fs.write('web.html',page.content,'w');
    } else {
    console.log("Page failed to load.");
}
phantom.exit(0);
}); 

關(guān)于Phantomjs的詳細(xì)介紹可以參照這篇博文:http://blog.csdn.net/tengdazhang770960436/article/details/41320079

Selenium

作為一個(gè)用于Web應(yīng)用程序測試的工具梢为,其測試直接運(yùn)行在瀏覽器中渐行,框架底層使用JavaScript模擬真實(shí)用戶對瀏覽器的操作,從終端用戶的角度測試應(yīng)用程序铸董。將Selenium與Phantomjs聯(lián)系起來祟印,便是我們可以通過使用Selenium操作Phantomjs訪問網(wǎng)頁以獲得js生成后的網(wǎng)頁。

在我看來粟害,這里Selenium的作用就像是Scrapy調(diào)用Phantomjs的中介蕴忆。我也存有疑問:“Scrapy是否能直接調(diào)用Phantomjs?” 期望回復(fù)

Scrapy使用Selenium

需要弄懂一個(gè)概念悲幅,下載中間件套鹅,可以閱讀下官方文檔http://scrapy-chs.readthedocs.io/zh_CN/1.0/topics/downloader-middleware.html

在settings.py加入

DOWNLOADER_MIDDLEWARES = {
    'jdSpider.middlewares.middleware.JavaScriptMiddleware': 543, #鍵為中間件類的路徑,值為中間件的順序
    'scrapy.downloadermiddlewares.useragent.UserAgentMiddleware':None, #禁止內(nèi)置的中間件
}

第一行為中間件的位置汰具,需要與自己目錄對應(yīng)卓鹿,我的目錄是這樣的:


文件目錄

如果運(yùn)行遇到robots.txt的問題,需要將settings.py中的

ROBOTSTXT_OBEY = False

下面貼上留荔,自定義中間件的代碼:

from selenium import webdriver
from scrapy.http import HtmlResponse
import time

class JavaScriptMiddleware(object):

def process_request(self, request, spider):
    if spider.name == "jd":
        print "PhantomJS is starting..."
        driver = webdriver.PhantomJS() #指定使用的瀏覽器
        # driver = webdriver.Firefox()
        driver.get(request.url)
        time.sleep(1)
        js = "var q=document.documentElement.scrollTop=10000" 
        driver.execute_script(js) #可執(zhí)行js减牺,模仿用戶操作。此處為將頁面拉至最底端。       
        time.sleep(3)
        body = driver.page_source
        print ("訪問"+request.url)
        return HtmlResponse(driver.current_url, body=body, encoding='utf-8', request=request)
    else:
        return

在spiders/jd.py中parse()方法接收到的response則是我們自定義中間件返回的結(jié)果拔疚。我們得到的便是js生成后的界面肥隆。

# -*- coding: utf-8 -*-
import scrapy

class JdSpider(scrapy.Spider):
    name = "jd"
    allowed_domains = ["jd.com"]
    start_urls = (
        'http://search.jd.com/Search?keyword=三星s7&enc=utf-8&wq=三星s7&pvid=tj0sfuri.v70avo',
    )

    def parse(self, response):
        print response.body
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市稚失,隨后出現(xiàn)的幾起案子栋艳,更是在濱河造成了極大的恐慌,老刑警劉巖句各,帶你破解...
    沈念sama閱讀 216,919評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件吸占,死亡現(xiàn)場離奇詭異,居然都是意外死亡凿宾,警方通過查閱死者的電腦和手機(jī)矾屯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來初厚,“玉大人件蚕,你說我怎么就攤上這事〔蹋” “怎么了排作?”我有些...
    開封第一講書人閱讀 163,316評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長亚情。 經(jīng)常有香客問我妄痪,道長,這世上最難降的妖魔是什么楞件? 我笑而不...
    開封第一講書人閱讀 58,294評論 1 292
  • 正文 為了忘掉前任衫生,我火速辦了婚禮,結(jié)果婚禮上土浸,老公的妹妹穿的比我還像新娘障簿。我一直安慰自己,他們只是感情好栅迄,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,318評論 6 390
  • 文/花漫 我一把揭開白布站故。 她就那樣靜靜地躺著,像睡著了一般毅舆。 火紅的嫁衣襯著肌膚如雪西篓。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,245評論 1 299
  • 那天憋活,我揣著相機(jī)與錄音岂津,去河邊找鬼。 笑死悦即,一個(gè)胖子當(dāng)著我的面吹牛吮成,可吹牛的內(nèi)容都是我干的橱乱。 我是一名探鬼主播,決...
    沈念sama閱讀 40,120評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼粱甫,長吁一口氣:“原來是場噩夢啊……” “哼泳叠!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起茶宵,我...
    開封第一講書人閱讀 38,964評論 0 275
  • 序言:老撾萬榮一對情侶失蹤危纫,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后乌庶,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體种蝶,經(jīng)...
    沈念sama閱讀 45,376評論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,592評論 2 333
  • 正文 我和宋清朗相戀三年瞒大,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了螃征。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,764評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡透敌,死狀恐怖盯滚,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情拙泽,我是刑警寧澤,帶...
    沈念sama閱讀 35,460評論 5 344
  • 正文 年R本政府宣布裸燎,位于F島的核電站顾瞻,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏德绿。R本人自食惡果不足惜荷荤,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,070評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望移稳。 院中可真熱鬧蕴纳,春花似錦、人聲如沸个粱。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,697評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽都许。三九已至稻薇,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間胶征,已是汗流浹背塞椎。 一陣腳步聲響...
    開封第一講書人閱讀 32,846評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留睛低,地道東北人案狠。 一個(gè)月前我還...
    沈念sama閱讀 47,819評論 2 370
  • 正文 我出身青樓服傍,卻偏偏與公主長得像,于是被迫代替她去往敵國和親骂铁。 傳聞我的和親對象是個(gè)殘疾皇子吹零,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,665評論 2 354

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