Django:AppRegistryNotReady()

时间:2014-07-17 01:13:02

标签: python django django-1.7

Python:2.7; Django:1.7; Mac 10.9.4

我遵循Tango with 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

然后我用Google搜索,找到类似this的内容:

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.

我仍然不知道我该怎么做,有人可以帮忙吗? THX !!!

4 个答案:

答案 0 :(得分:54)

如果您在独立脚本中使用django项目应用程序,换句话说,不使用manage.py - 您需要首先手动调用django.setup() - 它将配置日志记录,重要的是 - 填充apps registry

引自Initialization process docs:

  

设置()

     

自动调用此函数:

     
      
  • 通过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()

此外,Troubleshooting部分详细介绍了此问题。

答案 1 :(得分:3)

我在本地开发服务器中偶然发现了同样的问题。

在删除一些已更改的代码后,错误被抛出。 这里的问题显然与wsgi无关,所以我试着运行manage.py

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

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

也许这可以帮助其他人。

答案 2 :(得分:2)

我找到了这个解决方案,添加了

from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()

os.environ.setdefault ...

答案 3 :(得分:1)

我在Apache服务器上使用Django 1.7时也遇到过这个问题。更改wsgi文件中的wsgi.py处理程序调用修复了问题:

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

用户'jezdez'建议here