Подтвердить что ты не робот

Django: AppRegistryNotReady()

Python: 2.7; Django: 1,7; Mac 10.9.4

Я следую учебнику Танго с Django

В главе 5 учебное пособие описано, как создать популяцию script, которая может автоматически создавать некоторые данные для базы данных для простоты разработки.

Я создал populate_rango.py на том же уровне manage.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()

Затем я запустил python populate_rango.py на терминале на уровне manage.py, добавлен AppRegistryNotReady():

django.core.exceptions.AppRegistryNotReady

Затем я googled, нашел что-то вроде 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.

И я до сих пор не знаю, что мне делать, может ли кто-нибудь помочь? спасибо!!!

4b9b3361

Ответ 1

Если вы используете проектные приложения django в автономных сценариях, другими словами, без использования manage.py - сначала нужно сначала вызвать django.setup() вручную - он будет настраивать ведение журнала и, что важно - заполнить реестра приложений.

Цитата из Процесс инициализации docs:

Настройка()

Эта функция вызывается автоматически:

  • При запуске HTTP-сервера через поддержку Djangos WSGI.

  • При вызове команды управления.

Он должен быть вызван явно в других случаях, для экземпляр в простых сценариях Python.

В вашем случае вам нужно вызвать setup() вручную:

if __name__ == '__main__':
    print "Starting Rango population script..."
    os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'tangle.settings')

    import django
    django.setup()

    populate()

Кроме того, эта проблема подробно описана в разделе Troubleshooting.

Ответ 2

Я нашел это решение, добавив

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

после

os.environ.setdefault ...

Ответ 3

Я просто наткнулся на ту же проблему на локальном сервере разработки.

После того, как вы нажали какой-то измененный код, ошибка была сброшена. Проблема здесь явно не имеет ничего общего с wsgi, поэтому я попытался запустить manage.py

Простой: python manage.py показывает реальную причину ошибки.

В моем случае забытый импорт внешнего приложения Django.

Возможно, это помогает кому-то другому.

Ответ 4

Я также столкнулся с этой проблемой, используя Django 1.7 на сервере Apache. Изменение вызова обработчика wsgi в моем файле wsgi.py устраняет проблему:

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

Это было предложено здесь пользователем 'jezdez'.