MultiValueDictKeyError at / update 'date' - PullRequest
0 голосов
/ 04 апреля 2020

Я пытаюсь обновить базу данных, но обнаружил MultiValueDictKeyError.

Проблема вызвана датой:

t.date = request.POST.get('date')

Я пытался

print(request.POST)

с результатом:

<QueryDict: {'csrfmiddlewaretoken': ['9mgfDaQRsH4Pv5rvglufS3wC61QDL5i9tcOqmBQwNFAKFpzE79h9wBY8St9CwBsB'], 'ID_number': ['4'], 'date_month': ['1'], 'date_day': ['1'], 'date_year': ['2020'], 'first_name': ['Gedo'], 'last_name': ['Prasad'], 'Membership_Start_date_month': ['1'], 'Membership_Start_date_day': ['1'], 'Membership_Start_date_year': ['2020'], 'Membership_End_date_month': ['4'], 'Membership_End_date_day': ['1'], 'Membership_End_date_year': ['2020'], 'member_type': ['Gym&Sauna'], 'payment_type': ['3 Month'], 'rate': ['23'], 'paid': ['20'], 'due': ['3'], 'Contact_number': ['1121212129'], 'Email': ['gedo@pzrasad.com'], 'Remarks': ['gsa']}>

Обратите внимание, что в поле даты отдельно указываются «date_month», «date_day», «date_year». Может в этом проблема. Но я не знаю ответа. Любые предложения будут очень полезны, так как я студент и новичок.

Вот мои модели.py:

class Member(models.Model):
    ID_number = models.IntegerField()
    date = models.DateField(verbose_name='date')
    first_name = models.CharField(max_length=30)
    last_name = models.CharField(max_length=30)
    member_type = models.CharField(
        max_length=30,
        choices=MEMBERSHIP_CHOICES,
    )
    payment_type = models.CharField(
        max_length=30,
        choices=PAYMENT_TYPE_CHOICES,
    )
    Membership_Start_date = models.DateField(verbose_name='Membership_Start_date')
    Membership_End_date = models.DateField(verbose_name='Membership_End_date')
    rate = models.IntegerField()
    paid = models.IntegerField()
    due = models.IntegerField()
    Contact_number = models.CharField(max_length=14)
    Email = models.EmailField()
    Remarks = models.CharField(max_length=255, blank = True, null = True)

def __str__(self):
    return str(self.ID_number) + "  " + self.first_name + " " + self.last_name

1 Ответ

0 голосов
/ 05 апреля 2020

Итак, я нашел обходной путь, основанный на формате, который принимает поле даты, т.е. ГГГГ-ММ-ДД:

t.date = request.POST['date_year'] + "-" + request.POST['date_month'] + "-" + request.POST['date_day']

Но есть ли другой способ?

...