【问题标题】:Django: having trouble setting up app ready() to import signalsDjango:设置应用程序就绪()以导入信号时遇到问题
【发布时间】:2016-06-11 20:00:43
【问题描述】:

我遇到了常见的“尚未加载模型”错误,这是由于将单独的信号文件导入我的应用程序models.py 而引起的。我找到了 2 个关于如何在 ready() 函数中创建 AppConfig 和导入信号的简单指南,但我无法让它工作。我正在使用最佳答案 here 以及 this 博客文章。

部分原因可能是因为我的整个项目都有一个名称funproj,并且大部分代码所在的主应用程序被称为app - 我正在使用 Visual Studio VS 的 Python 工具,它在我创建项目时生成了这个结构。这是层次结构:

funproj
|--- __init__.py
|--- setttings.py
|--- urls.py
|
|--app
|   |--- __init__.py
|   |--- models.py
|   |--- signals.py
|
|--otherapp
|   |--- __init__.py
|   |--- other stuff

这是缩写,但我尝试将所需的apps.py__init.py__ 的相关代码放在funprojapp 下,但两种方法都不起作用。这就是我所拥有的:

apps.py

from django.apps import AppConfig

class FunProjAppConfig(AppConfig):
  name = 'app'

  def ready(self):
    from app import signals

__init.py__ 加法

#import signals in the app config
default_app_config = 'app.apps.FunProjAppConfig'

app 中包含此代码对我来说更有意义,因为它包含需要加载的信号,但是我链接的示例对我来说并不清楚。有人提到了“应用程序目录”,但我不确定这是否字面意思是 app,我认为应该如此,或者他们是否将应用程序用作项目的同义词。

我认为这不会很难解决,我只是不知道我做错了什么。

编辑:这是带有 Django 1.8 的 Python 3.4。回溯如下,当我只是有一个signals.py 文件并在“models.py”中导入这些信号时,我遇到的错误是一样的。

C:\Python34\lib\importlib\_bootstrap.py:321: RemovedInDjango19Warning: The utili
ties in django.db.models.loading are deprecated in favor of the new application
loading system.
  return f(*args, **kwds)

Traceback (most recent call last):
  File "C:\Users\David\Source\Repos\path\to\projfiles\manage.py", line
17, in <module>
    execute_from_command_line(sys.argv)
  File "C:\Python34\lib\site-packages\django\core\management\__init__.py", line
338, in execute_from_command_line
    utility.execute()
  File "C:\Python34\lib\site-packages\django\core\management\__init__.py", line
312, in execute
    django.setup()
  File "C:\Python34\lib\site-packages\django\__init__.py", line 18, in setup
    apps.populate(settings.INSTALLED_APPS)
  File "C:\Python34\lib\site-packages\django\apps\registry.py", line 108, in pop
ulate
    app_config.import_models(all_models)
  File "C:\Python34\lib\site-packages\django\apps\config.py", line 198, in impor
t_models
    self.models_module = import_module(models_module_name)
  File "C:\Python34\lib\importlib\__init__.py", line 109, in import_module
    return _bootstrap._gcd_import(name[level:], package, level)
  File "<frozen importlib._bootstrap>", line 2254, in _gcd_import
  File "<frozen importlib._bootstrap>", line 2237, in _find_and_load
  File "<frozen importlib._bootstrap>", line 2226, in _find_and_load_unlocked
  File "<frozen importlib._bootstrap>", line 1200, in _load_unlocked
  File "<frozen importlib._bootstrap>", line 1129, in _exec
  File "<frozen importlib._bootstrap>", line 1471, in exec_module
  File "<frozen importlib._bootstrap>", line 321, in _call_with_frames_removed
  File "C:\Users\David\Source\Repos\path\to\projfiles\app\models.py", l
ine 11, in <module>
    from app import signals
  File "C:\Users\David\Source\Repos\path\to\projfiles\app\signals.py",
line 7, in <module>
    @receiver(post_save, sender=get_model('app', 'Game'))
  File "C:\Python34\lib\site-packages\django\apps\registry.py", line 199, in get
_model
    self.check_models_ready()
  File "C:\Python34\lib\site-packages\django\apps\registry.py", line 131, in che
ck_models_ready
    raise AppRegistryNotReady("Models aren't loaded yet.")
django.core.exceptions.AppRegistryNotReady: Models aren't loaded yet.

EDIT2:我在ready() 函数中添加了print,但没有看到任何输出。这是我安装的应用程序:

INSTALLED_APPS = (
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.sites',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'kombu.transport.django',
    'accounts',
    'app',
    'scores',
    'rest_framework',
    'rest_framework.authtoken',
    'rest_auth',
    # Uncomment the next line to enable the admin:
     'django.contrib.admin',
    # Uncomment the next line to enable admin documentation:
    # 'django.contrib.admindocs',
)

【问题讨论】:

  • 您使用的是哪个版本的 Python?另外,请复制并粘贴您收到的确切回溯。
  • 如果您使用的是 Python 3,那么我认为您需要使用 from . import signals 进行相对导入,而不是 from app import signals。试一试。
  • 对不起,我试图快速编辑它。你的apps.py 文件应该是from . import signals,而不是from app import signals。这是假设apps.py 位于funproj/app/apps.py,紧邻signals.pymodels.py
  • 是的,它们都应该在app 中。只要funproj.app 在您的INSTALLED_APPS 设置中,ready 就应该执行。也许可以尝试:1)在ready() 中添加打印语句以确认它正在运行,2)从settings.py 复制并粘贴您的INSTALLED_APPS 设置,以便我们确保您的应用程序设置正确。
  • 是的,您的models.py 不应导入信号。只有apps.py 应该这样做来设置信号。

标签: python django django-models django-signals


【解决方案1】:

您似乎同时拥有 apps.pymodels.py 导入信号。加载 models.py 时,它会导入 signals,然后尝试引用您的 Game 模型,从而导致“模型尚未加载”错误。

models.py 中删除from app import signals。您可以从signals 导入您的models,但不能反过来。

【讨论】:

    【解决方案2】:

    试试这个:

    @receiver(post_save, sender='app.Game')
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2011-04-01
      • 2018-03-18
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多