Pensé que me tomaría un tiempo mostrarle cómo puede traducir un objeto para dictarlo 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 sección clave de este código es la __iter__
función.
Como explican los comentarios, lo primero que hacemos es tomar los elementos de la Clase y evitar cualquier cosa que comience con '__'.
Una vez que haya creado eso dict
, puede usar la update
función dict y pasar la instancia __dict__
.
Estos le darán un diccionario completo de clase + instancia de miembros. Ahora todo lo que queda es iterar sobre ellos y obtener los rendimientos.
Además, si planea usar esto mucho, puede crear un @iterable
decorador de clase.
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))