国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python:Scrapy框架中Item Pipeline組件使用詳解

2020-02-16 11:19:07
字體:
供稿:網(wǎng)友

Item Pipeline簡介

Item管道的主要責任是負責處理有蜘蛛從網(wǎng)頁中抽取的Item,他的主要任務是清晰、驗證和存儲數(shù)據(jù)。
當頁面被蜘蛛解析后,將被發(fā)送到Item管道,并經(jīng)過幾個特定的次序處理數(shù)據(jù)。
每個Item管道的組件都是有一個簡單的方法組成的Python類。
他們獲取了Item并執(zhí)行他們的方法,同時他們還需要確定的是是否需要在Item管道中繼續(xù)執(zhí)行下一步或是直接丟棄掉不處理。

Item管道通常執(zhí)行的過程有

清理HTML數(shù)據(jù)
驗證解析到的數(shù)據(jù)(檢查Item是否包含必要的字段)
檢查是否是重復數(shù)據(jù)(如果重復就刪除)
將解析到的數(shù)據(jù)存儲到數(shù)據(jù)庫中

編寫自己的Item Pipeline

編寫item管道其實是很容易的。
每個Item管道的組件都是由一個簡單的方法組成的Python類:

process_item(item, spider)

每一個item管道組件都會調(diào)用該方法,并且必須返回一個item對象實例或raise DropItem異常。
被丟掉的item將不會在管道組件進行執(zhí)行
此外,我們也可以在類中實現(xiàn)以下方法

open_spider(spider)

當spider執(zhí)行的時候?qū)⒄{(diào)用該方法

close_spider(spider)

當spider關閉的時候?qū)⒄{(diào)用該方法
Item Pipeline例子

代碼如下:

from scrapy.exceptions import DropItem  class PricePipeline(object):    vat_factor = 1.15    def process_item(self, item, spider):     if item['price']:       if item['price_excludes_vat']:         item['price'] = item['price'] * self.vat_factor       return item     else:       raise DropItem("Missing price in %s" % item) 

注:VAT:ValueAddedTax(增值稅)

以上代碼可以過濾那些沒有價格的產(chǎn)品,并且對那些不包括增值稅產(chǎn)品的價格進行調(diào)整

將抓取的items以json格式保存到文件中

從spider抓取到的items將被序列化為json格式,并且以每行一個item的形式被寫入到items.jl文件中

代碼:

import json  class JsonWriterPipeline(object):    def __init__(self):     self.file = open('items.jl', 'wb')    def process_item(self, item, spider):     line = json.dumps(dict(item)) + "/n"     self.file.write(line)     return item 

注:JsonWriterPipeline的目的是介紹如何編寫項目管道。如果想要保存抓取的items到json文件中,推薦使用Feedexports

刪除重復項

假設在spider中提取到的item有重復的id,那么我們就可以在process_item函數(shù)中進行過濾

如:

from scrapy.exceptions import DropItem  class DuplicatesPipeline(object):    def __init__(self):     self.ids_seen = set()    def process_item(self, item, spider):     if item['id'] in self.ids_seen:       raise DropItem("Duplicate item found: %s" % item)     else:       self.ids_seen.add(item['id'])       return item             
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 青田县| 枣庄市| 乡宁县| 满城县| 宣化县| 永济市| 商都县| 加查县| 榆树市| 万年县| 大渡口区| 菏泽市| 揭东县| 天镇县| 凌海市| 清丰县| 莒南县| 大石桥市| 台北市| 宜宾市| 华安县| 青河县| 濮阳县| 荔波县| 淮阳县| 黔江区| 南部县| 化州市| 潞城市| 扎赉特旗| 长沙县| 渑池县| 兴安盟| 台南市| 龙川县| 亳州市| 昂仁县| 砀山县| 恩施市| 宜城市| 大竹县|