web-dev-qa-db-ja.com

Django:ORMが知っているモデルのリストを見つけるにはどうすればよいですか?

Djangoには、ORMが知っているモデルのリストを取得したり調べたりできる場所がありますか?

75
interstar

シンプルなソリューション:

_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_パラメーターは、ManyToManyFieldsによって暗黙的に作成されたテーブルを通じても確実に取得されるようにします。

155
Daniel Roseman

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())
9
andreipak

good solution を使用せずにプレイしたい場合は、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を継承すると仮定します。

4
rob

Contenttypesアプリを使用する場合、簡単です: http://docs.djangoproject.com/en/dev/ref/contrib/contenttypes/

1
dar

すべてのモデルで辞書が必要な場合は、次を使用できます。

from Django.apps import apps

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

モデルを管理アプリに登録すると、これらのクラスのすべての属性を管理ドキュメントで確認できます。

0
Technical Bard

データベースには存在するが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))
0
Aidan