我正在使用Flask-WTF和SQLAlchemy进行多项选择测验,以从数据库表中提取随机引号和可能的答案。我已经能够做到这一点。但是,当提交表单并将所选答案保存到新的数据库表中时,我看到实际的问题(引号)和答案已更改。看起来好像在提交表单时正在运行新查询。这是我的意思的简单示例。
关于带有选项的测验的实际问题
谁说...“天空是蓝色的。”
数据已保存到数据库
问题:谁说...“苹果是红色的。”
选择的答案:汤姆
我正试图弄清楚如何阻止其他查询的发生,以便我可以保存用户实际看到并回答的问题中的数据。
这是我的表格:
class Quiz(FlaskForm):
q1 = RadioField('', coerce=str, validators=[DataRequired()], choices=[])
q2 = RadioField('', coerce=str, validators=[DataRequired()], choices=[])
q3 = RadioField('', coerce=str, validators=[DataRequired()], choices=[])
q4 = RadioField('', coerce=str, validators=[DataRequired()], choices=[])
q5 = RadioField('', coerce=str, validators=[DataRequired()], choices=[])
我的观看路线:
@app.route('/quiz/', methods=['GET', 'POST'])
def quiz():
form = Quiz()
for field in form:
if field.type != "RadioField":
continue
else:
pulls = Quotes.query.order_by(func.rand()).limit(1)
for pull in pulls:
answer = pull.speaker
option_two = pull.option_two
option_three = pull.option_three
option_four = pull.option_four
question = pull.line_text
field.label = pull.line_text
field.choices = [("1", answer), ("2", option_two), ("3", option_three), ("4", option_four)]
if form.validate_on_submit():
for field in form:
if field.type == "CSRFTokenField":
continue
else:
user_answer = field.data
question_id = field.id
question_line = field.label
correct_answer = answer
submission = Responses(question_id, question_line, user_answer, correct_answer)
db.session.add(submission)
db.session.commit()
return redirect(url_for('you_passed'))
return render_template('quiz.html', form=form)
任何帮助将不胜感激。我也愿意接受有关当前代码的任何建议。我是Python的新手,还没有达到我的编码要求。谢谢。