Czy w Django jest miejsce, w którym mogę uzyskać listę lub wyszukać modele, o których wie ORM?
Odpowiedzi:
Proste rozwiązanie:
import django.apps
django.apps.apps.get_models()
Domyślnie apps.get_models()
nie uwzględniaj
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_created
parametrów zapewnia, że poprzez tabele niejawnie stworzonych przez ManyToManyField
s będą pobierane również.
from django.apps.apps import get_models
produkuje ImportError: No module named 'django.apps.apps'
... jakiś pomysł?
from django.apps import apps
>>apps.get_models
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())
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.
Jeśli korzystasz z aplikacji contenttypes, jest to proste: http://docs.djangoproject.com/en/dev/ref/contrib/contenttypes/
Jeśli zarejestrujesz swoje modele za pomocą aplikacji administratora, możesz zobaczyć wszystkie atrybuty tych klas w dokumentacji administratora.
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))