亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

一文搞懂Scrapy與MongoDB交互過程

 更新時間:2022年07月08日 15:20:56   作者:依戀、陽光  
這篇文章主要介紹了Scrapy與MongoDB交互過程,文末給大家介紹了類方法@classmethod的相關知識,需要的朋友可以參考下

Pipeline.py

class MongoDBPipeline:
    def __init__(self,conn,database):
        self.conn = conn
        self.database = database
    @classmethod
    def from_crawler(cls, crawler):
        return cls(
            conn=crawler.settings.get('MONGODB_CONNECTION_STRING'),
            database=crawler.settings.get('MONGODB_DATABASE')
        )
    def open_spider(self,spider):
        # 創(chuàng)建連接對象
        self.client = pymongo.MongoClient(self.conn)
        # 連接要用的使用的數(shù)據(jù)庫
        self.db = self.client[self.database]
    def process_item(self,item,spider):
        # 設置使用表名稱
        name = item.__class__.__name__
        # 默認item類名
        self.db[name].insert_one(dict(item))
        return item
    def close_spider(self,spider):
        self.client.close()

PS:

1.不能用insert來插入數(shù)據(jù),PyMongo 4.0.* 中 Collection.insert 方法被移除,使用 Collection.insert_one 或者 Collection.insert_many 替代:

db[name].insert_one({'my': 'document'})
db[name].insert_many([{'doc': 2}, {'doc': 3}])

2.process_item一定要寫return item,不然接收不了返回值。

3.open_spider, process_item, close_spider的名稱和參數(shù)不能改變,因為這是重寫類方法。

setting.py

MONGODB_CONNECTION_STRING = '127.0.0.1'
MONGODB_DATABASE = 'test'

補充知識點:類方法@classmethod

類方法也算一種實用的技巧,簡單描述之:“類方法讓類模板具有記憶力”。

類模板就是我們所定義的類。在普通情況下,不使用類方法對類進行實例化,類本身是不具有記憶性的。只是當一個靜態(tài)模板被套用多次而已。如果我們想讓類在每一次實例化之后,都能記載一些記憶,是否會對很多操作很有用?

舉個例子:

class Man:
    id = 0 # 類變量
    def __init__(self, name):
        self.name = name
        self.id = self.id_number()
    @classmethod
    def id_number(cls):
        cls.id += 1
        return cls.id
a = Man('A')
print(a.id)
b = Man('B')
print(b.id)

上面的輸出為:

1
2

我對Man這個類進行實例化2次,每個實例的id都不一樣。這就依靠類方法來實現(xiàn)了:首先,用@classmethod描述類方法,然后用"cls"代表本類。類方法對類屬性進行的處理是有記憶性的。

PS:類方法處理的變量一定要是類變量。因為在類方法里你用不了self來尋址實例變量,所以需要把類變量放到最前面描述,如上面的"id=0"所示。類變量是可以被self訪問的,所以,在類變量定義好了以后,不需要在_init_函數(shù)里對類變量再一次描述。所以,上面代碼里self.id不一定需要。

到此這篇關于Scrapy與MongoDB交互的文章就介紹到這了,更多相關Scrapy與MongoDB內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • mongodb?linux下集群搭建過程

    mongodb?linux下集群搭建過程

    這篇文章主要介紹了mongodb?linux下集群搭建過程,本例中,為每個集群(shard?config)三個mongo實例,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-02-02
  • MongoDB高可用與分片

    MongoDB高可用與分片

    最近項目在使用MongoDB作為圖片和文檔的存儲數(shù)據(jù)庫,為啥不直接存MySQL里,還要搭個MongoDB集群,麻不麻煩?讓我們一起,一探究竟,繼續(xù)學習MongoDB高可用和片鍵策略,實現(xiàn)快速入門,感興趣的小伙伴可以參考閱讀
    2023-04-04
  • MongoDB中的一些坑(最好不要用)

    MongoDB中的一些坑(最好不要用)

    這篇文章主要介紹了MongoDB中的一些坑(最好不要用),本文總結(jié)了MongoDB 數(shù)據(jù)庫級鎖、建索引導致數(shù)據(jù)庫阻塞、不合理使用嵌入 embed document、不合理使用 Array 字段等4個坑,需要的朋友可以參考下
    2015-03-03
  • MongoDB數(shù)據(jù)庫常用28條查詢語句總結(jié)

    MongoDB數(shù)據(jù)庫常用28條查詢語句總結(jié)

    我們經(jīng)常使用的MySQL是最流行的關系型數(shù)據(jù)庫管理系統(tǒng),隨著時代的進步,互聯(lián)網(wǎng)的發(fā)展關系型數(shù)據(jù)庫已經(jīng)不滿足于互聯(lián)網(wǎng)的需求,因此出現(xiàn)了非關系數(shù)據(jù)庫,下面這篇文章主要給大家總結(jié)介紹了關于MongoDB數(shù)據(jù)庫常用28條查詢語句,需要的朋友可以參考下
    2023-05-05
  • Laravel?框架中使用?MongoDB?數(shù)據(jù)庫的操作

    Laravel?框架中使用?MongoDB?數(shù)據(jù)庫的操作

    這篇文章主要介紹了Laravel?框架中使用?MongoDB?數(shù)據(jù)庫的問題及操作方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • 關于mongoDB數(shù)據(jù)庫添加賬號的問題

    關于mongoDB數(shù)據(jù)庫添加賬號的問題

    這篇文章主要介紹了mongoDB數(shù)據(jù)庫添加賬號的問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-02-02
  • MongoDB運行日志實現(xiàn)自動分割的方法實例

    MongoDB運行日志實現(xiàn)自動分割的方法實例

    這篇文章主要給大家介紹了關于MongoDB運行日志實現(xiàn)自動分割的方法,文中以一個MongoDB實例為例,寫了一個腳本來實現(xiàn)自動分割MongoDB日志,有需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-01-01
  • 分布式文檔存儲數(shù)據(jù)庫之MongoDB訪問控制的操作方法

    分布式文檔存儲數(shù)據(jù)庫之MongoDB訪問控制的操作方法

    這篇文章主要介紹了分布式文檔存儲數(shù)據(jù)庫之MongoDB訪問控制的操作方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • MongoDB視圖的修改與刪除的實現(xiàn)

    MongoDB視圖的修改與刪除的實現(xiàn)

    視圖為mongodb的操作和數(shù)據(jù)安全上提供了便利,本文主要介紹了MongoDB視圖的修改與刪除的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • MongoDB優(yōu)化心得分享

    MongoDB優(yōu)化心得分享

    本文給大家分享的是一些使用mongoDB優(yōu)化方面的心得,有需要的小伙伴可以參考下
    2017-12-12

最新評論