如何使用 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')
感谢收看 ;-)
我正在尝试实现一个 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')
感谢收看 ;-)