django MultiValueDictKeyError ошибка, как мне с ней справиться

133

Я пытаюсь сохранить объект в моей базе данных, но он MultiValueDictKeyError ошибку MultiValueDictKeyError.

Проблемы лежат в форме, is_private представлен is_private. Если флажок НЕ установлен, очевидно, ничего не пропущено. Это где ошибка забрасывается.

Как мне правильно разобраться с этим исключением и поймать его?

Линия

is_private = request.POST['is_private']
  • 1
    Хорошей идеей было бы показать нам всю ошибку и след. Также покажите нам больше той части кода, где возникает ошибка.
  • 1
    Может кто-нибудь объяснить, почему происходит эта ошибка? Я видел эту ошибку, когда я использую другой Modelviewset в django rest .....
Показать ещё 1 комментарий
Теги:
exception

8 ответов

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

Используйте метод MultiValueDict get. Это также присутствует в стандартных dicts и является способом получения значения при предоставлении значения по умолчанию, если оно не существует.

is_private = request.POST.get('is_private', False)

Вообще,

my_var = dict.get(<key>, <default>)
  • 1
    Это дает мне значение None, но я отправляю значение на POST: /
  • 0
    Это правильное поведение .. флажок отправить checked , когда проверяется , но отправит null , если не проверяется. Вы можете проверить это на панели «Сеть» инструмента DEV Chrome / Firefox. Вот почему вы устанавливаете False в качестве значения по умолчанию: если значение равно null , установите значение false .
60

Выберите лучшее для вас:

1

is_private = request.POST.get('is_private', False);

Если в запросе присутствует ключ is_private. POST, переменная is_private будет равна ей, если нет, то она будет равна False.

2

if 'is_private' in request.POST:
    is_private = request.POST['is_private']
else:
    is_private = False

3

from django.utils.datastructures import MultiValueDictKeyError
try:
    is_private = request.POST['is_private']
except MultiValueDictKeyError:
    is_private = False
  • 12
    На самом деле не могу рекомендовать номер 3.
  • 0
    @ Джо, а почему бы и нет? Помедленнее?
Показать ещё 6 комментариев
10

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

попробовать:

is_private = 'is_private' in request.POST

или

is_private = 'is_private' in request.POST and request.POST['is_private']

в зависимости от используемых вами значений.

5

Почему вы не пытались определить is_private в своих моделях как default=False?

class Foo(models.Models):
    is_private = models.BooleanField(default=False)
  • 1
    Это не предотвратило бы ошибку, которую он получает, проверяя POST вручную для значения.
2

Следует также помнить, что request.POST['keyword'] ссылается на элемент, идентифицируемый указанным keyword атрибута html name.

Итак, если ваша форма:

<form action="/login/" method="POST">
  <input type="text" name="keyword" placeholder="Search query">
  <input type="number" name="results" placeholder="Number of results">
</form>

тогда request.POST['keyword'] и request.POST['results'] будут содержать значение keyword input и results соответственно.

0

Для меня эта ошибка произошла в моем проекте django из-за следующего:

  1. Я вставил новую гиперссылку в свой home.html подарок в папке шаблонов моего проекта, как показано ниже:

    <input type="button" value="About" onclick="location.href='{% url 'about' %}'">
    1. В views.py у меня были следующие определения count и about:

    def count(request): fulltext = request.GET['fulltext'] wordlist = fulltext.split() worddict = {} for word in wordlist: if word in worddict: worddict[word] += 1 else: worddict[word] = 1 worddict = sorted(worddict.items(), key = operator.itemgetter(1),reverse=True) return render(request,'count.html', 'fulltext':fulltext,'count':len(wordlist),'worddict'::worddict})

    def about(request): return render(request,"about.html")

    1. В urls.py у меня были следующие шаблоны URL:

    urlpatterns = [ path('admin/', admin.site.urls), path('',views.homepage,name="home"), path('eggs',views.eggs), path('count/',views.count,name="count"), path('about/',views.count,name="about"), ]

Как видно из №. 3 выше, в последнем шаблоне URL я неправильно вызывал views.count, тогда как мне нужно было вызвать views.about. Эта строка fulltext = request.GET['fulltext'] в функции count (которая была вызвана по ошибке из-за неправильной записи в urlpatterns) для views.py вызвала исключение multivaluedictkeyerror.

Затем я изменил последний шаблон URL в urls.py на правильный, т.е. path('about/',views.about,name="about"), и все работало нормально.

По-видимому, в общем, программист-новичок в django может совершить ошибку, которую я допустил из-за неправильного вызова другой функции представления для URL, которая может ожидать другой набор параметров или передачу другого набора объектов при вызове рендеринга, а не предполагаемого поведения.

Надеюсь, это поможет начинающему программисту в Django.

0

Сначала проверьте, имеет ли объект запроса параметр ключа is_private. В большинстве случаев это MultiValueDictKeyError происходило из-за отсутствия ключа в словарном объекте запроса. Поскольку словарь является неупорядоченным ключом, пара значений "ассоциативные воспоминания" или "ассоциативные массивы"

Другими словами request.GET или request.POST - это словарь-объект, содержащий все параметры запроса. Это специфично для Джанго.

Метод get() возвращает значение для данного ключа, если ключ находится в словаре. Если ключ недоступен, возвращается значение по умолчанию Нет.

Вы можете обработать эту ошибку, поместив:

is_private = request.POST.get('is_private', False);
0
is_private = request.POST.get('is_private', 'default value')

Ещё вопросы

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