Django Select 一个有效的选择。[...] 不是可用的选择之一。以动态生成的形式

Django Select a valid choice.[...] is not one of the available choices. in a dynamically generated form

我正在制作一个测验应用程序,我想制作一个动态表单来呈现问题。

我在我的问题中使用了两个小部件(widgets.RadioSelectwidgets.CheckboxSelectMultiple)来呈现问题的选择。当我提交表单时出现以下错误:

Select a valid choice.['option1', 'option2'] is not one of the available choices.

仅从第二个小部件的问题中上升,例如:widgets.CheckboxSelectMultiple。 RadioSelect 提交成功。

forms.py:

    class QuestionForm(forms.Form):
            
        def __init__(self, fields, *args, **kwargs):
    
            super(QuestionForm, self).__init__(*args, **kwargs)
    
            # Init form fields
            for field in fields:
                self.fields[field['name']] = forms.ChoiceField(
                    label=field['label'],
                    choices=field['choices'],
                    widget=getattr(widgets, field['widget']),
                    required=False
                )

views.py:

def quiz(request, quiz_id):

    quiz = get_object_or_404(QCM, pk=quiz_id)

    if request.method == 'POST':
        if request.POST['action'] == 'Save':
            form = QuestionForm(data=request.POST)
            if form.is_valid():
                print('form is valid :)')
                form.save()
            else:
                print('form is not valid :(')
    else:
        form = QuestionForm()

    context = {
        'form': form,
    }
    return render(request, 'quiz/quiz.html', context)

quiz.html

{% extends "quiz/first.html" %}
{% load staticfiles %}

{% block main %}
    <form method="POST" class="form-horizontal" id="qcm_form" enctype="multipart/form-data">
        <div class="row">
            <div class="col-md-12">
                {% csrf_token %}
                
                {% for field in form %}
                    <div class="form-group">
                        <label class="field-label" for="id_{{ field.name }}">{{ field.label }}{% if field.field.required %} <span class="text-danger">*</span>{% endif %}</label>
                        {{ field }}
                    </div>
                {% endfor %}
            </div>
        </div>
        <input type="submit" class="btn btn-primary" name="action" value="Save">
    </form>
{% endblock main %}

如有任何帮助,我们将不胜感激。

问题出在我使用的 forms.Field 子类中 (ChoiceField) 只接受字符串值而不是列表。这就解释了为什么单选按钮可以工作,因为它们提交了一个字符串值,而 CheckboxSelectMultiple 没有,因为它提交了一个列表。

我已经修改了生成的字段列表以包括 forms.Field 子类。

当我有多个值时,我使用 forms.MultipleChoiceField,如果只有一个值,我分配 forms.ChoiceField.