Django: AppRegistryNotReady()错误

41 投票
4 回答
33409 浏览
提问于 2025-04-18 13:37

Python版本:2.7;Django版本:1.7;Mac系统:10.9.4

我正在跟着Tango with Django的教程学习。

在第五章,教程教我们如何创建一个数据填充脚本,这个脚本可以自动为数据库生成一些数据,方便开发。

我在与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.

但是我还是不知道该怎么做,有人能帮帮我吗?谢谢!!!

4 个回答

1

我在使用Django 1.7和Apache服务器的时候也遇到了这个问题。通过修改我在wsgi.py文件中的wsgi处理器调用,问题就解决了:

import django.core.handlers.wsgi
application = django.core.handlers.wsgi.WSGIHandler()

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

3

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

在我拉取了一些修改过的代码后,出现了错误。

这个问题显然和wsgi没有关系,所以我尝试运行manage.py。

简单地输入:python manage.py,就能找到真正的错误原因。

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

希望这能帮助到其他人。

3

我找到了解决办法,就是在

os.environ.setdefault ...

后面加上

from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()
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()

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

撰写回答