如何使用 Python Flask 创建具有关联表单的项目列表

How to create a list of items with associated form with Python Flask

我正在尝试实现一个 Flask 网站,用于为协会预购一些产品。我想做的是在 上发布一个带有表格的网页,人们可以选择一定数量的某种产品。为此,我迭代 fake_product_list 并为列表中的每个项目创建一个表单。

例子:

Product name number of item to order
'MU' Select Quantity
'GP' Select Quantity
'ARE' Select Quantity
'CLL' Select Quantity

commande_initiale.html

{% extends "base.html" %}

{% block content %}
    <h1>Commande Initiale</h1>
    <form action="" method="post">
            {% for entry in form.entries %}
                <p>{{entry.quantity.label}}: {{ entry.quantity }}</p>
            {% endfor %}
            <p>{{form.submit()}}</p>
        </form>
{% endblock %}>

forms.py

class LigneCommande(FlaskForm):
    quantity = IntegerField()

class CommandeInitiale(FlaskForm):
    entries=FieldList(LigneCommande)
    submit=SubmitField('Passer la Commande')

routes.py

fake_product_list=['MU','GP','ARE','CLL']

@app.route('/commande_initiale', methods=['GET', 'POST'])
@login_required
def commande_initiale():

    fields = []
    for ligne_bcd in fake_product_list :
        ligne_item = LigneCommande()
        ligne_item.quantity.label=ligne_bcd
        ligne_item.quantity.name=ligne_bcd
        fields.append(ligne_item)

    form = CommandeInitiale()
    form.entries = fields
    if form.validate_on_submit():
        print(request.form)

    return render_template('commande_initiale.html', title='Commande Initiale',
                           form=form)

我不知道这段代码有什么问题,它 return 我是一个 AssertionError: Field must be unbound, not a field class 因为我想显示 html 页

这是调试器消息:

Traceback (most recent call last):
  File "\venv\Lib\site-packages\flask\app.py", line 2464, in __call__
    return self.wsgi_app(environ, start_response)
  File "\venv\Lib\site-packages\flask\app.py", line 2450, in wsgi_app
    response = self.handle_exception(e)
  File "\venv\Lib\site-packages\flask\app.py", line 1867, in handle_exception
    reraise(exc_type, exc_value, tb)
  File "\venv\Lib\site-packages\flask\_compat.py", line 39, in reraise
    raise value
  File "\venv\Lib\site-packages\flask\app.py", line 2447, in wsgi_app
    response = self.full_dispatch_request()
  File "\venv\Lib\site-packages\flask\app.py", line 1952, in full_dispatch_request
    rv = self.handle_user_exception(e)
  File "\venv\Lib\site-packages\flask\app.py", line 1821, in handle_user_exception
    reraise(exc_type, exc_value, tb)
  File "\venv\Lib\site-packages\flask\_compat.py", line 39, in reraise
    raise value
  File "\venv\Lib\site-packages\flask\app.py", line 1950, in full_dispatch_request
    rv = self.dispatch_request()
  File "\venv\Lib\site-packages\flask\app.py", line 1936, in dispatch_request
    return self.view_functions[rule.endpoint](**req.view_args)
  File "\venv\Lib\site-packages\flask_login\utils.py", line 272, in decorated_view
    return func(*args, **kwargs)
  File "\app\routes.py", line 184, in commande_initiale
    form = CommandeInitiale()
  File "\venv\Lib\site-packages\wtforms\form.py", line 208, in __call__
    return type.__call__(cls, *args, **kwargs)
  File "\venv\Lib\site-packages\flask_wtf\form.py", line 87, in __init__
    super(FlaskForm, self).__init__(formdata=formdata, **kwargs)
  File "\venv\Lib\site-packages\wtforms\form.py", line 268, in __init__
    super(Form, self).__init__(self._unbound_fields, meta=meta_obj, prefix=prefix)
  File "\venv\Lib\site-packages\wtforms\form.py", line 51, in __init__
    field = meta.bind_field(self, unbound_field, options)
  File "\venv\Lib\site-packages\wtforms\meta.py", line 27, in bind_field
    return unbound_field.bind(form=form, **options)
  File "\venv\Lib\site-packages\wtforms\fields\core.py", line 376, in bind
    return self.field_class(*self.args, **kw)
  File "\venv\Lib\site-packages\wtforms\fields\core.py", line 926, in __init__
    assert isinstance(unbound_field, UnboundField), 'Field must be unbound, not a field class'
AssertionError: Field must be unbound, not a field class

感谢您的帮助!!

好的,我找到问题了:

我必须在 forms.py

中更换
class CommandeInitiale(FlaskForm):
    entries=FieldList(LigneCommande)
    submit=SubmitField('Passer la Commande')

class CommandeInitiale(FlaskForm):
    entries=FieldList(FormField(LigneCommande))
    submit=SubmitField('Passer la Commande')

感谢收看 ;-)