我有一个非常简单的表格和表格,我正在努力提交到使用python flask。
sqllite表由此类创建(这可以):
class Country(db.Model):
__tablename__ = 'countries'
countryid = db.Column(db.Integer, primary_key=True)
country = db.Column(db.String(65), unique=True, index=True)
active = db.Column(db.Boolean, default=True)
def __init__(self, country):
"""
Used to create a Country object in the python server scope
"""
self.country = country
表单是通过此类生成的:
class CountryForm(Form):
country = StringField('Country name', validators=[Length(0, 64)])
submit = SubmitField('Submit')
页面显示在视图中:
@main.route('/country', methods=['GET','POST'])
def show_CountryForm():
form = CountryForm()
print 'Form Values',form
if form.validate_on_submit():
ctry = Country(country=form.country.data)
db.session.add(ctry)
flash('The country has been added.')
return redirect(url_for('chinese'))
return render_template("country.html", form=form)
html模板页面是:
{% extends "base.html" %}
{% import "_macros.html" as macros %}
{% block title %}Countries{% endblock %}
{% block page_content %}
<div class="container">
<form method="POST" action="/country">
<div>
<label for="country" class="label_control">
Country
</label>
<div class="form_control" id="country">
{{ form.country }}
</div>
</div>
{{ form.submit() }}
</form>
</div>
{% endblock %}
所以一切似乎运行没有错误,但记录没有添加到数据库。任何帮助将不胜感激。
答案 0 :(得分:3)
这里有两个问题。一个是你的表单永远不会验证,因为它没有form.hidden_tag()
任何地方,你没有在页面上显示错误。以下内容添加了令牌和div,用于显示任何表单错误。
第二个问题是,您从未将数据库会话提交到数据库,因此即使您的表单已经过验证,您的数据也不会被保存。
表单未验证且未显示错误:
在您的表单中,尝试添加{{ form.hidden_tag() }}
,之后您的表单应该很好地提交。如果你不添加它,表单将引发错误,因为它不再是有效的XHTML。
<div class="container">
<form method="POST" action="/country">
<div>
<label for="country" class="label_control">
Country
</label>
<div class="form_control" id="country">
{{ form.hidden_tag() }}
{{ form.country }}
</div>
<div class="form_errors">
{{ form.errors }}
</div>
</div>
{{ form.submit() }}
</form>
</div>
未保存数据:
你没有在任何地方调用db.session.commmit()
,这就是session
永远不会被提交到数据库的原因。
@main.route('/country', methods=['GET','POST'])
def show_CountryForm():
form = CountryForm()
print 'Form Values',form
if form.validate_on_submit():
ctry = Country(country=form.country.data)
db.session.add(ctry)
db.session.commit() # This saves the data.
flash('The country has been added.')
return redirect(url_for('chinese'))
return render_template("country.html", form=form)