[python] 점 “.”을 사용하는 방법 사전 멤버에게 액세스하려면?

점 “.”을 통해 Python 사전 멤버에 액세스 할 수있게하려면 어떻게해야합니까?

예를 들어을 쓰는 대신을 쓰고 mydict['val']싶습니다 mydict.val.

또한이 방법으로 중첩 된 dicts에 액세스하고 싶습니다. 예를 들어

mydict.mydict2.val 

참조 할 것이다

mydict = { 'mydict2': { 'val': ... } }



답변

방금 만든이 클래스를 사용하여 수행 할 수 있습니다. 이 클래스를 사용하면 Map다른 사전 (json 직렬화 포함) 또는 점 표기법과 같은 객체를 사용할 수 있습니다 . 나는 당신을 도울 수 있도록 노력하겠습니다 :

class Map(dict):
    """
    Example:
    m = Map({'first_name': 'Eduardo'}, last_name='Pool', age=24, sports=['Soccer'])
    """
    def __init__(self, *args, **kwargs):
        super(Map, self).__init__(*args, **kwargs)
        for arg in args:
            if isinstance(arg, dict):
                for k, v in arg.iteritems():
                    self[k] = v

        if kwargs:
            for k, v in kwargs.iteritems():
                self[k] = v

    def __getattr__(self, attr):
        return self.get(attr)

    def __setattr__(self, key, value):
        self.__setitem__(key, value)

    def __setitem__(self, key, value):
        super(Map, self).__setitem__(key, value)
        self.__dict__.update({key: value})

    def __delattr__(self, item):
        self.__delitem__(item)

    def __delitem__(self, key):
        super(Map, self).__delitem__(key)
        del self.__dict__[key]

사용 예 :

m = Map({'first_name': 'Eduardo'}, last_name='Pool', age=24, sports=['Soccer'])
# Add new key
m.new_key = 'Hello world!'
# Or
m['new_key'] = 'Hello world!'
print m.new_key
print m['new_key']
# Update values
m.new_key = 'Yay!'
# Or
m['new_key'] = 'Yay!'
# Delete key
del m.new_key
# Or
del m['new_key']


답변

나는 항상 이것을 util 파일에 보관했습니다. 자신의 수업에서 믹스 인으로 사용할 수도 있습니다.

class dotdict(dict):
    """dot.notation access to dictionary attributes"""
    __getattr__ = dict.get
    __setattr__ = dict.__setitem__
    __delattr__ = dict.__delitem__

mydict = {'val':'it works'}
nested_dict = {'val':'nested works too'}
mydict = dotdict(mydict)
mydict.val
# 'it works'

mydict.nested = dotdict(nested_dict)
mydict.nested.val
# 'nested works too'


답변

dotmap통해 설치pip

pip install dotmap

원하는 모든 작업과 하위 클래스를 수행 dict하므로 일반 사전처럼 작동합니다.

from dotmap import DotMap

m = DotMap()
m.hello = 'world'
m.hello
m.hello += '!'
# m.hello and m['hello'] now both return 'world!'
m.val = 5
m.val2 = 'Sam'

또한 dict객체 와 객체 간에 변환 할 수 있습니다 .

d = m.toDict()
m = DotMap(d) # automatic conversion in constructor

즉, 액세스하려는 항목이 이미 dict양식에 들어 있으면 DotMap쉽게 액세스 할 수 있도록 할 수 있습니다.

import json
jsonDict = json.loads(text)
data = DotMap(jsonDict)
print data.location.city

마지막으로 DotMap다음과 같은 작업을 수행 할 수 있도록 자동으로 새 자식 인스턴스를 만듭니다 .

m = DotMap()
m.people.steve.age = 31

무리와 비교

전체 공개 : 저는 DotMap 의 제작자입니다 . Bunch이 기능이 없어서 만들었습니다.

  • 주문 항목을 기억하고 그 순서대로 반복
  • 자동 하위 DotMap생성 기능을 통해 시간이 절약되고 계층 구조가 많을 때 코드가 깨끗해집니다.
  • 에서 dict모든 자식 dict인스턴스를 생성 하고 재귀 적으로 변환DotMap

답변

받아쓰기 및 구현 __getattr____setattr__.

또는 매우 유사한 Bunch 를 사용할 수 있습니다 .

내장 dict 클래스를 monkeypatch하는 것이 가능하지 않다고 생각합니다.


답변

패브릭 은 정말 훌륭하고 최소한의 구현을 가지고 있습니다. 중첩 액세스를 허용하도록 확장하면을 사용할 수 defaultdict있으며 결과는 다음과 같습니다.

from collections import defaultdict

class AttributeDict(defaultdict):
    def __init__(self):
        super(AttributeDict, self).__init__(AttributeDict)

    def __getattr__(self, key):
        try:
            return self[key]
        except KeyError:
            raise AttributeError(key)

    def __setattr__(self, key, value):
        self[key] = value

다음과 같이 사용하십시오.

keys = AttributeDict()
keys.abc.xyz.x = 123
keys.abc.xyz.a.b.c = 234

이는 Kugel의 “dict and and implementation __getattr__and from and dict”에__setattr__ 대한 답변을 조금 더 자세하게 설명합니다 . 이제 당신은 방법을 알고 있습니다!


답변

나는 이것을 시도했다 :

class dotdict(dict):
    def __getattr__(self, name):
        return self[name]

당신도 시도 할 수 __getattribute__있습니다.

모든 dict을 dotdict의 유형으로 충분하게 만드십시오. 멀티 레이어 dict에서 이것을 시작하려면 구현하십시오 __init__.


답변

하지마 파이썬에서 속성 접근과 색인 생성은 별개의 것이므로, 그것들이 같은 것을 수행해서는 안됩니다. namedtuple접근 가능한 속성을 가져야 할 []항목이 있고 표기법을 사용 하여 dict에서 항목을 가져 오는 경우 클래스를 만들 수 있습니다 (아마 만든 클래스 ) .