我想在wtforms中使用数据库中的数据预加载表单数据,而不知道列名。
只要我知道我想要的列名。
form.column.data=User.query.get(1).first().column
我想要做的就是遍历所有列:
for attr, value in User.query.get(1).__dict__.iteritems():
form.attr.data = value
这样做会给我一个错误:
AttributeError: 'EditUsersForm' object has no attribute 'attr'
以下是我试图专门开展工作的代码片段。
forms.py
class EditUsersForm(ModelForm):
class Meta:
model=User
exclude=['password_hash']
models.py
class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
username = db.Column(db.String(32), index=True, unique=True)
password_hash = db.Column(db.String(128))
email = db.Column(db.String(120), index=True, unique=True)
posts = db.relationship('Post', backref='author', lazy='dynamic')
#mobilitys = db.relationship('Mobility', backref='username', lazy='dynamic')
about_me = db.Column(db.String(140))
last_seen = db.Column(db.DateTime)
def __repr__(self): # pragma: no cover
return '<user> %r' % (self.username)
views.py
@app.route('/manpower_edit_users', methods=['GET', 'POST'])
@login_required
def manpower_edit_users():
form=QueryAllUsers(request.form)
forms=EditUsersForm(request.form)
'''
if forms.validate():
print("validate")
print("forms.validate=",forms.validate)
flash("User added")
'''
if request.method == "POST":
for attr, value in User.query.get(user_list).__dict__.iteritems():
forms.attr.data=value
elif request.method == "GET":
for attr, value in User.query.get(1).__dict__.iteritems():
forms.attr.data=value
return render_template('manpower_edit_users.html',title='Manpower Edit User', form=form, forms=forms)
答案 0 :(得分:1)
edit_user_form = EditUsersForm(obj = User.query.get(1))
您可以从数据填充表单。 obj
文档中的关键字参数WTForms
表示:
obj - 如果formdata没有字段数据,表单将尝试从传递的对象中获取它。