При использовании Python 3.9 и Django 3.1.3 сервер вылетает при повторном запуске

#python-3.x #django #localhost #pihole

#python-3.x #django #localhost #pihole

Вопрос:

это мой первый вопрос при переполнении стека. Я изучаю Python около месяца, а Django — две недели. Я попытался запустить второй сервер на своем MacBook Pro, а затем возникли эти проблемы.(сообщения об ошибках с моего терминала ниже) Второй сервер включал в себя некоторые другие приложения, включая Pihole. Я удалил файлы второго сервера и перезагрузился, проблема решена! Следующим делом было то, что я попытался отредактировать свой Views.py файл в Django, а затем то же сообщение об ошибке вернулось, когда я повторно загрузил свой сервер Django в папку виртуальной среды. Смотрите Ошибки ниже:

 mymac@michaels-MacBook-Pro mfdw_root % python manage.py runserver
Traceback (most recent call last):
  File "/Users/mymac/Desktop/mfdw_project/mfdw_root/manage.py", line 22, in <module>
    main()
  File "/Users/mymac/Desktop/mfdw_project/mfdw_root/manage.py", line 18, in main
    execute_from_command_line(sys.argv)
  File "/Library/Frameworks/Python.framework/Versions/3.9/lib/python3.9/site-packages/django/core/management/__init__.py", line 401, in execute_from_command_line
    utility.execute()
  File "/Library/Frameworks/Python.framework/Versions/3.9/lib/python3.9/site-packages/django/core/management/__init__.py", line 345, in execute
    settings.INSTALLED_APPS
  File "/Library/Frameworks/Python.framework/Versions/3.9/lib/python3.9/site-packages/django/conf/__init__.py", line 83, in __getattr__
    self._setup(name)
  File "/Library/Frameworks/Python.framework/Versions/3.9/lib/python3.9/site-packages/django/conf/__init__.py", line 70, in _setup
    self._wrapped = Settings(settings_module)
  File "/Library/Frameworks/Python.framework/Versions/3.9/lib/python3.9/site-packages/django/conf/__init__.py", line 177, in __init__
    mod = importlib.import_module(self.SETTINGS_MODULE)
  File "/Library/Frameworks/Python.framework/Versions/3.9/lib/python3.9/importlib/__init__.py", line 127, in import_module
    return _bootstrap._gcd_import(name[level:], package, level)
  File "<frozen importlib._bootstrap>", line 1030, in _gcd_import
  File "<frozen importlib._bootstrap>", line 1007, in _find_and_load
  File "<frozen importlib._bootstrap>", line 986, in _find_and_load_unlocked
  File "<frozen importlib._bootstrap>", line 680, in _load_unlocked
  File "<frozen importlib._bootstrap_external>", line 786, in exec_module
  File "<frozen importlib._bootstrap_external>", line 923, in get_code
  File "<frozen importlib._bootstrap_external>", line 853, in source_to_code
  File "<frozen importlib._bootstrap>", line 228, in _call_with_frames_removed
  File "/Users/mymac/Desktop/mfdw_project/mfdw_root/mfdw_site/settings.py", line 123
    'DIRS': [BASE_DIR / 'mfdw_site/templates'],
    ^
SyntaxError: illegal target for annotation


end of errors********
 

Это мой первый вопрос в Stack Overflow, и сейчас я очень не уверен, смогу ли я когда-нибудь снова запустить свой сервер на моем MacBook Pro с Python 3.9.0 и Django 3.1.3
Это ошибка, которую я получаю выше, и я не могу подключиться к 127.0.0.1, локальному хосту на моем MacBook Pro.
Пожалуйста, попробуйте и дайте мне подсказку о том, как действовать дальше. Я следил за уроками djangobook.com .

Ниже приведен мой settings.py файл:

 """
Django settings for mfdw_site project.

Generated by 'django-admin startproject' using Django 3.1.3.

For more information on this file, see
https://docs.djangoproject.com/en/3.1/topics/settings/

For the full list of settings and their values, see
https://docs.djangoproject.com/en/3.1/ref/settings/
"""

from pathlib import Path

# Build paths inside the project like this: BASE_DIR / 'subdir'.
BASE_DIR = Path(__file__).resolve().parent.parent


# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/3.1/howto/deployment/checklist/

# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = '# secret key goes here, it is present in actual code'

# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True

ALLOWED_HOSTS = []


# Application definition

INSTALLED_APPS = [
    'pages.apps.PagesConfig',
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
]

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

ROOT_URLCONF = 'mfdw_site.urls'

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [BASE_DIR / 'mfdw_site/templates'],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]

WSGI_APPLICATION = 'mfdw_site.wsgi.application'


# Database
# https://docs.djangoproject.com/en/3.1/ref/settings/#databases

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': BASE_DIR / 'db.sqlite3',
    }
}


# Password validation
# https://docs.djangoproject.com/en/3.1/ref/settings/#auth-password-validators

AUTH_PASSWORD_VALIDATORS = [
    {
        'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
    },
]


