Python中的Bunch模式

引用:

        当树这样的数据结构被原型化(或者乃至于被定型)时,它往往会时一个非常有用而灵活的类型,允许我们在其构造器中设置任何属性。在这些情况下,我们会需要用到一种叫做“Bunch”的设计模式。

  

class Bunch(dict):
    def __init__(self, *args, **kwargs):
        super(Bunch, self).__init__(*args, **kwargs)
        self.__dict__ = self

        由于这个类直接继承dict类,所以我们可以自然而然地获得dict类地大量功能,比如对键/值的遍历,或者简单查询一个属性是否存在。

  

>>> x = Bunch(a="1", b="2", c="3")
>>> print (x.a)
'1'
>>> print (x.b)
'2'
>>> print (x.c)
'3'

        这样就构建好了树型结构,因为Bunch模式非常灵活,其属性可以动态设置,所以可以用该模型实现很多类型。

T = Bunch
t = T(left=T(left="1",right="2"),right=T(left="3",right="4"))
>>> t.left
{'left': '1', 'right': '2'}
>>> t.left.right
'2'
>>> t['left']['right']
'2'
>>> 'left' in t.right
True
>>> '3' in t.right
False
原文地址:https://www.cnblogs.com/caiyishuai/p/13270969.html