Django: Jak mogę znaleźć listę modeli, które zna ORM?

86

Czy w Django jest miejsce, w którym mogę uzyskać listę lub wyszukać modele, o których wie ORM?

interstar
źródło

Odpowiedzi:

174

Proste rozwiązanie:

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

Domyślnie apps.get_models()nie uwzględniaj

  • modele tworzone automatycznie dla relacji wiele do wielu bez jawnej tabeli pośredniej
  • modele, które zostały zamienione.

Jeśli chcesz je również uwzględnić,

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

Przed Django 1.7 zamiast tego użyj:

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

Do include_auto_createdparametrów zapewnia, że poprzez tabele niejawnie stworzonych przez ManyToManyFields będą pobierane również.

Daniel Roseman
źródło
2
Korzystając z tej samej metody, możesz również pobrać wszystkie modele w jednej aplikacji: stackoverflow.com/a/8702854/117268
Emil Stenström
from django.apps.apps import get_modelsprodukuje ImportError: No module named 'django.apps.apps'... jakiś pomysł?
aljabear
3
from django.apps import apps>>apps.get_models
Dingo,
11

Wyświetl modele za pomocą http://docs.djangoproject.com/en/dev/ref/contrib/contenttypes/

from django.contrib.contenttypes.models import ContentType

for ct in ContentType.objects.all():
    m = ct.model_class()
    print "%s.%s\t%d" % (m.__module__, m.__name__, m._default_manager.count())
andreipak
źródło
7

Jeśli chcesz mieć słownik ze wszystkimi modelami, możesz użyć:

from django.apps import apps

models = {
    model.__name__: model for model in apps.get_models()
}
Myzel394
źródło
4

Jeśli chcesz się pobawić, a nie korzystasz z dobrego rozwiązania , możesz trochę pobawić się introspekcją w Pythonie:

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

Uwaga: to jest dość szorstki fragment kodu; przyjmie, że wszystkie modele są zdefiniowane w „models.py” i że dziedziczą po django.db.models.Model.

obrabować
źródło
0

Jeśli zarejestrujesz swoje modele za pomocą aplikacji administratora, możesz zobaczyć wszystkie atrybuty tych klas w dokumentacji administratora.

Bard techniczny
źródło
0

Oto prosty sposób na znalezienie i usunięcie wszelkich uprawnień, które istnieją w bazie danych, ale nie istnieją w definicjach modelu 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
źródło