# Internationalization
# https://docs.djangoproject.com/en/3.1/topics/i18n/

LANGUAGE_CODE = 'en-us'

TIME_ZONE = 'UTC'

USE_I18N = True

USE_L10N = True

USE_TZ = True


# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/3.1/howto/static-files/

STATIC_URL = '/static/'

'DIRS': [BASE_DIR / 'mfdw_site/templates'],

STATICFILES_DIRS = [BASE_DIR / 'mfdw_site/static')]

 

Кроме того, есть ли проблема с путем при моей установке Django? Я работаю на MacBook Pro, который должным образом обновлен для использования Python 3.9. Я думаю, что это может иметь какое-то отношение к этой части ошибок:

 "/Library/Frameworks/Python.framework/Versions/3.9/lib/python3.9/site-packages/django/core/management/__init__.py", line 401, in execute_from_command_line
    utility.execute()
 

Кажется ли это разумным? Помеченный код в settings.py встречается в строке 123.
Также мне кажется, что в python 3.9 включена установка django, которая путается по пути с файлами mfdw_project.
Прав ли я и что мне с этим делать?

Комментарии:

1. Первое, что я бы сделал, это убедиться, что у вас нет синтаксических ошибок в вашем settings.py досье.

Ответ №1:

Пожалуйста, внимательно прочитайте сообщение об ошибке, в нем говорится, что ваш файл настроек неправильно настроен в строке 123, и отображается строка, которая нарушает ^ в качестве знака того, где это происходит:

 'DIRS': [BASE_DIR / 'mfdw_site/templates'],
^
 

и в нем говорится о синтаксической ошибке, поэтому вы можете сказать, что проблема в том, что вы написали что-то не в соответствии с синтаксисом python.
В соответствии с этим вы должны проверить, что происходит в строке перед этой строкой (строка 122), проверить, что произойдет, если вы поместите эту строку в комментарий (с #), он либо найдет другую ошибку в следующей строке, найдет ошибку где-нибудь позже или будет работать гладко.

Если он обнаружит ошибку в следующей строке, вы можете проверить, что вы сделали неправильно в строке перед этой (строка 122). Если он обнаружит ошибку где-нибудь позже, вы можете понять, что проблема связана с фактической строкой (строка 122), и это, вероятно, /, который у вас есть, разделителем списка является запятая (,), а не / …

Редактировать: Во-первых, спасибо за добавление файла настроек, это помогает найти ошибку после того, как мы знаем, что искать. Нарушающая строка равна 123 и выглядит так:

 'DIRS': [BASE_DIR / 'mfdw_site/templates'],
 

У этого есть 3 проблемы:

  1. ‘DIRS’ не должен быть строкой, это должна быть переменная, поэтому удалите ‘.
  2. В строке не должно быть двоеточия, это не словарь или определение функции.
  3. Я понимаю, что вы хотите указать путь как BASE_DIR/mfdw_site/templates , предполагая, что это так, это может быть [f'{BASE_DIR}/mfdw_site/templates’] и несколько других вариантов, но это самый простой

Комментарии:

1. В строке 11 или перед ней в моем settings.py файл есть только комментарии, созданные с помощью «django-admin startproject mfdw_site» в консоли, чтобы начать создавать файлы django. Комментарии заключены в три двойные кавычки, например: «»» комментарии «»» Строка 12 — пустая строка.

2. Я отредактировал ответ, чтобы учесть предоставленные вами добавленные данные и исправить номер строки

3. Я думаю, вы могли бы подумать, что имеете в виду конструкцию, которая опирается на os.path.join , которая устарела в пользу pathlib. Я взял код, который использовал в settings.py из курса под названием Djangobook.com . Он застрял в пересмотре кода, чтобы справиться с обновлением с python 2 до python 3. Остальные ошибки после той, которую вы упомянули, относятся к установке python 3 в папке библиотеки моего mac и его собственной подпапке, содержащей Django. У меня также есть папка на моем рабочем столе, которая является моей папкой проекта Django, и она содержит мою виртуальную среду Django для запуска приложений Django.

4. Весь смысл использования virtualenv для создания виртуальной среды в папке, в которой установлена собственная версия python. Предполагается, что это предотвратит случайное изменение установки python на моем Mac. Эта проблема, с которой я сталкиваюсь, заключается в том, что я слишком молод, чтобы знать, как убедиться, что я использую только версию python виртуальной среды в своем приложении. Я слышал, что причиной может быть переменная PYTHONPATH, но это выходит далеко за рамки моего понимания. Последние ошибки в приведенном выше файле, похоже, относятся к вызовам, выполняемым внутри библиотечной версии python на моем компьютере, которые не должны быть задействованы. спасибо

5. Я не уверен, что понимаю, вы исправили ошибку в строке 123 или нет? Если вы это сделали, я предлагаю вам задать другой вопрос, поскольку я не совсем понимаю ваши новые ошибки, и мне трудно помочь в комментариях. Если вы не исправили, то каковы были ваши выводы по моим предложениям?