提取內(nèi)容

我們在 Scrapy 的 shell 中展示如何從網(wǎng)頁提取數(shù)據(jù):

scrapy shell "http://quotes.toscrape.com/page/1/"

注意:windows 系統(tǒng)下 url 需要用雙引號未巫。

你會看到這樣的輸出:

2017-06-14 21:26:03 [scrapy.core.engine] DEBUG: Crawled (200) <GET http://quotes.toscrape.com/page/1/> (referer: None)
[s] Available Scrapy objects:
[s]   scrapy     scrapy module (contains scrapy.Request, scrapy.Selector, etc)
[s]   crawler    <scrapy.crawler.Crawler object at 0x01047E90>
[s]   item       {}
[s]   request    <GET http://quotes.toscrape.com/page/1/>
[s]   response   <200 http://quotes.toscrape.com/page/1/>
[s]   settings   <scrapy.settings.Settings object at 0x0427C310>
[s]   spider     <DefaultSpider 'default' at 0x4e43af0>
[s] Useful shortcuts:
[s]   fetch(url[, redirect=True]) Fetch URL and update local objects (by default, redirects are followed)
[s]   fetch(req)                  Fetch a scrapy.Request and update local objects
[s]   shelp()           Shell help (print this help)
[s]   view(response)    View response in a browser
>>>

下面我們在 shell 里面利用 css 選擇器來提取網(wǎng)頁的數(shù)據(jù):

>>> response.css('title')
[<Selector xpath='descendant-or-self::title' data='<title>Quotes to Scrape</title>'>]

執(zhí)行上述命令將會返回一個類似列表的對象:SelectorList令花;這是由選擇器根據(jù)提取規(guī)則提取出來的 XML/HTML 元素潘酗,你可以對它進一步細分或提取溪食。

要提取 <title> 標簽里面的內(nèi)容链沼,可以這樣:

>>> response.css('title::text').extract()
['Quotes to Scrape']

在 css 選擇器表達式中使用 ::text理逊,可以提取標簽的內(nèi)容春叫,如果不使用,結(jié)果如下:

>>> response.css('title').extract()
['<title>Quotes to Scrape</title>']

.extract() 方法會根據(jù) SelectorList 內(nèi)容返回一個列表碾褂,如果我們只需要返回列表中第一個元素兽间,或者知道列表中只存在一個元素,可以這樣寫:

>>> response.css('title::text').extract_first()
'Quotes to Scrape'

又或者正塌,可以用列表切片的方式:

>>> response.css('title::text')[0].extract()
'Quotes to Scrape'

但我們還是建議采用 .extract_first()嘀略,這樣可以避免要提取的元素為空的時候發(fā)生 IndexError恤溶。

除了上述方法外,我們還可以用正則表達式提取元素帜羊,用 re() 方法即可:

>>> response.css('title::text').re(r'Quotes.*')
['Quotes to Scrape']

>>> response.css('title::text').re(r'Q\w+')
['Quotes']

>>> response.css('title::text').re(r'(\w+) to (\w+)')
['Quotes', 'Scrape']

Scrapy 還能用 Xpath 來提取內(nèi)容:

>>> response.xpath('//title')
[<Selector xpath='//title' data='<title>Quotes to Scrape</title>'>]

>>> response.xpath('//title/text()').extract_first()
'Quotes to Scrape'
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末咒程,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子讼育,更是在濱河造成了極大的恐慌帐姻,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,542評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件奶段,死亡現(xiàn)場離奇詭異饥瓷,居然都是意外死亡,警方通過查閱死者的電腦和手機痹籍,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評論 3 385
  • 文/潘曉璐 我一進店門呢铆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蹲缠,你說我怎么就攤上這事棺克。” “怎么了线定?”我有些...
    開封第一講書人閱讀 158,021評論 0 348
  • 文/不壞的土叔 我叫張陵娜谊,是天一觀的道長。 經(jīng)常有香客問我斤讥,道長纱皆,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,682評論 1 284
  • 正文 為了忘掉前任周偎,我火速辦了婚禮抹剩,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘蓉坎。我一直安慰自己澳眷,他們只是感情好,可當我...
    茶點故事閱讀 65,792評論 6 386
  • 文/花漫 我一把揭開白布蛉艾。 她就那樣靜靜地躺著钳踊,像睡著了一般。 火紅的嫁衣襯著肌膚如雪勿侯。 梳的紋絲不亂的頭發(fā)上拓瞪,一...
    開封第一講書人閱讀 49,985評論 1 291
  • 那天,我揣著相機與錄音助琐,去河邊找鬼祭埂。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的蛆橡。 我是一名探鬼主播舌界,決...
    沈念sama閱讀 39,107評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼泰演!你這毒婦竟也來了呻拌?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,845評論 0 268
  • 序言:老撾萬榮一對情侶失蹤睦焕,失蹤者是張志新(化名)和其女友劉穎藐握,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體垃喊,經(jīng)...
    沈念sama閱讀 44,299評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡猾普,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,612評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了缔御。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片抬闷。...
    茶點故事閱讀 38,747評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡妇蛀,死狀恐怖耕突,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情评架,我是刑警寧澤眷茁,帶...
    沈念sama閱讀 34,441評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站纵诞,受9級特大地震影響上祈,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜浙芙,卻給世界環(huán)境...
    茶點故事閱讀 40,072評論 3 317
  • 文/蒙蒙 一登刺、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧嗡呼,春花似錦纸俭、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至万伤,卻和暖如春窒悔,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背敌买。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評論 1 267
  • 我被黑心中介騙來泰國打工简珠, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人虹钮。 一個月前我還...
    沈念sama閱讀 46,545評論 2 362
  • 正文 我出身青樓聋庵,卻偏偏與公主長得像荐操,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子珍策,可洞房花燭夜當晚...
    茶點故事閱讀 43,658評論 2 350

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