Ho pensato che avrei impiegato del tempo per mostrarti come puoi tradurre un oggetto da dettare tramite 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'}"
La sezione chiave di questo codice è la __iter__
funzione.
Come spiegano i commenti, la prima cosa che facciamo è prendere gli oggetti Class e prevenire tutto ciò che inizia con '__'.
Dopo averlo creato dict
, puoi utilizzare la update
funzione dict e passare l'istanza __dict__
.
Questi ti daranno un dizionario completo di membri di classe + istanza. Ora non resta che iterare su di essi e produrre i rendimenti.
Inoltre, se hai intenzione di usarlo molto, puoi creare un @iterable
decoratore di classe.
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))