最近在看《Python算法教程》,今天看到了一个新的模式,记录下来。
引用:
当树这样的数据结构被原型化(或者乃至于被定型)时,它往往会时一个非常有用而灵活的类型,允许我们在其构造器中设置任何属性。在这些情况下,我们会需要用到一种叫做“Bunch”的设计模式。
class Bunch(dict):
def __init__(self, *args, **kwargs):
super(Bunch, self).__init__(*args, **kwargs)
self.__dict__ = self
先举个例子简单的使用下这个Bunch类
>>> x = Bunch(a="1", b="2", c="3")
>>> print (x.a)
'1'
>>> print (x.b)
'2'
>>> print (x.c)
'3'
由于这个类直接继承dict类,所以我们可以自然而然地获得dict类地大量功能,比如对键/值的遍历,或者简单查询一个属性是否存在。
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
这样就构建好了树型结构,因为Bunch模式非常灵活,其属性可以动态设置,所以可以用该模型实现很多类型。