점 “.”을 통해 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에서 항목을 가져 오는 경우 클래스를 만들 수 있습니다 (아마 만든 클래스 ) .