Django: AppRegistryNotReady()错误
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 个回答
我在使用Django 1.7和Apache服务器的时候也遇到了这个问题。通过修改我在wsgi.py
文件中的wsgi
处理器调用,问题就解决了:
import django.core.handlers.wsgi
application = django.core.handlers.wsgi.WSGIHandler()
这个建议是用户'jezdez'在这里提出来的。
我在本地开发服务器上遇到了同样的问题。
在我拉取了一些修改过的代码后,出现了错误。
这个问题显然和wsgi没有关系,所以我尝试运行manage.py。
简单地输入:python manage.py
,就能找到真正的错误原因。
在我的情况下,是我忘记导入一个外部的Django应用。
希望这能帮助到其他人。
我找到了解决办法,就是在
os.environ.setdefault ...
后面加上
from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()
如果你在独立的脚本中使用你的 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()
此外,这个问题在 故障排除 部分有详细描述。