Django 1.9:我应该避免在`django.setup()`中导入模型吗?

时间:2015-12-10 00:03:14

标签: python django django-models django-1.9

将我的应用移植到django 1.9,我得到了可怕的django.core.exceptions.AppRegistryNotReady: Apps aren't loaded yet

基本上我的堆栈跟踪是:

  manage.py
    execute_from_command_line(sys.argv)
  django/core/management:352, in execute_from_command_line
    utility.execute()
  django/core/management/__init__.py:326, in execute
    django.setup()
  django/__init__.py:18, in setup
    apps.populate(settings.INSTALLED_APPS)
  django/apps/registry.py:85, in populate
    app_config = AppConfig.create(entry)
  django/apps/config.py:90, in create
    module = import_module(entry)
  python2.7/importlib/__init__.py:37, in import_module
    __import__(name)
  myapp/mylib/__init__.py:52, in <module>
    from django.contrib.contenttypes.models import ContentType   #<= The important part
  django/contrib/contenttypes/models.py:159, in <module>
    class ContentType(models.Model):
  django/db/models/base.py:94, in __new__
    app_config = apps.get_containing_app_config(module)
  django/apps/registry.p:239, in get_containing_app_config
    self.check_apps_ready()
  django/apps/registry.py:124, in check_apps_ready
    raise AppRegistryNotReady("Apps aren't loaded yet.")
django.core.exceptions.AppRegistryNotReady: Apps aren't loaded yet.

我的主要问题是:

我应该在我的django应用的__init__.py中导入我的模型吗?

似乎会触发django.models.ModelBase元类,在创建模型之前检查应用是否准备就绪。

1 个答案:

答案 0 :(得分:13)

  

我应该在我的django应用的__init__.py中导入我的模型吗?

不,您必须不导入任何已安装应用的__init__.py文件中的任何模型。这在1.9中不再可能。

来自release notes

  

所有型号都需要在已安装的应用程序中定义或   声明一个明确的app_label。此外,它是不可能的   在加载应用程序之前导入它们。 特别是,它   无法在根包中导入模型   应用