Ich dachte, ich würde einige Zeit brauchen, um Ihnen zu zeigen, wie Sie ein Objekt übersetzen können, über das Sie diktieren möchten dict(obj)
.
class A(object):
d = '4'
e = '5'
f = '6'
def __init__(self):
self.a = '1'
self.b = '2'
self.c = '3'
def __iter__(self):
# first start by grabbing the Class items
iters = dict((x,y) for x,y in A.__dict__.items() if x[:2] != '__')
# then update the class items with the instance items
iters.update(self.__dict__)
# now 'yield' through the items
for x,y in iters.items():
yield x,y
a = A()
print(dict(a))
# prints "{'a': '1', 'c': '3', 'b': '2', 'e': '5', 'd': '4', 'f': '6'}"
Der Schlüsselabschnitt dieses Codes ist die __iter__
Funktion.
Wie die Kommentare erklären, greifen wir zuerst die Klassenelemente zu und verhindern alles, was mit '__' beginnt.
Sobald Sie das erstellt haben, dict
können Sie die update
Diktierfunktion verwenden und die Instanz übergeben __dict__
.
Diese geben Ihnen ein vollständiges Klassen- + Instanzwörterbuch der Mitglieder. Jetzt müssen sie nur noch durchlaufen und die Renditen erzielen.
Wenn Sie dies häufig verwenden möchten, können Sie auch einen @iterable
Klassendekorateur erstellen .
def iterable(cls):
def iterfn(self):
iters = dict((x,y) for x,y in cls.__dict__.items() if x[:2] != '__')
iters.update(self.__dict__)
for x,y in iters.items():
yield x,y
cls.__iter__ = iterfn
return cls
@iterable
class B(object):
d = 'd'
e = 'e'
f = 'f'
def __init__(self):
self.a = 'a'
self.b = 'b'
self.c = 'c'
b = B()
print(dict(b))