Django: Как мне найти список моделей, которые знает ORM?


86

Есть ли в Django место, где я могу получить список или найти модели, о которых знает ORM?

Ответы:


174

Простое решение:

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

По умолчанию apps.get_models()не включать

  • автоматически созданные модели для отношений многие-ко-многим без явной промежуточной таблицы
  • модели, которые были заменены.

Если вы хотите включить и их,

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

До Django 1.7 вместо этого используйте:

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

В include_auto_createdпараметр гарантирует , что через таблиц неявно созданных ManyToManyFieldс будет извлечено , а также.


2
Используя тот же метод, вы также можете получить все модели в одном приложении: stackoverflow.com/a/8702854/117268
Emil Stenström

from django.apps.apps import get_modelsпроизводит ImportError: No module named 'django.apps.apps'... любую идею?
aljabear

3
from django.apps import apps>>apps.get_models
Динго


7

Если вам нужен словарь со всеми моделями, вы можете использовать:

from django.apps import apps

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

4

Если вы хотите поиграть, а не использовать хорошее решение , вы можете немного поиграть с самоанализом 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

Примечание: это довольно грубый фрагмент кода; он будет предполагать, что все модели определены в "models.py" и наследуются от django.db.models.Model.



0

Если вы зарегистрируете свои модели в приложении администратора, вы сможете увидеть все атрибуты этих классов в документации администратора.


0

Вот простой способ найти и удалить любые разрешения, которые существуют в базе данных, но не существуют в определениях модели 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))
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.