Verwenden der Basisidee von How to "perfectly" override a dict?, codierte ich eine Klasse basierend auf Wörterbücher, den Punkt begrenzt Tasten zuweisen, dh Extendeddict('level1.level2', 'value') == {'level1':{'level2':'value'}}
ein dict mit numpy Unterstützung
Der Code ist
import collections
import numpy
class Extendeddict(collections.MutableMapping):
"""Dictionary overload class that adds functions to support chained keys, e.g. A.B.C
:rtype : Extendeddict
"""
# noinspection PyMissingConstructor
def __init__(self, *args, **kwargs):
self._store = dict()
self.update(dict(*args, **kwargs))
def __getitem__(self, key):
keys = self._keytransform(key)
print 'Original key: {0}\nTransformed keys: {1}'.format(key, keys)
if len(keys) == 1:
return self._store[key]
else:
key1 = '.'.join(keys[1:])
if keys[0] in self._store:
subdict = Extendeddict(self[keys[0]] or {})
try:
return subdict[key1]
except:
raise KeyError(key)
else:
raise KeyError(key)
def __setitem__(self, key, value):
keys = self._keytransform(key)
if len(keys) == 1:
self._store[key] = value
else:
key1 = '.'.join(keys[1:])
subdict = Extendeddict(self.get(keys[0]) or {})
subdict.update({key1: value})
self._store[keys[0]] = subdict._store
def __delitem__(self, key):
keys = self._keytransform(key)
if len(keys) == 1:
del self._store[key]
else:
key1 = '.'.join(keys[1:])
del self._store[keys[0]][key1]
if not self._store[keys[0]]:
del self._store[keys[0]]
def __iter__(self):
return iter(self._store)
def __len__(self):
return len(self._store)
def __repr__(self):
return self._store.__repr__()
# noinspection PyMethodMayBeStatic
def _keytransform(self, key):
try:
return key.split('.')
except:
return [key]
Aber mit Python unterstützen sollte 2.7.10 und numpy 1.11.0,
basic = {'Test.field': 'test'}
print 'Normal dictionary: {0}'.format(basic)
print 'Normal dictionary in a list: {0}'.format([basic])
print 'Normal dictionary in numpy array: {0}'.format(numpy.array([basic], dtype=object))
print 'Normal dictionary in numpy array.tolist(): {0}'.format(numpy.array([basic], dtype=object).tolist())
extended_dict = Extendeddict(basic)
print 'Extended dictionary: {0}'.format(extended_dict)
print 'Extended dictionary in a list: {0}'.format([extended_dict])
print 'Extended dictionary in numpy array: {0}'.format(numpy.array([extended_dict], dtype=object))
print 'Extended dictionary in numpy array.tolist(): {0}'.format(numpy.array([extended_dict], dtype=object).tolist())
läuft ich:
Normal dictionary: {'Test.field': 'test'}
Normal dictionary in a list: [{'Test.field': 'test'}]
Normal dictionary in numpy array: [{'Test.field': 'test'}]
Normal dictionary in numpy array.tolist(): [{'Test.field': 'test'}]
Original key: Test
Transformed keys: ['Test']
Extended dictionary: {'Test': {'field': 'test'}}
Extended dictionary in a list: [{'Test': {'field': 'test'}}]
Original key: 0
Transformed keys: [0]
Traceback (most recent call last):
File "/tmp/scratch_2.py", line 77, in <module>
print 'Extended dictionary in numpy array: {0}'.format(numpy.array([extended_dict], dtype=object))
File "/tmp/scratch_2.py", line 20, in __getitem__
return self._store[key]
KeyError: 0
Während ich würde erwarten, print 'Extended dictionary in numpy array: {0}'.format(numpy.array([extended_dict], dtype=object))
in Extended dictionary in numpy array: [{'Test': {'field': 'test'}}]
Irgendwelche Vorschläge auf, führen, was für dieses falsch sein könnte? Ist das überhaupt der richtige Weg?
es scheint mir, dass Sie versuchen, die [pandas] (http://pandas.pydata.org/pandas-docs/stable/10min.html) Bibliothek neu zu erfinden;) – MaxU
@MaxU Pandas macht etwas ganz anderes von dem, was ich dafür brauchen würde, und ich benutze es für viele andere Dinge. Was ich will, ist ein "einfaches" Klassenwörterbuch wie das unterstützt s Punkt-getrennte Felder. –
Fügen Sie einige Debugging-Ausdrucke hinzu, z. B. "Schlüssel" und "Schlüssel" in der Nähe des Fehlers. – hpaulj