如何使用zip()函数插入数据

时间:2019-04-09 13:52:12

标签: django

我正在尝试使用zip()函数获取数据后插入数据,但收到错误消息。 x是问题ID,y是选定的答案,corrected_answer中的print(x, y, correct_answers)。我想通过设置is_correct=True的值和对is_correct=False的错误答案来保存正确的问题

enter image description here

@login_required
@student_required
def take_exam(request, pk):
    course = get_object_or_404(Course, pk=pk)
    student = request.user.student
    question = course.questions.filter()  
    #correct_answers = student.course_answers.filter(answer__question__quiz=course, answer__is_correct=True).count()
    total_questions = course.questions.count()
    choice = Answer.objects.filter()
    marks_obtainable = Details.objects.get(course_id=course)

    if request.method == 'POST':

        question_pk = request.POST.getlist('question_pk')
        #question_obj = Question.objects.filter(id=int(question_pk))
        #question_obj = Question.objects.filter(id=question_pk)

        #choice_pk = [request.POST['choice_pk{}'.format(q)] for q in question_obj]
        choice_pk = [request.POST['choice_pk{}'.format(q)] for q in question_pk]

        #print(marks_obtainable.marks_obtained)
        zipped = zip(question_pk, choice_pk)

        for x, y in zipped:
            correct_answers = Answer.objects.filter(question_id=x,  is_correct=True).values("id").first()['id']

            print(x, y, correct_answers)
            if int(y) == int(correct_answers):
                z = TakenQuiz(student=student, course=course, question=x, selected_choice=y,  marks_obtained=marks_obtainable, is_correct=True)
                print("correct")
            else:
                z = TakenQuiz(student=student, course=course, question=x, selected_choice=y,  marks_obtained=marks_obtainable, is_correct=False)
                print("Not Correct")

    return render(request, 'classroom/students/take_exam_form.html', {
        'course': course,
        'question': question,
        'course': course,
        'total_questions': total_questions,
        'choice': choice,
        'marks_obtainable': marks_obtainable 
    })

<form method="post" novalidate>

        {% csrf_token %}

        {% for questions in question %}

        <input type="hidden" name="question_pk" value="{{ questions.pk }}">

        <h3 class="text-info">{{ questions.text|safe }}</h3>


    {% for choices in questions.answers.all %}

        <input class="form-check-input" type="radio" name="choice_pk{{ questions.pk }}" id="choices-{{ forloop.counter }}" value="{{ choices.pk }}">

        <label class="form-check-label" for="choices-{{ forloop.counter }}">
              {{ choices.text|safe }}
        </label>

      {% endfor %}

      {% endfor %}
            <button type="submit" class="btn btn-primary">Submit Now →</button>

</form>

1 个答案:

答案 0 :(得分:0)

基于错误x,应为Question实例。

您需要为每个pk获取Question对象,然后将其压缩。

question_pk = [Question.objects.get(pk=pk) for pk in request.POST.getlist('question_pk')]