像属性一样访问丁字键?

像属性一样访问丁字键?

我发现更方便地访问切分键obj.foo而不是obj['foo'],所以我写了这个片段:

class AttributeDict(dict):
    def __getattr__(self, attr):
        return self[attr]
    def __setattr__(self, attr, value):
        self[attr] = value

但是,我假设Python没有提供这种功能是有原因的。以这种方式访问dict键的警告和缺陷是什么?


qq_笑_17
浏览 466回答 5
5回答

森林海

最好的方法是:class&nbsp;AttrDict(dict): &nbsp;&nbsp;&nbsp;&nbsp;def&nbsp;__init__(self,&nbsp;*args,&nbsp;**kwargs): &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;super(AttrDict,&nbsp;self).__init__(*args,&nbsp;**kwargs) &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;self.__dict__&nbsp;=&nbsp;self一些优点:真的很管用!没有隐藏字典类方法(例如:.keys()工作得很好)属性和项总是同步的。尝试以正确的方式访问不存在的键作为属性引发。AttributeError而不是KeyError缺点:方法,如.keys()将要不如果它们被传入的数据覆盖,就可以正常工作。使.内存泄漏Python<2.7.4/Python 3<3.2.3皮林特和E1123(unexpected-keyword-arg)和E1103(maybe-no-member)对于不熟悉的人来说,这似乎是一种纯粹的魔法。这是如何工作的一个简短的解释所有python对象内部都将它们的属性存储在名为__dict__.没有要求内部字典__dict__将需要是“简单的dict”,这样我们就可以将所有的子类分配给dict()内部字典。在我们的例子中,我们只需分配AttrDict()实例,我们正在实例化(就像我们在__init__).打电话super()氏__init__()方法,确保它(已经)的行为与字典完全类似,因为该函数调用所有字典实例化密码。Python不提供这种功能的一个原因是正如在“conds”列表中所指出的,这结合了存储密钥的命名空间(这些名称空间可能来自任意和/或不受信任的数据!)使用内置方法属性的命名空间。例如:d&nbsp;=&nbsp;AttrDict()d.update({'items':["jacket",&nbsp;"necktie",&nbsp;"trousers"]})for&nbsp;k,&nbsp;v&nbsp;in&nbsp;d.items():&nbsp;&nbsp;&nbsp;&nbsp;#&nbsp;TypeError:&nbsp;'list'&nbsp;object&nbsp;is&nbsp;not&nbsp;callable &nbsp;&nbsp;&nbsp;&nbsp;print&nbsp;"Never&nbsp;reached!"

哔哔one

如果使用数组表示法,则可以将所有合法字符串字符作为键的一部分。例如,obj['!#$%^&*()_']
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Python