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