I was wandering how does elixir\sqlalchemy get to know all the entity classes I've declared in my model, when I call setup_all()
? I need that kind of functionality in a little project of mine, but I have no clue. I've tried to steptrace through elixir's setup_all()
, and I found that it keeps a collection of all entity classes in a "global" list (or was it dict?), but I can't catch the moment when the list is filled. Any ideas?
How to iterate through every class declaration, descended from a particular base class?
834 Views Asked by AlexVhr At
2
There are 2 best solutions below
3

For class definitions, this is easier (no importing)
def find_subclasses(cls):
results = []
for sc in cls.__subclasses__():
results.append(sc)
return results
I'm not sure if you wanted this, or objects. If you want objects:
import gc
def find_subclasses(cls):
results = []
for sc in cls.__subclasses__():
for obj in gc.get_objects():
if isinstance(obj, sc):
results.append(obj)
return results
Answering the main question, without dealign with SQLALchemy or elixir at all - yes, it is possible in Python.
The garbage colector (
gc
) module on the standard library, have a function call that allows one to retrieve all references to a given object, interpreter wide. A class is always referred to in the__mro__
attribute of any inherited classes.So, the following function could retrieve all classes that inherit from a given class: