成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

使用ChainMap

EscapedDog / 3358人閱讀

摘要:使用最近看到組內(nèi)有小伙伴在處理在多個內(nèi)順序查找元素的時候,用了,有意思。場景當(dāng)用戶輸入一個產(chǎn)品的時候,你希望能正在出售的產(chǎn)品,或在已過期的產(chǎn)品中查找。

使用ChainMap

最近看到組內(nèi)有小伙伴在處理在多個dict內(nèi)順序查找元素的時候,用了ChainMap,有意思。場景: 當(dāng)用戶輸入一個產(chǎn)品id的時候,你希望能正在出售的產(chǎn)品,或在已過期的產(chǎn)品中查找。

你可以實現(xiàn):

g_expire_products = {
    1: {"name": "nike shoes", "price": 30}, 
    2: {"name": "box", "price": 2},
}
g_on_sale_products = {
    3: {"name": "adidas shoes", "price": 25},
    4: {"name": "tee", "price": 2},
}

def get_product(id):
    return g_on_sale_products.get(id, g_expire_products.get(id))
    

如果是不止已過期產(chǎn)品,希望在其他庫房的產(chǎn)品也能被查找,你可能還要在一個新的dict里面查找。

這不難實現(xiàn),就是代碼看起來有點難看。
為何不試下ChainMap,用ChainMap可以這樣寫:

g_products = ChainMap(g_on_sale_products, g_expire_products)

def get_product(id):
    return g_products.get(id)

ChainMap可以添加多個dict,相當(dāng)于把你的if-else判斷做了抽象。

ChainMap源碼

ChainMap源碼在這兒

可以看下__init__

def __init__(self, *maps):
    """Initialize a ChainMap by setting *maps* to the given mappings.
    If no mappings are provided, a single empty dictionary is used.
    """
    self.maps = list(maps) or [{}]          # always at least one map

這里傳入多個dict后,多個dict放在maps里,這里maps傳的是多個dict的引用,也就是它沒有拷貝內(nèi)存。

那么它是如何查找key的,我們來看下:

def __missing__(self, key):
    raise KeyError(key)

def __getitem__(self, key):
    for mapping in self.maps:
        try:
            return mapping[key]             # can"t use "key in mapping" with defaultdict
        except KeyError:
            pass
    return self.__missing__(key)            # support subclasses that define __missing__

def get(self, key, default=None):
    return self[key] if key in self else default

def __contains__(self, key):
    return any(key in m for m in self.maps)

可以看到,當(dāng)通過dict[key]的時候,它是從self.maps里的存的dict,從前往后找,初始化的時候,第一個dict先被查找,key不在第一個dict的時候,就會找下一個dict里查找。

不過它在修改的時候,是這樣做的

def __setitem__(self, key, value):
    self.maps[0][key] = value

def __delitem__(self, key):
    try:
        del self.maps[0][key]
    except KeyError:
        raise KeyError("Key not found in the first mapping: {!r}".format(key))

也就是你修改其中一個key的時候,它會在第一個dict里面修改,刪除一個key時候也是。

所以一般使用ChainMap的時候,我覺得最好不要做修改,因為修改是基于你初始化的時候,傳入的dict的順序,每次如果初始化的時候,如果dict的順序不確定,你每次就不能確定會修改哪一個dict。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/43610.html

相關(guān)文章

  • Python每日一練0013

    摘要:問題現(xiàn)在有多個字典或者映射,你想將它們從邏輯上合并為一個單一的映射后執(zhí)行某些操作,比如查找值或者檢查某些鍵是否存在。 問題 現(xiàn)在有多個字典或者映射,你想將它們從邏輯上合并為一個單一的映射后執(zhí)行某些操作, 比如查找值或者檢查某些鍵是否存在。 解決方案 使用collections庫的ChainMap類,可以快速的將多個dict合并在一起 >>> from collections impor...

    sihai 評論0 收藏0
  • Python中collections模塊的使用

    摘要:這里提示一下,有些函數(shù)對隊列進行操作,但返回值是,比如反轉(zhuǎn)隊列,將隊列中元素向右移位,尾部的元素移到頭部。比如字典中的鍵映射多個值輸出結(jié)果如下三用途創(chuàng)建命名字段的元組。四用途統(tǒng)計可哈希的對象。 本文將詳細講解collections模塊中的所有類,和每個類中的方法,從源碼和性能的角度剖析。 一個模塊主要用來干嘛,有哪些類可以使用,看__init__.py就知道 This module i...

    xorpay 評論0 收藏0
  • Python中collections模塊的使用

    摘要:這里提示一下,有些函數(shù)對隊列進行操作,但返回值是,比如反轉(zhuǎn)隊列,將隊列中元素向右移位,尾部的元素移到頭部。比如字典中的鍵映射多個值輸出結(jié)果如下三用途創(chuàng)建命名字段的元組。四用途統(tǒng)計可哈希的對象。 本文將詳細講解collections模塊中的所有類,和每個類中的方法,從源碼和性能的角度剖析。 一個模塊主要用來干嘛,有哪些類可以使用,看__init__.py就知道 This module i...

    sf190404 評論0 收藏0

發(fā)表評論

0條評論

EscapedDog

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<