Ошибка неверной настройки параметров Django DB

128

Django (1.5) отлично работает для меня, но когда я запускаю интерпретатор Python (Python 3), чтобы проверить некоторые вещи, я получаю самую странную ошибку при попытке импортировать - from django.contrib.auth.models import User -

Traceback (most recent call last):
  File "/usr/local/lib/python3.2/dist-packages/django/conf/__init__.py", line 36, in _setup
    settings_module = os.environ[ENVIRONMENT_VARIABLE]
  File "/usr/lib/python3.2/os.py", line 450, in __getitem__
    value = self._data[self.encodekey(key)]
KeyError: b'DJANGO_SETTINGS_MODULE'

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/usr/local/lib/python3.2/dist-packages/django/contrib/auth/models.py", line 8, in <module>
    from django.db import models
  File "/usr/local/lib/python3.2/dist-packages/django/db/__init__.py", line 11, in <module>
    if settings.DATABASES and DEFAULT_DB_ALIAS not in settings.DATABASES:
  File "/usr/local/lib/python3.2/dist-packages/django/conf/__init__.py", line 52, in __getattr__
    self._setup(name)
  File "/usr/local/lib/python3.2/dist-packages/django/conf/__init__.py", line 45, in _setup
    % (desc, ENVIRONMENT_VARIABLE))

django.core.exceptions.ImproperlyConfigured: Requested setting DATABASES, 
  but settings are not configured. You must either define the environment 
  variable DJANGO_SETTINGS_MODULE or call settings.configure() 
  before accessing settings.

Как он может быть неправильно настроен, когда он отлично работает за пределами интерпретатора Python? В настройках Django настройки DATABASES:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2', # Add 'postgresql_psycopg2', 'mysql', 'sqlite3' or 'oracle'.
        'NAME': 'django_db', # Or path to database file if using sqlite3.
        # The following settings are not used with sqlite3:
        'USER': 'zamphatta',
        'PASSWORD': 'mypassword91',
        'HOST': '', # Empty for localhost through domain sockets or '127.0.0.1' for localhost through TCP.
        'PORT': '', # Set to empty string for default.
    }
}

... как это неправильно настроено?

  • 0
    Наткнулся на это при настройке нового проекта. Мне показалось полезным unset DJANGO_SETTINGS_MODULE . Я столкнулся с проблемой, когда я установил env var в моем .bashrc
Теги:

6 ответов

210
Лучший ответ

Вы не можете просто запускать Python и проверять вещи, Django не знает, с каким проектом вы хотите работать. Вы должны сделать одно из следующих:

  • Используйте python manage.py shell
  • Используйте django-admin.py shell --settings=mysite.settings (или любой другой модуль настроек, который вы используете)
  • Установите переменную среды DJANGO_SETTINGS_MODULE в вашей ОС на mysite.settings
  • (Это удалено в Django 1.6). Используйте setup_environ в интерпретаторе python:

    from django.core.management import setup_environ
    from mysite import settings
    
    setup_environ(settings)
    

Естественно, первый способ - самый простой.

  • 0
    Спасибо! Это было не совсем ясно для меня в документации, или, может быть, я прочитал это и забыл, когда мне нужно было это сделать.
  • 6
    Как ни странно, он не может найти файл «mysite.settings», но я вижу, что он находится прямо там, как mysite / settings.py. Тьфу! Я начинаю ненавидеть Джанго.
Показать ещё 9 комментариев
29

В вашей оболочке python/ipython выполните:

from django.conf import settings

settings.configure()
  • 7
    Apps aren't loaded yet.
7

В Django 1.9 я попробовал django-admin runningerver и получил ту же ошибку, но когда я использовал "python manage.py runningerver", я получил ожидаемый результат. Это может решить эту ошибку для многих людей!

  • 0
    то же самое, на django 1.10, но при попытке запустить команду loaddata
5

В 2017 году с django 1.11.5 и python 3.6:

import django
import os
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "mysite.settings")
django.setup()

.py, в который вы помещаете этот код, должен находиться в mysite (родительский)

  • 0
    кажется, это работает для меня, спасибо
  • 0
    Большое спасибо, ни одно из других решений не сработало в моем случае
Показать ещё 2 комментария
2

В моем случае, я получил это, пытаясь запустить тесты Django через PyCharm. Я думаю, это потому, что PyCharm не загружает начальные параметры проекта Django, то есть те, которые manage.py shell запускаются изначально. Их можно добавить к началу тестирования script или просто запустить тесты с помощью manage.py test.

Версии:

  • Python 3.5 (in virtualenv)
  • PyCharm 2016.3.2 Professional
  • Django 1.10
2

в моем собственном случае в django 1.10.1, запущенном на python2.7.11, я пытался запустить сервер, используя django-admin runserver вместо manage.py runserver в моей директории проектов.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню