Django: ¿Cómo puedo encontrar una lista de modelos que conoce el ORM?

86

En Django, ¿hay algún lugar donde pueda obtener una lista o buscar los modelos que conoce el ORM?

interestar
fuente

Respuestas:

174

Solución simple:

import django.apps
django.apps.apps.get_models()

Por defecto apps.get_models()no incluir

  • modelos de creación automática para relaciones de muchos a muchos sin una tabla intermedia explícita
  • modelos que se han cambiado.

Si también desea incluirlos,

django.apps.apps.get_models(include_auto_created=True, include_swapped=True)

Antes de Django 1.7, use en su lugar:

from django.db import models
models.get_models(include_auto_created=True)

El include_auto_createdparámetro asegura que a través de tablas creadas implícitamente por ManyToManyFields también se recuperarán.

Daniel Roseman
fuente
2
Con el mismo método, también puede obtener todos los modelos en una sola aplicación: stackoverflow.com/a/8702854/117268
Emil Stenström
from django.apps.apps import get_modelsproduce ImportError: No module named 'django.apps.apps'... alguna idea?
aljabear
3
from django.apps import apps>>apps.get_models
Dingo
7

Si quieres un diccionario con todos los modelos puedes usar:

from django.apps import apps

models = {
    model.__name__: model for model in apps.get_models()
}
Myzel394
fuente
4

Si quieres jugar y no usar la buena solución , puedes jugar un poco con la introspección de Python:

import settings
from django.db import models

for app in settings.INSTALLED_APPS:
  models_name = app + ".models"
  try:
    models_module = __import__(models_name, fromlist=["models"])
    attributes = dir(models_module)
    for attr in attributes:
      try:
        attrib = models_module.__getattribute__(attr)
        if issubclass(attrib, models.Model) and attrib.__module__== models_name:
          print "%s.%s" % (models_name, attr)
      except TypeError, e:
        pass
  except ImportError, e:
    pass

Nota: este es un código bastante aproximado; asumirá que todos los modelos están definidos en "models.py" y que heredan de django.db.models.Model.

robar
fuente
0

Si registra sus modelos con la aplicación de administración, puede ver todos los atributos de estas clases en la documentación de administración.

Bardo técnico
fuente
0

A continuación, se muestra una forma sencilla de buscar y eliminar los permisos que existen en la base de datos pero que no existen en las definiciones del modelo ORM:

from django.apps import apps
from django.contrib.auth.management import _get_all_permissions
from django.contrib.auth.models import Permission
from django.core.management.base import BaseCommand


class Command(BaseCommand):
    def handle(self, *args, **options):
        builtins = []
        for klass in apps.get_models():
            for perm in _get_all_permissions(klass._meta):
                builtins.append(perm[0])
        builtins = set(builtins)

        permissions = set(Permission.objects.all().values_list('codename', flat=True))
        to_remove = permissions - builtins
        res = Permission.objects.filter(codename__in=to_remove).delete()
        self.stdout.write('Deleted records: ' + str(res))
Aidan
fuente