id обязательное поле - ошибка в наборе форм Django - PullRequest
1 голос
/ 03 октября 2019

Я использую Django 2.2. Мои модели

class Group(models.Model):
    group_name = models.CharField(max_length=100)
    def __str__(self):
        return self.group_name
class Category(models.Model):
    category_name = models.CharField(max_length=50)
    def __str__(self):
        return self.category_name
class Profile(models.Model):
    user = models.OneToOneField(User, on_delete=models.CASCADE)
    board = models.CharField(choices=board_options,max_length=1,null=True)
    group = models.ForeignKey(Group,on_delete=models.CASCADE,null=True)

class Subject(models.Model):
    subject_name = models.CharField(max_length=50)
    subject_category = models.ForeignKey(Category, on_delete=models.CASCADE)
    subject_photo = models.ImageField(null=True,blank=True)
    def __str__(self):
        return self.subject_name

class Subject_Assignment(models.Model):
    board = models.CharField(choices=board_options,max_length=1,null=True)
    group = models.ForeignKey(Group,on_delete=models.CASCADE,null=True)
    Subject = models.ForeignKey(Subject, on_delete=models.CASCADE)

class Mark_Survey(models.Model):
    survey_name = models.CharField(max_length=50)
    opens_at =  models.DateField()
    ends_at = models.DateField()

class Survey_Mark(models.Model):
    mark_survey = models.ForeignKey(Mark_Survey,on_delete=models.CASCADE)
    user = models.ForeignKey(User, on_delete=models.CASCADE)
    Subject = models.ForeignKey(Subject, on_delete=models.CASCADE)
    marks = models.IntegerField()

Здесь я создаю набор форм для Survey_Mark, и моя форма должна получать оценки всех субъектов. Используя Subject_Assignment, я могу получить все темы конкретного пользователя. Следующее представление работает для метода get, но выдает ошибку в методе post.

def postsurvey(request,pk):
    #post = get_object_or_404(Mark_Survey, pk=pk)
    SurveyFormSet = modelformset_factory(Survey_Mark, fields=('marks','Subject'),extra=0)
    if request.method == "POST":
        formset = SurveyFormSet(request.POST,request.FILES)
        print(formset.data)
        print(formset.errors)

        if formset.is_valid():
            post = formset.save(commit=False)
            post.mark_survey=pk
            post.user=request.user
            post.save()
            html = "<html><body>Success</body></html>" % now
            return HttpResponse(html)
        else:
            print("failure")
            html = "<html><body>failure </body></html>" 
            return HttpResponse(html)

    else:
        user=request.user
        profile = get_object_or_404(Profile,user_id=user.id)
        formset = SurveyFormSet(queryset=Subject_Assignment.objects.filter(Q(board=profile.board) & Q(group=profile.group)))
        return render(request, 'subject_assignment_detail.html', {'formset': formset})

Получаю id, поле является обязательной ошибкой. если я использовал {{hidden}} в шаблоне, тогда я получаю Выберите правильный выбор. Этот выбор не является одним из доступных вариантов ошибка в методе записи. Я хочу получить оценки по всем предметам в единой форме и сохранить их в соответствующей таблице. Мой шаблон

<form method="post">
  {% csrf_token %}
  {{ formset.management_form }}


  {% for form in formset %}
  {% for hidden in form.hidden_fields %}
        {{ hidden }}
    {% endfor %}
  {{form}}

  {% endfor %}

  <input type="submit" value="OK">
</form>

Ответы [ 2 ]

0 голосов
/ 09 октября 2019

Моя форма должна получать оценки всех субъектов.

user=request.user
profile = get_object_or_404(Profile,user_id=user.id)
subjects = Subject_Assignment.objects.filter(Q(board=profile.board) & Q(group=profile.group))
SurveyFormSet = modelformset_factory(Survey_Mark, fields=('marks','Subject'),extra=len(subjects))

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

formset = SurveyFormSet(initial=[{'marks':'','Subject':x.id} for x in subjects])
0 голосов
/ 03 октября 2019

Можете ли вы предоставить полную форму для анализа?

post.mark_survey_id=pk
...