Кажется, что нет встроенного способа получить представление в словаре. Самый простой обходной путь - подход Йохена. Я немного адаптировал его код, чтобы он работал для моих целей:
from collections import MutableMapping
class DictView(MutableMapping):
def __init__(self, source, valid_keys):
self.source, self.valid_keys = source, valid_keys
def __getitem__(self, key):
if key in self.valid_keys:
return self.source[key]
else:
raise KeyError(key)
def __len__(self):
return len(self.valid_keys)
def __iter__(self):
for key in self.valid_keys:
yield key
def __setitem__(self, key, value):
if key in self.valid_keys:
self.source[key] = value
else:
raise KeyError(key)
def __delitem__(self, key):
self.valid_keys.remove(key)
d = dict(a=1, b=2, c=3)
valid_keys = ['a', 'c']
d2 = DictView(d, valid_keys)
d2['a'] = -1 # overwrite element 'a' in source dictionary
print d # prints {'a': -1, 'c': 3, 'b': 2}
Таким образом, d2
ведет себя как словарь во всех аспектах, кроме печати, из-за другого метода __repr__()
. Наследование от dict
для получения __repr__()
потребует повторной реализации каждого метода, как это делается для collections.OrderedDict
. Если кто-то хочет только чтение только для чтения, он может наследовать от collections.Mapping
и сохранить реализацию __setitem__()
и __delitem__()
. DictView
полезен для выбора параметров из self.__dict__
и передачи их в компактной форме.