django-admin и manage.py¶
django-admin – это консольный инструмент Django. Этот раздел описывает его возможности.
Также для каждого проекта автоматически создается manage.py. manage.py – это простой интерфейс для django-admin, но есть ряд отличий:
Скрипт django-admin должен находиться в вашем системном пути, если вы установили Django через pip. Если его нет на вашем пути, убедитесь, что ваша виртуальная среда активирована.
При работе с одним проектом Django удобнее использоваться manage.py, чем django-admin. Если вам необходимо переключаться между различными фалами настройки, используйте django-admin с переменной окружения DJANGO_SETTINGS_MODULE или опцией :djadminopt:`--settings`.
Во всех примерах в этом разделе используется django-admin, но вы можете использовать manage.py или python -m django, ничего не изменится.
Использование¶
$ django-admin <command> [options]
$ manage.py <command> [options]
$ python -m django <command> [options]
...\> django-admin <command> [options]
...\> manage.py <command> [options]
...\> py -m django <command> [options]
command – одна из команд, описанных в этом разделе. options – необязательные опции команды.
Как отобразить помощь¶
- django-admin help¶
Выполните django-admin help, что бы увидеть помощь и список доступных команд.
Выполните django-admin help --commands, чтобы увидеть список доступных команд.
Выполните django-admin help <command>, чтобы увидеть описание указанной команды и список доступных опций.
Названия приложений¶
Большая часть команд принимает список «названий приложений». «Название приложения» – это название основного пакета приложения. Например, если настройка INSTALLED_APPS содержит строку 'mysite.blog', название приложения будет blog.
Получаем текущую версию Django¶
- django-admin version¶
Выполните django-admin version, чтобы получить текущую версию Django.
Вывод соответствует схеме, описанной в PEP 440:
1.4.dev17026
1.4a1
1.4
Вывод отладочной информации¶
Используйте --verbosity, если он поддерживается, чтобы указать объём уведомлений и отладочной информации, которые django-admin выводит на консоль.
Доступные команды¶
black¶
- django-admin check [app_label [app_label ...]]¶
Использует приложение проверки, чтобы проанализировать проект Django на наличие распространенных проблем.
По умолчанию будут проверены все приложения. Вы можете проверить подмножество приложений, предоставив список ярлыков приложений в качестве аргументов:
django-admin check auth admin myapp
- --tag TAGS, -t TAGS¶
Платформа системной проверки выполняет множество различных типов проверок, которые категоризируются тегами. Вы можете использовать эти теги, чтобы ограничить выполняемые проверки только теми, которые относятся к определенной категории. Например, чтобы выполнить только проверку моделей и совместимости, запустите:
django-admin check --tag models --tag compatibility
- --database DATABASE¶
Указывает базу данных для запуска проверок, требующих доступа к базе данных:
django-admin check --database default --database other
По умолчанию эти проверки не выполняются.
- --list-tags¶
Выводит список всех доступных тегов.
- --deploy¶
Опция --deploy выполняет дополнительные проверки, которые уместны только для настроек сервера, а не окружения для разработки.
Вы можете использовать эту опцию в своей локальной среде разработки, но поскольку ваш локальный модуль настроек разработки может не содержать многих ваших производственных настроек, вы, вероятно, захотите указать команде check другой модуль настроек, либо установив переменную среды DJANGO_SETTINGS_MODULE, либо передав опцию --settings:
django-admin check --deploy --settings=production_settings
Вы можете использовать эту опцию на «боевом» или тестовом сервере (без --settings). Вы даже можете сделать проверку частью тестов.
- --fail-level {CRITICAL,ERROR,WARNING,INFO,DEBUG}¶
Указывает уровень сообщения, при котором команда завершится с ненулевым статусом. По умолчанию установлено ОШИБКА.
compilemessages¶
- django-admin compilemessages¶
Компилирует .po файлы, созданные командой makemessages, в файлы .mo, которые используются gettext для локализации проекта. Смотрите Интернационализация и локализация.
- --locale LOCALE, -l LOCALE¶
Опция --locale или -l позволяет указать локаль, которая будет использоваться при выполнении команды.
- --exclude EXCLUDE, -x EXCLUDE¶
Опция :djadminopt:`--exclude` (или короткий вариант -x) позволяет исключить локали из обработки. Если не указана, ни одна локаль не будет исключена.
- --use-fuzzy, -f¶
Включает «нечеткие переводы»_ в скомпилированные файлы.
Пример использования:
django-admin compilemessages --locale=pt_BR
django-admin compilemessages --locale=pt_BR --locale=fr -f
django-admin compilemessages -l pt_BR
django-admin compilemessages -l pt_BR -l fr --use-fuzzy
django-admin compilemessages --exclude=pt_BR
django-admin compilemessages --exclude=pt_BR --exclude=fr
django-admin compilemessages -x pt_BR
django-admin compilemessages -x pt_BR -x fr
- --ignore PATTERN, -i PATTERN¶
Опция --ignore или -i позволяет игнорировать файлы или каталоги, которые соответствуют указанному шаблону в стиле glob. Можно указать несколько раз.
Пример использования:
django-admin compilemessages --ignore=cache --ignore=outdated/*/locale
createcachetable¶
- django-admin createcachetable¶
Создает таблицу в базе данных, которая будет использоваться соответствующим бэкендом кеша, используя информацию из настроек проекта. Смотрите Система кэширования Django.
- --database DATABASE¶
Указывает базу данных, в которой будут созданы таблицы кэша. По умолчанию установлено default.
- --dry-run¶
Опция :djadminopt:`--dry-run` выведет SQL, который выполнился бы, без его выполнения. Вы можете изменить его или использовать миграции.
dbshell¶
- django-admin dbshell¶
Запускает консольный клиент для подключения к базе данных. Консольный клиент определяется настройкой ENGINE, параметры подключения – настройками USER, PASSWORD, и т.д.
Для PostgreSQL используется консольный клиент
psql.Для MySQL используется
mysql.Для SQLite используется
sqlite3.Для Oracle запустит консольный клиент
sqlplus.
Эта команда подразумевает, что клиент находится в PATH системы, и запуск клиента в консоли (psql, mysql, sqlite3, sqlplus) работает. Нет способа указать путь к клиенту.
- --database DATABASE¶
Указывает базу данных, в которой открывается оболочка. По умолчанию установлено default.
- -- ARGUMENTS¶
Любые аргументы после разделителя -- будут переданы базовому клиенту командной строки. Например, в PostgreSQL вы можете использовать флаг -c команды psql для прямого выполнения необработанного SQL-запроса:
$ django-admin dbshell -- -c 'select current_user'
current_user
--------------
postgres
(1 row)
...\> django-admin dbshell -- -c 'select current_user'
current_user
--------------
postgres
(1 row)
В MySQL/MariaDB это можно сделать с помощью флага -e команды mysql:
$ django-admin dbshell -- -e "select user()"
+----------------------+
| user() |
+----------------------+
| djangonaut@localhost |
+----------------------+
...\> django-admin dbshell -- -e "select user()"
+----------------------+
| user() |
+----------------------+
| djangonaut@localhost |
+----------------------+
diffsettings¶
- django-admin diffsettings¶
Показывает разницу между текущими настройками и настройками Django по умолчанию.
Настройки, которые не указаны в настройках по умолчанию, выводятся с "###" в конце. Например, в настройках по умолчанию не указан ROOT_URLCONF, и в выводе diffsettings, к ROOT_URLCONF будет добавлен "###" в конце.
- --all¶
Опция :djadminopt:`--all` позволяет вывести все настройки, даже если они не отличаются от настроек по умолчанию. Такие настройки выводятся с префиксом "###".
- --default MODULE¶
Показывает разницу между текущими настройками и настройками Django по умолчанию.
- --output {hash,unified}¶
Определяет выходной формат. Доступные значения: hash и unified. хеш — это режим по умолчанию, в котором отображаются выходные данные, описанные выше. unified отображает вывод, аналогичный diff -u. Настройки по умолчанию имеют префикс со знаком минус, за которым следуют измененные настройки со знаком плюс.
magenta¶
- django-admin dumpdata [app_label[.ModelName] [app_label[.ModelName] ...]]¶
Выводит в консоль все данные из базы данных, которые связаны с указанными приложениями.
Если приложение не указано, будет выполнен дамп данных для всех приложений.
Вывод команды dumpdata может использоваться для команды loaddata.
Когда результат dumpdata сохраняется в виде файла, он может служить фикстурой для tests или как начальными данными.
Обратите внимание, dumpdata использует менеджер по умолчанию модели для получения данных. Если вы используете собственный менеджер как менеджер по умолчанию, который отфильтровывает часть данных, отфильтрованные данные не попадут в результат команды.
- --all, -a¶
Опция :djadminopt:`--all` позволяет указать dumpdata использовать базовый менеджер Django, чтобы исключить фильтрацию данных собственным менеджером модели.
- --format FORMAT¶
Указывает формат сериализации выходных данных. По умолчанию JSON. Поддерживаемые форматы перечислены в Форматы сериализации.
- --indent INDENT¶
Указывает количество отступов, которые будут использоваться при выводе. По умолчанию установлено значение «Нет», при котором все данные отображаются в одной строке.
- --exclude EXCLUDE, -e EXCLUDE¶
Предотвращает сохранение определенных приложений или моделей (указанных в форме app_label.ModelName). Если вы укажете имя модели, будет исключена только эта модель, а не все приложение. Вы также можете смешивать имена приложений и названия моделей.
Если вы хотите исключить несколько приложений, передайте --exclude несколько раз:
django-admin dumpdata --exclude=auth --exclude=contenttypes
- --database DATABASE¶
Указывает базу данных, из которой будут выгружены данные. По умолчанию установлено default.
- --natural-foreign¶
Если указана эта опция, Django будут использовать метод связанной модели natural_key() для внешних ключей и связей многое-ко-многим. Если вы делаете дамп contrib.auth Permission или contrib.contenttypes ContentType, вам следует использовать эту опцию. Подробности смотрите в разделе о натуральных ключах.
- --natural-primary¶
Если указана эта опция, Django не будет добавлять первичный ключ в результат, т.к. он может быть вычислен при десирализации данных.
- --pks PRIMARY_KEYS¶
Выводит только объекты, указанные в списке первичных ключей, разделенных запятыми. Это доступно только при сбросе одной модели. По умолчанию выводятся все записи модели.
- --output OUTPUT, -o OUTPUT¶
Указывает файл для записи сериализованных данных. По умолчанию данные передаются на стандартный вывод.
Если эта опция установлена и --verbosity больше 0 (по умолчанию), в терминале отображается индикатор выполнения.
Сжатие светильников¶
Выходной файл можно сжать в один из форматов bz2, gz, lzma или xz, закончив имя файла соответствующим расширением. Например, чтобы вывести данные в виде сжатого файла JSON:
django-admin dumpdata -o mydata.json.gz
flush¶
- django-admin flush¶
Удаляет все данные из базы данных, запускает «post-synchronization» обработчики. Таблица с выполненными миграциями не очищается.
Если вы предпочитаете начать с пустой базы данных и повторно выполнить все миграции, вам следует удалить и воссоздать базу данных, а затем вместо этого запустить migrate.
- --noinput, --no-input¶
Подавляет все запросы пользователя.
- --database DATABASE¶
Указывает базу данных для очистки. По умолчанию установлено default.
inspectdb¶
- django-admin inspectdb [table [table ...]]¶
Анализирует таблицы в базе данных, указанной настройкой NAME, и выводит сгенерированные модели Django (файл models.py) в стандартный вывод.
Вы можете выбрать, какие таблицы или представления проверять, передав их имена в качестве аргументов. Если аргументы не указаны, модели для представлений создаются только в том случае, если используется опция --include-views. Модели для таблиц разделов создаются в PostgreSQL, если используется опция --include-partitions.
Вы можете использовать эту команду, чтобы создать модели для уже существующей базы данных. Команда анализирует базу данных и создает модель для каждой таблицы.
Сгенерированные модели будут содержать атрибут поля для каждого поля таблицы. Обратите внимание, есть несколько особенностей в работе этой команды:
Если
inspectdbне может подобрать подходящий тип поля модели, будет использоваться полеTextFieldс комментарием в коде'This field type is a guess.'возле этого поля.Если название колонки в таблице входит в зарезервированные слова Python (такие как
'pass','class'или'for'),inspectdbдобавит'_field'к названию атрибута. Например, если таблица содержит колонку'for', сгенерированная модель будет содержать поле'for_field', с параметромdb_columnравным'for'.inspectdbдобавит комментарий в коде'Field renamed because it was a Python reserved word.'возле поля.
Эту команду можно использовать для генерации начальных моделей. После выполнения команды вам следует проверить сгенерированные модели и внести необходимые изменения. Также вам следует изменить порядок моделей в соответствии с внешними связями.
Django не добавляет значение по умолчанию для колонки в таблице, если поле модели содержит default. Аналогично команда inspectdb не добавляет в поле модели значение по умолчанию из колонки в таблице.
По умолчанию inspectdb создает неуправляемые модели. То есть с managed=False``в классе ``Meta модели, что указывает Django не управляет созданием, изменением или удалением таблицы. Чтобы позволить Django управлять моделью, установите параметр managed в True (или просто удалите его, True является значением по умолчанию).
Фикстуры для определенной базы данных¶
Оракул¶
Модели создаются для материализованных представлений, если используется
--include-views.
PostgreSQL¶
Модели создаются для сторонних таблиц.
Модели создаются для материализованных представлений, если используется
--include-views.Модели создаются для таблиц разделов, если используется
--include-partitions.
- --database DATABASE¶
Указывает базу данных для анализа. По умолчанию установлено default.
- --include-partitions¶
Если эта опция предусмотрена, модели также создаются для разделов.
Реализована только поддержка PostgreSQL.
- --include-views¶
Если указана эта опция, модели также создаются для представлений базы данных.
magenta¶
- django-admin loaddata fixture [fixture ...]¶
Ищет и загружает содержимое fixture в базу данных.
- --database DATABASE¶
Указывает базу данных, в которую будут загружены данные. По умолчанию установлено default.
- --ignorenonexistent, -i¶
Опция :djadminopt:`--ignorenonexistent` позволяет игнорировать отсутствие полей в модели и моделей, если они были удалены после создания фикстуры.
- --app APP_LABEL¶
Опция :djadminopt:`--app` позволяет указать приложение, которое будет использоваться для поиска фикстур. Без этой опции фикстуры ищутся во всех приложениях.
- --format FORMAT¶
Указывает формат сериализации (например, json или xml) для приборов, читаемых из стандартного ввода.
- --exclude EXCLUDE, -e EXCLUDE¶
Исключает загрузку фикстур из указанных приложений и/или моделей (в форме app_label или app_label.ModelName). Используйте эту опцию несколько раз, чтобы исключить более одного приложения или модели.
Загрузка фикстур из stdin¶
Вы можете использовать тире в качестве имени прибора для загрузки входных данных из sys.stdin. Например:
django-admin loaddata --format=json -
При чтении из stdin опция --format необходима для указания формата сериализации входных данных (например, json или xml).
Загрузка из stdin полезна при перенаправлении стандартного ввода и вывода. Например:
django-admin dumpdata --format=json --database=test app_label.ModelName | django-admin loaddata --format=json --database=prod -
Для генерации фикстур для loaddata можно использовать команду dumpdata.
См.также
Более подробную информацию о фикстурах смотрите в теме Фикстуры.
makemessages¶
- django-admin makemessages¶
Анализирует все файлы в текущем каталоге и парсит строки, которые помечены для перевода. Создает (или обновляет) файл переводимых сообщений в conf/locale (в каталоге проекта) или каталоге переводов (для проекта или приложения). Чтобы использовать файлы перевода с помощью gettext, необходимо их скомпилировать командой compilemessages. Смотрите раздел о i18n
Эта команда не требует настроенных настроек. Однако, если настройки не настроены, команда не может игнорировать каталоги MEDIA_ROOT и STATIC_ROOT или включать LOCALE_PATHS.
- --all, -a¶
Используйте опцию --all или -a чтобы обновить файлы перевода для всех языков.
- --extension EXTENSIONS, -e EXTENSIONS¶
Указывает список расширений файлов для проверки (по умолчанию: html, txt, py или js, если --domain` имеет значение djangojs).
Пример использования:
django-admin makemessages --locale=de --extension xhtml
Разделяйте несколько расширений запятыми или используйте -e или --extension несколько раз:
django-admin makemessages --locale=de --extension=html,txt --extension xml
- --locale LOCALE, -l LOCALE¶
Указывает локаль(и) для обработки.
- --exclude EXCLUDE, -x EXCLUDE¶
Опция :djadminopt:`--exclude` (или короткий вариант -x) позволяет исключить локали из обработки. Если не указана, ни одна локаль не будет исключена.
Пример использования:
django-admin makemessages --locale=pt_BR
django-admin makemessages --locale=pt_BR --locale=fr
django-admin makemessages -l pt_BR
django-admin makemessages -l pt_BR -l fr
django-admin makemessages --exclude=pt_BR
django-admin makemessages --exclude=pt_BR --exclude=fr
django-admin makemessages -x pt_BR
django-admin makemessages -x pt_BR -x fr
- --domain DOMAIN, -d DOMAIN¶
Указывает домен файлов сообщений. Поддерживаемые параметры:
djangoдля*.py,*.htmlи*.txtфайлов (по умолчанию)djangojsдля файлов*.js
- --symlinks, -s¶
Опция --symlinks или -s позволяет указать следовать ли по символическим ссылкам при поиске файлов.
Пример использования:
django-admin makemessages --locale=de --symlinks
- --ignore PATTERN, -i PATTERN¶
Опция --ignore или -i позволяет игнорировать файлы или каталоги, которые соответствуют указанному шаблону в стиле glob. Можно указать несколько раз.
По умолчанию используются следующие шаблоны: 'CVS', '.*', '*~', '*.pyc'
Пример использования:
django-admin makemessages --locale=en_US --ignore=apps/* --ignore=secret/*.html
- --no-default-ignore¶
Отключает значения по умолчанию --ignore.
- --no-wrap¶
Опция --no-wrap позволяет отключить разбивку длинных сообщений на несколько строк в файле перевода.
- --no-location¶
Опция --no-location позволяет отключить добавление „#: filename:line’ в файлы перевода. Обратите внимание, использование этой опции может усложнить работу технически образованным переводчикам, которым такие комментарии помогают понять смысл переводимого сообщения.
- --add-location [{full,file,never}]¶
Управляет строками комментариев #:filename:line в языковых файлах. Если вариант:
full(по умолчанию, если не указано): строки включают как имя файла, так и номер строки.файл: номер строки опущен.никогда: строки подавляются (аналогично--no-location).
Требуется gettext 0.19 или новее.
- --no-obsolete¶
Удаляет устаревшие строки сообщений из файлов .po.
- --keep-pot¶
Опция --keep-pot указывает Django не удалять временные .pot файлы, которые создаются перед созданием .po файлов. Это полезно при отладке ошибок, которые мешают созданию файлов перевода.
См.также
В Настройка команды makemessages вы можете узнать как настроить параметры, которые makemessages передает в xgettext.
makemigrations [<app_label>]¶
- django-admin makemigrations [app_label [app_label ...]]¶
Создает новые миграции на основе изменений в моделях. Подробнее о миграциях вы можете прочитать в соответствующем разделе.
Вы можете указать приложения, для которых следует создать миграции, также будут учитываться связанные приложения (например, которые содержат модели, на которые ссылаются ForeignKey).
Чтобы добавить миграции в приложение, у которого нет каталога «migrations», запустите makemigrations с атрибутом app_label приложения.
- --noinput, --no-input¶
Опция --noinput позволяет выполнить команду без запроса на любые действия от пользователя. Если команда не может выполнится автоматически, она завершиться с кодом ошибки 3.
- --empty¶
Опция --empty укажет makemigrations создать пустую миграцию для последующего редактирования вручную. Эту опцию следует использоваться только продвинутым пользователям, которые хорошо знают как работают миграции в Django.
- --dry-run¶
Опция --dry-run позволяет вывести все действия, которые будут выполнять создаваемые миграции, не создавая файл с миграцией. Если дополнительно указать --verbosity 3, будет выведено содержимое файлов миграций, которые будут созданы.
- --merge¶
Опция --merge позволяет исправить конфликты в миграциях.
- --name NAME, -n NAME¶
Опция --name позволяет указать миграции название.
- --no-header¶
Создавайте файлы миграции без версии Django и заголовка временной метки.
- --check¶
Выполняет выход makemigrations с ненулевым статусом при обнаружении изменений модели без миграции. Подразумевает --пробный запуск.
- --scriptable¶
Перенаправляет вывод журнала и входные запросы на stderr, записывая в stdout только пути к сгенерированным файлам миграции.
- --update¶
Объединяет изменения модели с последней миграцией и оптимизирует полученные операции.
Обновленная миграция будет иметь сгенерированное имя. Чтобы сохранить предыдущее имя, установите его с помощью --name.
white¶
- django-admin migrate [app_label] [migration_name]¶
Синхронизирует состояние базы данных с текущим состоянием моделей и миграций. Подробнее о миграциях вы можете прочитать в соответствующем разделе.
Поведение команды зависит от указанных аргументов:
Без аргументов: будет выполнена синхронизация всех приложений.
<app_label>: Будут выполнены миграции для указанного приложения до самой последней миграции. Это может вызвать миграцию других приложений через зависимости в миграциях.<app_label> <migrationname>: Приводит базу данных к состоянию, которые было бы после завершения указанной миграции, но последующие миграции не выполнены. Обратите внимание, это может привести к отмене миграций, если были выполнены миграции, которые следуют после указанной вами. Используйтеzero, чтобы отменить все миграции для приложения.
Предупреждение
При отмене миграции все зависимые миграции также будут отменены, независимо от <app_label>. Вы можете использовать --plan, чтобы проверить, какие миграции не будут применены.
- --database DATABASE¶
Указывает базу данных для миграции. По умолчанию установлено default.
- --fake¶
Опция --fake указывает Django пометить миграции как выполненные/невыполненные без выполнения каких-либо SQL запросов.
Эта опция предназначена для опытных пользователей, которые хотят явно указать состояние миграций после применения изменений вручную. Будьте осторожны, использование --fake может «сломать» автоматическое применение миграций.
- --fake-initial¶
Опция --fake-initial позволяет Django пропустить начальную миграцию, если уже существуют все таблицы для моделей, которые указанны в операциях :class:`~django.db.migrations.operations.CreateModel`миграции. Эта опция создана для первого выполнения миграции на базе данных, которая существовала до создания миграций. Однако, эта опция не выполняет проверки соответствия структуры таблиц и моделей, поэтому следует использовать её, если вы уверены в правильности миграций.
- --plan¶
Показывает операции миграции, которые будут выполнены для данной команды migrate.
- --run-syncdb¶
Опция --run-syncdb позволяет создать таблицы для приложений без миграций. Хоть это и не рекомендуется, но миграции могут быть очень медленными для больших проектов с сотнями моделей.
- --noinput, --no-input¶
Подавляет все запросы пользователя. Пример запроса спрашивает об удалении устаревших типов контента.
- --check¶
При обнаружении непримененных миграций завершает работу migrate с ненулевым статусом.
- --prune¶
Удаляет несуществующие миграции из таблицы django_migrations. Это полезно, когда файлы миграции, замененные сжатой миграцией, были удалены. Подробнее см. Объединение миграций.
оптимизировать миграцию¶
- django-admin optimizemigration app_label migration_name¶
Оптимизирует операции для именованной миграции и переопределяет существующий файл. Если миграция содержит функции, которые необходимо скопировать вручную, команда создает новый файл миграции с суффиксом _optimized, который предназначен для замены именованной миграции.
- --check¶
Выполняет выход optimizemigration с ненулевым статусом, когда миграцию можно оптимизировать.
runserver¶
- django-admin runserver [addrport]¶
Запускает облегченный веб-сервер разработки на локальном компьютере. По умолчанию сервер работает на порту 8000 по IP-адресу 127.0.0.1. Вы можете явно указать IP-адрес и номер порта.
Если вы запускаете команду как пользователь со стандартными правами (рекомендуется), у вас может не быть доступа к портам с малым номером. Такие порты зарезервированы для супер-пользователя (root).
Этот сервер использует объект WSGI приложения, которое указанно в настройке WSGI_APPLICATION.
Предупреждение
НЕ ИСПОЛЬЗУЙТЕ ЭТОТ СЕРВЕР В ПРОИЗВОДСТВЕННЫХ НАСТРОЙКАХ.
Этот легкий сервер разработки не прошел аудит безопасности или тестирование производительности, поэтому не подходит для производства. Обеспечение возможности работы этого сервера с производственной средой выходит за рамки Django.
Сервер для разработки автоматически перезапускается при изменении Python кода при необходимости. Нет необходимости перезапускать сервер при каждом изменении. Однако, некоторые изменения, такие как добавление файла, не вызывают перезапуск сервера, и вам необходимо сделать это самостоятельно.
Если вы используете Linux или MacOS и установили как pywatchman, так и службу Watchman, сигналы ядра будут использоваться для автоматической перезагрузки сервера (вместо опроса временных меток изменения файла каждую секунду). Это обеспечивает более высокую производительность в крупных проектах, сокращение времени отклика после изменений кода, более надежное обнаружение изменений и снижение энергопотребления. Django поддерживает pywatchman версии 1.2.0 и выше.
Большие каталоги с большим количеством файлов могут вызвать проблемы с производительностью.
При использовании Watchman с проектом, который включает в себя большие каталоги, не относящиеся к Python, такие как node_modules, рекомендуется игнорировать этот каталог для оптимальной производительности. Информацию о том, как это сделать, см. в документации сторожа.
Тайм-аут сторожа
- DJANGO_WATCHMAN_TIMEOUT¶
Тайм-аут клиента Watchman по умолчанию составляет 5 секунд. Вы можете изменить его, установив переменную среды DJANGO_WATCHMAN_TIMEOUT.
Когда вы запускаете сервер и каждый раз, когда вы меняете код Python во время работы сервера, система проверки системы проверяет весь ваш проект Django на наличие некоторых распространенных ошибок (см. команду check). Если будут обнаружены какие-либо ошибки, они будут выведены на стандартный вывод. Вы можете использовать опцию --skip-checks, чтобы пропустить выполнение системных проверок.
Вы можете запустить несколько серверов, указав разные порты. Просто запустите django-admin runserver несколько раз.
Обратите внимание, что IP-адрес по умолчанию «127.0.0.1» недоступен с других компьютеров в вашей сети. Чтобы сделать ваш сервер разработки видимым для других компьютеров в сети, используйте его собственный IP-адрес (например, 192.168.2.1), «0» (ярлык для «0.0.0.0»), «0.0.0.0» или «::» (с включенным IPv6).
Вы можете указать IPv6 адрес в квадратных скобках (например [200a::1]:8000). Это включит поддержку IPv6.
Можно использовать имя хоста, которое состоит из ASCII-символов.
Если включено приложение staticfiles (по умолчанию включено в новых проектах), команда runserver будет заменена на команду runserver этого приложения.
Протоколирование каждого запроса и ответа сервера отправляется в регистратор django-server-logger.
- --noreload¶
Опция --noreload позволяет отключить автоматическую перезагрузку сервера при изменении Python файлов.
- --nothreading¶
Отключает использование потоков на сервере разработки. По умолчанию сервер является многопоточным.
- --ipv6, -6¶
Опция --ipv6 (или короткий вариант -6) указывает Django использовать IPv6. IP адрес по умолчанию 127.0.0.1 будет заменен на ::1.
Примеры использования различных портов и адресов¶
Порт 8000 на IP-адресе 127.0.0.1:
django-admin runserver
Порт 8000 на IP-адресе 1.2.3.4:
django-admin runserver 1.2.3.4:8000
Порт 7000 на IP-адресе 127.0.0.1:
django-admin runserver 7000
Порт 7000 на IP-адресе 1.2.3.4:
django-admin runserver 1.2.3.4:7000
Порт 8000 на IPv6-адресе ::1:
django-admin runserver -6
Порт 7000 на IPv6-адресе ::1:
django-admin runserver -6 7000
Порт 7000 на IPv6-адресе 2001:0db8:1234:5678::9:
django-admin runserver [2001:0db8:1234:5678::9]:7000
Порт 8000 на IPv4-адресе хоста localhost:
django-admin runserver localhost:8000
Порт 8000 на IPv6-адресе хоста localhost:
django-admin runserver -6 localhost:8000
Раздача статических файлов сервером для разработки¶
По умолчанию сервер для разработки не раздает статические файлы (CSS файлы, изображения и другие файлы по адресу MEDIA_URL). Как настроить раздачу файлов можно узнать из раздела Как управлять статическими файлами (изображениями, скриптами JS, CSS и т.д.).
Работа с ASGI в разработке¶
Команда Django runserver предоставляет сервер WSGI. Для работы под управлением ASGI вам потребуется использовать ASGI-сервер. Проект Django Daphne предоставляет Интеграция с runserver, который вы можете использовать.
sendtestemail¶
- django-admin sendtestemail [email [email ...]]¶
Отправляет тестовое электронное письмо (чтобы подтвердить, что отправка электронного письма через Django работает) указанным получателям. Например:
django-admin sendtestemail foo@example.com bar@example.com
Вы можете использовать любую комбинацию этих опций.
- --managers¶
Опция --managers отправит электронное письмо всем, кто указан в MANAGERS, используя mail_managers().
- --admins¶
Опция --admins отправит электронное письмо всем, кто указан в ADMINS, используя mail_admins().
shell¶
- django-admin shell¶
Запускает интерактивный интерпретатор Python.
- --interface {ipython,bpython,python}, -i {ipython,bpython,python}¶
Django использует IPython или bpython, если они установлены. Если вы хотите использовать «обычный» интерпретатор Python, укажите опцию --plain:
IPython:
django-admin shell -i ipython
бпитон:
django-admin shell -i bpython
Если у вас установлена «насыщенная» оболочка, но вы хотите принудительно использовать «простой» интерпретатор Python, используйте python в качестве имени интерфейса, например:
django-admin shell -i python
- --no-startup¶
Отключает чтение сценария запуска для «простого» интерпретатора Python. По умолчанию считывается сценарий, на который указывает переменная среды PYTHONSTARTUP, или скрипт ~/.pythonrc.py.
- --command COMMAND, -c COMMAND¶
Позволяет передать команду в виде строки для ее выполнения как Django, например:
django-admin shell --command="import django; print(django.__version__)"
Вы также можете передать код на стандартный ввод для его выполнения. Например:
$ django-admin shell <<EOF
> import django
> print(django.__version__)
> EOF
В Windows REPL выводится из-за ограничений реализации select.select() на этой платформе.
**options¶
- django-admin showmigrations [app_label [app_label ...]]¶
Показывает все миграции в проекте.
- --list, -l¶
Опция --list выведет все активированные приложения в проекте, список доступных миграций и пометки были ли они выполнены (знак [X] возле названия миграции).
Приложения без миграций также будут указаны, но с пометкой (no migrations).
Это формат вывода по умолчанию.
- --plan, -p¶
Опция --plan показывает план выполнения миграций, которому будет следовать Django для выполнения всех миграций. Указанные приложения игнорируются т.к. план выполнения миграций может содержать миграций из разных приложений. Как и для --list, выполненные миграции помечены [X]. При --verbosity 2 и выше будут выведены все зависимости миграции.
Аргументы app_label ограничивают вывод, однако также могут быть включены зависимости предоставленных приложений.
- --database DATABASE¶
Указывает базу данных для проверки. По умолчанию установлено default.
sqlflush¶
- django-admin sqlflush¶
Выводить в консоль SQL запросы, которые будут выполнены при выполнении команды flush.
- --database DATABASE¶
Указывает базу данных, для которой необходимо распечатать SQL. По умолчанию установлено default.
white¶
- django-admin sqlmigrate app_label migration_name¶
Выводит в консоль SQL запросы для указанной миграции. Требует активного подключения к базе данных, чтобы определить доступны имена constraint(FIXME). Это значит, что вы должны создать SQL для копии базы данных, к которой будут применяться запросы.
Обратите внимание, sqlmigrate не использует цветной вывод в консоль.
- --backwards¶
Генерирует SQL для отмены миграции. По умолчанию созданный SQL предназначен для запуска миграции в прямом направлении.
- --database DATABASE¶
Указывает базу данных, для которой создается SQL. По умолчанию установлено default.
sqlsequencereset¶
- django-admin sqlsequencereset app_label [app_label ...]¶
Выводит в консоль SQL запросы для сброса счетчика автоинкрементных полей.
Эти счетчики используются для определения следующего доступного номера.
Вы можете использовать эту команду для генерации SQL запросов, которые помогут исправить несоответствие счетчиков и существующих данных в автоинкрементных полях.
- --database DATABASE¶
Указывает базу данных, для которой необходимо распечатать SQL. По умолчанию установлено default.
сквошмиграции¶
- django-admin squashmigrations app_label [start_migration_name] migration_name¶
Объединяет миграции, если это возможно, для приложения app_label от начальной и до migration_name, включая её. Полученные объединенные миграции могут существовать параллельно с начальными. Подробности смотрите в разделе Объединение миграций.
Если передать start_migration_name, Django будет учитывать только миграции, начиная с указанной. Это позволяет обойти проблемы с RunPython и django.db.migrations.operations.RunSQL.
- --no-optimize¶
По умолчанию Django пытается оптимизировать операции в миграциях, чтобы уменьшить размер файла. Опция --no-optimize позволяет отключить такое поведение, если оптимизация привела к созданию неправильной миграции, или ошибке при выполнении команды. Также мы просим сообщить об этом в баг-трекере Django.
- --noinput, --no-input¶
Подавляет все запросы пользователя.
- --squashed-name SQUASHED_NAME¶
Устанавливает имя сжатой миграции. Если этот параметр опущен, имя основано на первой и последней миграции с _squashed_ между ними.
- --no-header¶
Создайте сжатый файл миграции без версии Django и заголовка временной метки.
стартап¶
- django-admin startapp name [directory]¶
Создает структуру каталога приложения Django с указанным названием в текущем каталоге, или в котором вы укажите.
По умолчанию созданный каталог содержит файл models.py и другие файлы шаблона приложения. (Смотрите исходный код). Если вы указали только название приложения, оно будет создано в текущем каталоге.
Если вы указали путь к каталогу, Django будет использовать его, вместо создания нового. Вы можете использовать „.“, чтобы указать текущий каталог.
Например:
django-admin startapp myapp /Users/jezdez/Code/myapp
- --template TEMPLATE¶
Опция --template позволяет указать путь к своему шаблону приложения. Вы можете указать путь к каталогу или архиву (.tar.gz, .tar.bz2, .tgz, .tbz, .zip), который содержит файлы шаблона приложения.
Например, это будет искать шаблон приложения в заданном каталоге при создании приложения myapp:
django-admin startapp --template=/Users/jezdez/Code/my_app_template myapp
Django также позволяет указать URL (http, https, ftp) к архиву с шаблоном приложения, он будет автоматически загружен и распакован.
Например, воспользовавшись функцией GitHub для предоставления репозиториев в виде zip-файлов, вы можете использовать такой URL-адрес:
django-admin startapp --template=https://github.com/githubuser/django-app-template/archive/main.zip myapp
- --extension EXTENSIONS, -e EXTENSIONS¶
Указывает, какие расширения файлов в шаблоне приложения должны отображаться с помощью механизма шаблонов. По умолчанию py.
- --name FILES, -n FILES¶
Указывает, какие файлы в шаблоне приложения (помимо тех, которые соответствуют --extension) должны отображаться с помощью механизма шаблонов. По умолчанию пустой список.
- --exclude DIRECTORIES, -x DIRECTORIES¶
Указывает, какие каталоги в шаблоне приложения следует исключить, помимо .git и __pycache__. Если эта опция не указана, каталоги с именем __pycache__ или начинающиеся с . будут исключены.
Контекст шаблона <django.template.Context>`, используемый для всех соответствующих файлов:
Все опции, переданные при вызове команды
startapp(только поддерживаемые этой командой)app_name– название приложение, указанное при вызове командыapp_directory– полный путь к созданному приложениюcamel_case_app_name– название приложение в «camel case» форматеdocs_version– версия документации:'dev'или'1.x'docs_version– версия документации:'dev'или'1.x'
Предупреждение
При рендеринге файлов шаблона приложения (по умолчанию все *.py файлы) Django заменит все шаблонные переменные. Например, если какой-то Python файл содержит комментарий, описывающий примеры использования системы шаблонов Django, он может быть искажен в созданном приложении.
Чтобы избежать этого, используйте тег templatetag для «экранирования» синтаксиса шаблонов.
Кроме того, чтобы разрешить использование файлов шаблонов Python, содержащих синтаксис языка шаблонов Django, а также предотвратить попытки систем упаковки побайтно-компилировать недопустимые файлы *.py, файлы шаблонов, заканчивающиеся на .py-tpl, будут переименованы в .py.
Предупреждение
Содержимое пользовательских шаблонов приложений (или проектов) всегда должно проверяться перед использованием: такие шаблоны определяют код, который станет частью вашего проекта, а это означает, что такому коду будут доверять так же, как любому приложению, которое вы устанавливаете, или коду, который вы пишете самостоятельно. Более того, даже отрисовка шаблонов фактически является выполнением кода, который был предоставлен в качестве входных данных для команды управления. Язык шаблонов Django может обеспечить широкий доступ к системе, поэтому убедитесь, что любой используемый вами собственный шаблон заслуживает вашего доверия.
стартпроект¶
- django-admin startproject name [directory]¶
Создает структуру каталога проета Django с указанным названием в текущем каталоге, или в котором вы укажите.
По умолчанию новый каталог содержит manage.py и пакет проекта (содержащий settings.py и другие файлы). Подробности смотрите в исходниках.
Если указано только название проекта, и каталог и Python пакет проекта будет называться <projectname>, и будут созданы в текущем каталоге.
Если указать необязательный путь к каталогу, Django будет использовать его как каталог проекта, создаст в нём manage.py и пакет проекта. Можно использовать „.“, чтобы указать текущий каталог.
Например:
django-admin startproject myproject /Users/jezdez/Code/myproject_repo
- --template TEMPLATE¶
Как и для команды startapp, опция --template позволяет указать путь или URL к шаблону проекта. Подробности смотрите в описании startapp.
- --extension EXTENSIONS, -e EXTENSIONS¶
Указывает, какие расширения файлов в шаблоне проекта должны отображаться с помощью механизма шаблонов. По умолчанию py.
- --name FILES, -n FILES¶
Указывает, какие файлы в шаблоне проекта (помимо тех, которые соответствуют --extension) должны отображаться с помощью механизма шаблонов. По умолчанию пустой список.
- --exclude DIRECTORIES, -x DIRECTORIES¶
Указывает, какие каталоги из шаблона проекта следует исключить, помимо .git и __pycache__. Если эта опция не указана, каталоги с именем __pycache__ или начинающиеся с . будут исключены.
Используемый контекст шаблона:
Все опции, переданные при вызове команды
startproject(только поддерживаемые этой командой)project_name– название проекта, указанное при вызове командыproject_directory– полный путь к созданному проектуsecret_key– случайный ключ для настройкиSECRET_KEYdocs_version– версия документации:'dev'или'1.x'docs_version– версия документации:'dev'или'1.x'
Также ознакомьтесь с предупреждением о рендеринге и предупреждением о доверенном коде, как указано для startapp.
тест¶
- django-admin test [test_label [test_label ...]]¶
Выполняет тесты для всех установленных моделей(FIXME: models?). Смотрите Тестирование в Django.
- --failfast¶
Опция --failfast позволяет остановить выполнение тестов после первой ошибки.
- --testrunner TESTRUNNER¶
Опция --testrunner позволяет указать класс исполнителя тестов, который будет использоваться для запуска тестов. Указанное значение переопределяет значение настройки TEST_RUNNER.
- --noinput, --no-input¶
Подавляет все запросы пользователя. Типичным приглашением является предупреждение об удалении существующей тестовой базы данных.
runfcgi [options]¶
Команда test получает параметры от имени указанного --testrunner. Это параметры запуска тестов по умолчанию: DiscoverRunner.
- --keepdb¶
Сохраняет тестовую базу данных между запусками тестов. Преимущество этого подхода заключается в пропуске действий создания и уничтожения, что может значительно сократить время выполнения тестов, особенно в большом наборе тестов. Если тестовая база данных не существует, она будет создана при первом запуске и затем сохранится для каждого последующего запуска. Если параметр теста MIGRATE не имеет значения False, любые непримененные миграции также будут применены к тестовой базе данных перед запуском набора тестов.
- --shuffle [SEED]¶
Рандомизирует порядок тестов перед их запуском. Это может помочь обнаружить тесты, которые не изолированы должным образом. Порядок тестирования, создаваемый этой опцией, является детерминированной функцией заданного целочисленного начального числа. Если начальное число не передается, оно выбирается случайным образом и выводится на консоль. Чтобы повторить определенный тестовый заказ, передайте начальное число. Тестовые заказы, созданные с помощью этой опции, сохраняют гарантии Django на тестовый заказ. Они также группируют тесты по классам тестовых примеров.
Перетасованный порядок также обладает особым свойством согласованности, полезным при решении проблем изоляции. А именно, для данного начального числа и при выполнении подмножества тестов новым порядком будет исходная перетасовка, ограниченная меньшим набором. Аналогично, при добавлении тестов с сохранением начального числа порядок исходных тестов будет таким же в новом порядке.
- --reverse, -r¶
Сортирует тестовые примеры в противоположном порядке выполнения. Это может помочь в отладке побочных эффектов тестов, которые не изолированы должным образом. Группировка по тестовому классу сохраняется при использовании этой опции. Это можно использовать в сочетании с –shuffle, чтобы изменить порядок для определенного начального числа.
- --debug-mode¶
Устанавливает для параметра DEBUG значение True перед запуском тестов. Это может помочь устранить сбои при тестировании.
- --debug-sql, -d¶
Опция --debug-sql позволяет включить логгирование SQL для «упавших» тестов. Если :djadminopt:`--verbosity` выше 2, будет логгированы запросы и успешно выполненных тестов.
- --parallel [N]¶
- DJANGO_TEST_PROCESSES¶
Опция --parallel позволяет запустить тесты параллельно в нескольких процессах. Т.к. современные процессоры состоят из нескольких ядер, это позволяет выполнять тесты значительно быстрее.
Использование --parallel без значения или со значением auto запускает один тестовый процесс для каждого ядра в соответствии с multiprocessing.cpu_count(). Вы можете переопределить это, передав желаемое количество процессов, например. --parallel 4 или установив переменную среды DJANGO_TEST_PROCESSES.
Django распределяет тестовые примеры (подклассы unittest.TestCase) по подпроцессам. Если классов тестовых примеров меньше, чем настроенных процессов, Django соответственно уменьшит количество процессов.
Каждый процесс получает свою собственную базу данных. Вы должны гарантировать, что разные классы тестовых примеров не имеют доступа к одним и тем же ресурсам. Например, классы тестовых сценариев, которые затрагивают файловую систему, должны создать временный каталог для собственного использования.
Примечание
Если у вас есть тестовые классы, которые нельзя запускать параллельно, вы можете использовать SerializeMixin для их последовательного запуска. См. Обеспечить последовательный запуск тестовых классов.
Эта опция требует установить пакет tblib, чтобы правильно показывать трейсбек:
$ python -m pip install tblib
Этот функционал не работает на Windows. Также не работает с Oracle.
Если вы используете pdb при отладке тестов, необходимо отключить параллельное выполнение (--parallel=1). Вы увидите приблизительно следующее bdb.BdbQuit, если не сделаете этого?.
Предупреждение
Когда тесты выполняются параллельно, могут быть проблемы при отображении тресбека для теста с ошибкой. Это затрудняет отладку тестов. В таком случае выполните этот тест в одном потоке.
Это известное ограничение. Вызвано необходимостью сериализировать объекты для передачи между процессами. Подробности смотрите в python:pickle-picklable.
- --tag TAGS¶
Запускает только тесты, помеченные указанными тегами <topics-tagged-tests>. Может быть указано несколько раз и объединено с test --exclude-tag.
Тесты, которые не загружаются, всегда считаются совпадающими.
- --exclude-tag EXCLUDE_TAGS¶
Исключает тесты, отмеченные указанными тегами <topics-tagged-tests>. Может быть указано несколько раз и объединено с test --tag.
- -k TEST_NAME_PATTERNS¶
Запускает тестовые методы и классы, соответствующие шаблонам имен тестов, так же, как unittest's -k option. Можно указать несколько раз.
- --pdb¶
Запускает отладчик pdb при каждой ошибке или сбое теста. Если он у вас установлен, вместо него используется ipdb.
- --buffer, -b¶
Отменяет вывод (stdout и stderr) для прохождения тестов, так же, как unittest --buffer option.
- --no-faulthandler¶
Django автоматически вызывает faulthandler.enable() при запуске тестов, что позволяет ему распечатать обратную трассировку в случае сбоя интерпретатора. Передайте --no-faulthandler, чтобы отключить это поведение.
- --timing¶
Выводит время, включая настройку базы данных и общее время выполнения.
- --durations N¶
Показывает N самых медленных тестовых случаев (N=0 для всех).
Python 3.12 и более поздние версии
Эта функция доступна только для Python 3.12 и более поздних версий.
тестовый сервер¶
- django-admin testserver [fixture [fixture ...]]¶
Запускает сервер Django для разработки (как и runserver), используя данные из указанных фикстур.
Например, эта команда:
django-admin testserver mydata.json
…выполнит следующее:
Создаст тестовую базу данных, как описано вы Тестовая база данных.
Добавит в нее данных из указанных фикстур. (Подробности о фикстурах смотрите в описании
loaddata.)Запускает сервер Django для разработки (как и
runserver), сервер будет использовать созданную тестовую базу данных.
Эта команда может быть полезна в следующих случаях:
Когда вы пишете юнит-тесты того, как ваши представления действуют с определенными данными о приборах, вы можете использовать
testserverдля взаимодействия с представлениями в веб-браузере вручную.Допустим, вы разрабатываете приложение Django и у вас есть «чистая» копия базы данных, с которой вы хотите взаимодействовать. Вы можете сбросить свою базу данных в fixture (используя команду
dumpdata, описанную выше), а затем использоватьtestserverдля запуска вашего веб-приложения с этими данными. Благодаря такому расположению у вас есть возможность испортить ваши данные любым способом, зная, что любые изменения данных, которые вы вносите, вносятся только в тестовую базу данных.
Обратите внимание, этот сервер не определяет изменения в Python файлах (как это делает команда runserver). Однако, он отслеживает изменения в шаблонах.
- --addrport ADDRPORT¶
Опция --addrport позволяет указать порт, или IP и порт, переопределив значение по умолчанию 127.0.0.1:8000. Формат значение аналогичен runserver.
Например:
Чтобы запустить тестовый сервер на порту 7000 с fixture1 и fixture2:
django-admin testserver --addrport 7000 fixture1 fixture2
django-admin testserver fixture1 fixture2 --addrport 7000
(Эти команды идентичны. Мы указали обе, чтобы показать, что порядок аргументов и опций не важен.)
Для запуска на 1.2.3.4:7000 с тестовым приспособлением:
django-admin testserver --addrport 1.2.3.4:7000 test
- --noinput, --no-input¶
Подавляет все запросы пользователя. Типичным приглашением является предупреждение об удалении существующей тестовой базы данных.
Команды предоставленные приложениями¶
Некоторые команды доступны только в случае, если приложение django.contrib, которое реализует их, было установлено. Этот раздел описывает эти команды, сгруппированные по приложениям.
django.contrib.auth¶
changepassword¶
- django-admin changepassword [<username>]¶
Эта команда работает только, если установлена система авторизации (django.contrib.auth).
Позволяет изменить пароль пользователя. Требует дважды ввести новый пароль для указанного пользователя. Если введённые пароли совпадают, новый пароль будет установлен. Если вы не указали пользователя, команда попытается найти пользователя с именем аналогичным текущему пользователю системы и поменять ему пароль.
- --database DATABASE¶
Указывает базу данных для запроса пользователя. По умолчанию установлено default.
Пример использования:
django-admin changepassword ringo
createsuperuser¶
- django-admin createsuperuser¶
- DJANGO_SUPERUSER_PASSWORD¶
Эта команда работает только, если установлена система авторизации (django.contrib.auth).
Создает суперпользователя (пользователь со всеми правами). Можно использовать для создания самого первого суперпользователя, или чтобы программно создавать суперпользователей.
При интерактивном запуске эта команда запросит пароль для новой учетной записи суперпользователя. При неинтерактивном запуске вы можете указать пароль, установив переменную среды DJANGO_SUPERUSER_PASSWORD. В противном случае пароль не будет установлен, и учетная запись суперпользователя не сможет войти в систему, пока для нее не будет установлен пароль вручную.
В неинтерактивном режиме USERNAME_FIELD и обязательные поля (перечисленные в REQUIRED_FIELDS) возвращаются к среде DJANGO_SUPERUSER_<uppercase_field_name>. переменные, если они не переопределены аргументом командной строки. Например, чтобы предоставить поле электронной почты, вы можете использовать переменную среды DJANGO_SUPERUSER_EMAIL.
- --noinput, --no-input¶
Опция --noinput позволяет выполнить команду без запроса на любые действия от пользователя. Если команда не может выполнится автоматически, она завершиться с кодом ошибки 3.
- --username USERNAME¶
- --email EMAIL¶
Вы можете указать имя пользователя и email с помощью опций --username и --email. Если одна из опций не указана, createsuperuser попросит ввести значение, при запуске команды через консоль.
- --database DATABASE¶
Опция --database позволяет указать базу данных, в которой будет создан новый пользователь.
Вы можете унаследоваться от команды и переопределить get_input_data(), если вы хотите настроить данные для ввода и их проверку. Детали реализации и параметры вы можете найти в исходном коде. Например, это может пригодиться, если у вас есть ForeignKey в REQUIRED_FIELDS и вы хотите создавать экземпляр вместо того, чтобы указывать первичный ключ существующего связанного объекта.
django.contrib.sitemaps¶
remove_stale_contenttypes¶
- django-admin remove_stale_contenttypes¶
Эта команда доступна, если установлен Sitemap приложение (django.contrib.sitemaps).
Удаляет устаревшие типы контента (из удаленных моделей) в вашей базе данных. Любые объекты, зависящие от удаленных типов контента, также будут удалены. Список удаленных объектов будет отображен, прежде чем вы подтвердите, что можно продолжить удаление.
- --database DATABASE¶
Указывает базу данных, которую следует использовать. По умолчанию установлено default.
- --include-stale-apps¶
Удаляет устаревшие типы контента, в том числе из ранее установленных приложений, которые были удалены из INSTALLED_APPS. По умолчанию установлено значение «False».
django.contrib.gis¶
ogrinspect¶
Эта команда доступна только при установленном GeoDjango (django.contrib.gis).
Подробности смотрите в документации GeoDjango.
django.contrib.sessions¶
clearsessions¶
- django-admin clearsessions¶
Может запускаться в кроне или из консоли, чтобы удалить устаревшие данные сессий.
django.contrib.staticfiles¶
collectstatic¶
Команда доступна, если установлено приложение для работы со статикой (django.contrib.staticfiles).
Смотрите описание команды в разделе staticfiles.
findstatic¶
Команда доступна, если установлено приложение для работы со статикой (django.contrib.staticfiles).
Смотрите описание команды в разделе staticfiles.
Опции по умолчанию¶
Хотя некоторые команды могут иметь свои собственные параметры, каждая команда по умолчанию допускает следующие параметры:
- --pythonpath PYTHONPATH¶
Добавляет заданный путь файловой системы к атрибуту модуля Python sys.path. Если это не предусмотрено, django-admin будет использовать переменную среды PYTHONPATH.
Обратите внимание, эта опция не обязательна при использовании manage.py, т.к. он сам устанавливает необходимые пути поиска Python.
Пример использования:
django-admin migrate --pythonpath='/home/djangoprojects/myproject'
- --settings SETTINGS¶
Указывает модуль настроек, который будет использоваться. Модуль настроек должен иметь синтаксис пакета Python, например mysite.settings. Если это не указано, django-admin будет использовать переменную среды DJANGO_SETTINGS_MODULE.
Обратите внимание, эта опция не обязательна при использовании manage.py, т.к. он использует settings.py текущего проекта.
Пример использования:
django-admin migrate --settings=mysite.settings
- --traceback¶
Отображает полную трассировку стека при возникновении ошибки CommandError. По умолчанию django-admin отображает сообщение об ошибке при возникновении CommandError и полную трассировку стека для любого другого исключения.
Эта опция игнорируется runserver.
Пример использования:
django-admin migrate --traceback
- --verbosity {0,1,2,3}, -v {0,1,2,3}¶
Опция --verbosity позволяет указать уровень вывода в консоль сообщений и отладочной информации для django-admin.
0– ничего не выводить.1– обычный вывод (по умолчанию).2– подробный вывод.3– очень подробный вывод.
Эта опция игнорируется runserver.
Пример использования:
django-admin migrate --verbosity 2
- --no-color¶
По умолчанию django-admin использует цвета для форматирования вывода. Например, ошибки выводятся красным, а для SQL запросов используется подсветка синтаксиса. Чтобы отключить цветной вывод, используйте опцию --no-color.
Пример использования:
django-admin runserver --no-color
- --force-color¶
Принудительно раскрашивает вывод команды, если в противном случае он был бы отключен, как описано в Подсветка синтаксиса. Например, вы можете захотеть передать цветной вывод в другую команду.
- --skip-checks¶
Пропускает проверку системы перед запуском команды. Эта опция доступна только в том случае, если атрибут команды requires_system_checks не является пустым списком или кортежем.
Пример использования:
django-admin migrate --skip-checks
Дополнительные возможности¶
Подсветка синтаксиса¶
- DJANGO_COLORS¶
Команды django-admin / manage.py использует цветной вывод, если терминал поддерживает ANSI-цветной вывод. Если вывод передается в другую команду через «pipe»(|), цветной выводе не будет использоваться.
Поддержка Windows¶
В Windows 10 приложения Windows Terminal, VS Code и PowerShell (где включена обработка виртуального терминала) допускают цветной вывод и поддерживаются по умолчанию.
В Windows устаревшая собственная консоль cmd.exe не поддерживает escape-последовательности ANSI, поэтому по умолчанию цветной вывод отсутствует. В этом случае необходима одна из двух сторонних библиотек:
Установите colorama, пакет Python, который преобразует цветовые коды ANSI в вызовы Windows API. Команды Django обнаружат его присутствие и будут использовать его сервисы для цветного вывода, как на платформах на базе Unix.
coloramaможно установить через pip:...\> py -m pip install "colorama >= 0.4.6"
Установите ANSICON, сторонний инструмент, который позволяет cmd.exe обрабатывать цветовые коды ANSI. Команды Django обнаружат его присутствие и будут использовать его сервисы для цветного вывода, как на платформах на базе Unix.
Другие современные терминальные среды в Windows, которые поддерживают цвета терминала, но которые не определяются автоматически как поддерживаемые Django, могут «фальсифицировать» установку ANSICON, устанавливая соответствующую переменную среды ANSICON=»on»``.
Пользовательские цвета¶
Вы можете настроить цвета для подсветки синтаксиса. Django предоставляет цветовых темы:
dark, удобна для терминалов, которые выводят белый текст на черном фоне. Используется по умолчанию.light, для терминалов, которые выводят черный текст на белом фоне.nocolor, отключает подсветку синтаксиса.
Вы выбираете палитру, устанавливая переменную среды DJANGO_COLORS, чтобы указать палитру, которую вы хотите использовать. Например, чтобы указать палитру light в оболочке BASH Unix или OS/X, вам нужно запустить в командной строке следующую команду:
export DJANGO_COLORS="light"
Вы можете указать какие цвета использовать. Django предоставляет несколько типов сообщений, для которых можно указать цвет:
error- Важная ошибка.notice- Незначительная ошибка.success- Без ошибок.warning- Предупреждение.sql_field- Название поля модели в SQL.sql_coltype- Тип поля модели в SQL.sql_keyword- Ключевые слова SQL.sql_table- Название модели в SQL.http_info- 1XX HTTP Informational ответ сервера.http_success- 2XX HTTP Success ответ сервера.http_not_modified- 304 HTTP Not Modified ответ сервера.http_redirect- 3XX HTTP Redirect ответ сервера, исключая 304.http_not_found- 404 HTTP Not Found ответ сервера.http_bad_request- 4XX HTTP Bad Request ответ сервера, исключая 404.http_server_error- 5XX HTTP Server Error ответ сервера.migrate_heading- Заголовок в команде миграции.migrate_label- Название миграции.
Для каждого сообщения можно указать цвет текста и фона. Доступные цвета:
blackredgreenyellowbluemagentacyanwhite
Можно указать дополнительно следующие параметры:
boldunderscoreblinkreverseconceal
Цвета можно указать в следующем формате:
role=fgrole=fg/bgrole=fg,option,optionrole=fg/bg,option,option
где role — это имя допустимой цветовой роли, fg — это цвет переднего плана, bg — это цвет фона, а каждая опция — это один из вариантов изменения цвета. Затем несколько спецификаций цвета разделяются точкой с запятой. Например:
export DJANGO_COLORS="error=yellow/blue,blink;notice=magenta"
укажет показывать ошибки мигающим желтым на синем фоне, а уведомления будут пурпурными. Все остальные сообщения будут бесцветные.
Цвета также можно указать, расширив базовую палитру. Если вы поместите имя палитры в спецификацию цвета, будут загружены все цвета, подразумеваемые этой палитрой. Так:
export DJANGO_COLORS="light;error=yellow/blue,blink;notice=magenta"
укажет использовать цветы из light темы, кроме сообщений об ошибках и уведомлениях, для которых мы явно указали настройки.
Автодополнение в Bash¶
Если вы используете оболочку Bash, рассмотрите возможность установки сценария завершения Django bash, который находится в extras/django_bash_completion в дистрибутиве исходного кода Django. Он позволяет заполнять команды django-admin и manage.py с помощью табуляции, так что вы можете, например…
Введите
django-admin.Нажать [TAB], чтобы увидеть все доступные команды.
Ввести
sql, затем [TAB], чтобы увидеть все доступные команды, название которых начинается наsql.
Смотрите Реализация собственных команд django-admin о том, как добавить свои команды.
Черное форматирование¶
Файлы Python, созданные startproject, startapp, optimizemigration, makemigrations и squashmigrations, форматируются с использованием команды black, если она присутствует в вашем PATH.
Если у вас глобально установлен black, но вы не хотите, чтобы он использовался в текущем проекте, вы можете явно указать PATH:
PATH=path/to/venv/bin django-admin makemigrations
Для команд, использующих stdout, вы можете передать вывод в black, если необходимо:
django-admin inspectdb | black -
Выполнение команд в коде¶
- django.core.management.call_command(name, *args, **options)¶
Чтобы вызвать команду управления из кода, используйте call_command().
nameимя вызываемой команды или объект команды. Передача имени предпочтительна, если только объект не требуется для тестирования.
*argsсписок аргументов, принимаемых командой. Аргументы передаются в анализатор аргументов, поэтому вы можете использовать тот же стиль, что и в командной строке. Например,
call_command('flush', '--verbosity=0').**optionsименованные параметры, принимаемые в командной строке. Параметры передаются команде без запуска анализатора аргументов, а это значит, что вам нужно будет передать правильный тип. Например,
call_command('flush', verbosity=0)(ноль должен быть целым числом, а не строкой).
Например:
from django.core import management
from django.core.management.commands import loaddata
management.call_command("flush", verbosity=0, interactive=False)
management.call_command("loaddata", "test_data", verbosity=0)
management.call_command(loaddata.Command(), "test_data", verbosity=0)
Обратите внимание, опции, которые не принимают аргументы, указываются как именованные аргументы функции с True или False. Вы можете найти пример в описании опции interactive выше.
Именованные аргументы могут переданы один из следующих способов:
# Similar to the command line
management.call_command("dumpdata", "--natural-foreign")
# Named argument similar to the command line minus the initial dashes and
# with internal dashes replaced by underscores
management.call_command("dumpdata", natural_foreign=True)
# `use_natural_foreign_keys` is the option destination variable
management.call_command("dumpdata", use_natural_foreign_keys=True)
Некоторые параметры команды имеют разные имена при использовании call_command() вместо django-admin или manage.py. Например, django-admin createuperuser --no-input переводится как call_command('createsuperuser',interactive=False). Чтобы узнать, какое имя аргумента ключевого слова использовать для call_command(), проверьте исходный код команды на наличие аргумента dest, переданного в parser.add_argument().
Опции, которые принимают несколько значений, передаются через список:
management.call_command("dumpdata", exclude=["contenttypes", "auth"])
Возвращаемое значение функции call_command() такое же, как возвращаемое значение метода handle() этой команды.
Перенаправление вывода¶
Обратите внимание, вы можете перенаправить вывод команды т.к. все команды поддерживают опции stdout и stderr. Например:
with open("/path/to/command_output", "w") as f:
management.call_command("dumpdata", stdout=f)