Django:AppRegistryNotReady()

41

Python版本:2.7;Django版本:1.7;Mac操作系统版本为10.9.4。

我正在按照《与 Django 跳舞》教程中的创建填充数据脚本的步骤进行操作,以便于在开发时自动向数据库中添加一些数据。

在第5章,该教程介绍了如何创建填充数据脚本。

我已经在manage.py同级目录下创建了populate_rango.py文件。

以下是populate_rango.py文件内容:

import os

def populate():
    python_cat = add_cat('Python')

    add_page(
        cat=python_cat,
        title="Official Python Tutorial",
        url="http://docs.python.org/2/tutorial/"
    )

    add_page(
        cat=python_cat,
        title="How to Think like a Computer Scientist",
        url="http://www.greenteapress.com/thinkpython/"
    )

    add_page(
        cat=python_cat,
        title="Learn Python in 10 Minutes",
        url="http://www.korokithakis.net/tutorials/python/"
    )

    django_cat = add_cat("Django")

    add_page(
        cat=django_cat,
        title="Official Django Tutorial",
        url="https://docs.djangoproject.com/en/1.5/intro/tutorial01/"
    )

    add_page(
        cat=django_cat,
        title="Django Rocks",
        url="http://www.djangorocks.com/"
    )

    add_page(
        cat=django_cat,
        title="How to Tango with Django",
        url="http://www.tangowithdjango.com/"
    )

    frame_cat = add_cat("Other Frameworks")

    add_page(
        cat=frame_cat,
        title="Bottle",
        url="http://bottlepy.org/docs/dev/"
    )

    add_page(
        cat=frame_cat,
        title="Flask",
        url="http://flask.pocoo.org"
    )

    for c in Category.objects.all():
        for p in Page.objects.filter(category=c):
            print "- {0} - {1}".format(str(c), str(p))


def add_page(cat, title, url, views=0):
    p = Page.objects.get_or_create(category=cat, title=title, url=url, views=views)[0]
    return p


def add_cat(name):
    c = Category.objects.get_or_create(name=name)[0]
    return c

if __name__ == '__main__':
    print "Starting Rango population script..."
    os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'tangle.settings')
    from rango.models import Category, Page
    populate()

我在manage.py所在的终端运行python populate_rango.py时,遇到了AppRegistryNotReady()错误。

django.core.exceptions.AppRegistryNotReady

然后我在谷歌上搜索,找到了类似于这个的东西:

Standalone scripts¶
If you’re using Django in a plain Python script — rather than a management command — and you rely on the DJANGO_SETTINGS_MODULE environment variable, you must now explicitly initialize Django at the beginning of your script with:

>>> import django
>>> django.setup()
Otherwise, you will hit an AppRegistryNotReady exception.

我仍然不知道我应该做什么,有人能帮忙吗?谢谢!!!


如果您在运行测试时遇到异常,我建议使用 pytest-django - guettli
4个回答

66
如果您在独立脚本中使用Django项目应用程序,换句话说,不使用manage.py - 您需要手动调用django.setup(),它将配置日志记录,并且更重要的是 - 填充 应用注册表
引用自初始化过程文档:
setup()函数
此函数会自动调用:
通过Django的WSGI支持运行HTTP服务器时。 当调用管理命令时。
在其他情况下必须显式调用它,例如在纯Python脚本中。
在您的情况下,您需要手动调用setup()
if __name__ == '__main__':
    print "Starting Rango population script..."
    os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'tangle.settings')

    import django
    django.setup()

    populate()

此外,该问题在故障排除部分有详细描述。


3

我在本地开发服务器上遇到了同样的问题。

在拉取一些更改的代码后,错误被抛出。显然,这里的问题与wsgi无关,因此我尝试运行manage.py

一个简单的:python manage.py揭示了真正的错误原因。

在我的情况下,是忘记导入外部Django应用程序。

也许这会帮助其他人解决问题。


谢谢,伙计。错误与 celery 无关,而是来自外部包的错误... 只需运行 manage.py 并找到真正的原因即可。 - Thomas John

3
我发现了这个解决方案,只需要添加
from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()

之后

os.environ.setdefault ...

1
我也遇到了使用Django 1.7在Apache服务器上的这个问题。更改我的wsgi.py文件中的wsgi处理程序调用可以解决这个问题:
import django.core.handlers.wsgi
application = django.core.handlers.wsgi.WSGIHandler()

这个建议是由用户'jezdez' 在这里 提出的。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接