Django вызывает несколько собственных исключений на ряду со стандартными исключениями Python.
Основные исключения Django определены в django.core.exceptions.
Основной класс DoesNotExist. try/except для ObjectDoesNotExist словит исключения DoesNotExist для всех моделей.
Смотрите get() для подробной информации об исключениях ObjectDoesNotExist и DoesNotExist.
Исключение FieldDoesNotExist вызывается методом _meta.get_field() модели, если запрошенное поле не найдено в модели или в предках модели.
Ранее это исключение было определено в django.db.models.fields и не было частью публичного API.
Исключение MultipleObjectsReturned вызывается запросом при получении нескольких объектов в случае, когда ожидался один объект. Базовая версия этого исключения предоставляется модулем django.core.exceptions; каждый класс модели содержит версию подкласса, которая может использоваться для идентификации особого объектного типа, который возвратил коллекцию объектов.
См. get() для подробной информации.
Исключение SuspiciousOperation вызывается когда пользователь выполнил операцию, которая должна быть рассмотрена как подозрительная с точки зрения безопасности, например, при подмене куки сессии. Подклассы SuspiciousOperation:
Исключение SuspiciousOperation на уровне WSGI обработчика будет логгировано как ошибка и будет возвращен HttpResponseBadRequest. Подробности смотрите в разделе о логгировании.
Исключение PermissionDenied вызывается если пользователь не имеет права на выполнение запрошенного действия.
Исключение ViewDoesNotExist вызывается модулем django.core.urlresolvers, если запрошенное представление на найдено.
Исключение MiddlewareNotUsed вызывается, если мидлвар не используется в конфигурации сервера.
Исключение ImproperlyConfigured вызывается, если Django неправильно сконфигурировано. Например, если значение в settings.py неправильное.
Исключение FieldError вызывается, если существует проблема с полем модели. Такое может произойти по следующим причинам:
Поле в модели конфликтует с полем абстрактного класса, которое имеет такое же имя.
Бесконечный цикл, вызванный сортировкой.
Аргумент не может быть получен из параметров фильтра.
Поле не может быть определено из аргумента в параметрах запроса.
Объединение не разрешено для указанного поля.
Имя поля неверное.
Запрос состоит из неверного порядка аргументов.
Исключение ValidationError вызывается, если происходит ошибка проверки данных от формы или модели. Для подробностей о проверке данных, см. Проверка форм и полей, Проверка поля модели и the Справочник проверки.
Ошибки определения URL определены в django.core.urlresolvers.
Исключение Resolver404 вызывается в django.core.urlresolvers.resolve(), если путь переданный в resolve() не соответствует ни одному представлению. Подкласс django.http.Http404.
Исключение NoReverseMatch вызывается модулем django.core.urlresolvers, если не получилось найти соответствующий URL по переданным параметрам.
Ошибки базы данных определены в django.db.
Django оборачивает стандартные исключения базы данных таким образом, что код Django гарантирует стандартную реализацию этих классов.
Обёртка Django для исключений базы данных ведёт себя аналогично обёртываемым исключениям. См. PEP 249, вторую версию Python Database API Specification, для подробностей.
В соответствии с PEP 3134, атрибут __cause__ содержит изначальное исключение базы данных, предоставляя доступ к дополнительной информации. (Этот атрибут доступен для Python 2 и Python 3, хотя PEP 3134 создавался для Python 3.)
Выбрасывается для предотвращения удаления связанных объектов при использовании django.db.models.PROTECT. models.ProtectedError`является дочерним классом :exc:`IntegrityError.
Ошибки HTTP определенны в django.http.
Ошибки транзакции определены в django.db.transaction.
Ошибки HTTP определенны в django.test.
Исключение RedirectCycleError вызывается, если тестовый клиент определил циклическое перенаправление или очень длинную цепочку перенаправлений.
Django вызывает встроенные исключения Python когда это требуется. Обратитесь к документации Python для получения более подробной информации Built-in Exceptions.
Mar 31, 2016