烧瓶,我如何获得模型结果?

时间:2016-01-14 11:23:59

标签: python flask flask-sqlalchemy flask-wtforms

我正在尝试将角色输出到菜单列表中,我正在获取。

roles = QuerySelectField(query_factory=lambda: Role.query.filter_by(front=True), allow_blank=True)

我正在

project.models.Role object at 0x7f0205ec5cd0

获取Role->名称的正确方法是什么? 这是我的模特:

class Role(db.Model):

    __tablename__ = 'roles'
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(20), index=True)
    front  = db.Column(db.Boolean, default=True)
    #permissions = db.relationship('Permission', backref='permission')
    users = db.relationship('User', backref='roles')

    def __init__(self, name, front):
        self.name = name
        self.front = front

这是我的表格

class RegisterForm(Form):
    email = StringField('Email', validators=[DataRequired(), Email()])
    username = StringField('Username', validators=[DataRequired(), Length(min=3, max=50, message="You must enter a min and max character")])
    password = PasswordField('Password', validators=[DataRequired(), EqualTo('password2', message='Your Passwords must be same')])
    password2 = PasswordField('Re-Enter Password', validators=[DataRequired(), EqualTo('password', message='Passwords must match.')]) 
    village = QuerySelectField(get_label='village', query_factory=villages_lists)
    roles = QuerySelectField(query_factory=lambda: Role.query.filter_by(front=True), allow_blank=True)

2 个答案:

答案 0 :(得分:1)

所选模型在表单字段的数据属性中可用。

e.g。收到帖子后,您可以执行以下操作:

form = RegisterForm()
if form.validate_on_submit():
   print form.roles.data.name

答案 1 :(得分:1)

您需要为Role对象提供wtforms可以使用的字符串表示形式。

例如,在您当前的代码中,您将获得以下内容:

r = Role.query.first()
print(r) # project.models.Role object at 0x7f0205ec5cd0

如果将以下内容添加到Role类:

def __repr__(self):
    return self.name

对象现在将具有该表示形式,因此如果我们再次运行相同的代码:

r = Role.query.first()
print(r) # Admin

wtforms使用该表示来设置字段中元素的显示值,所以一旦你拥有了该集合(并返回一个有用的表示),你就会按照你期望的方式工作。

相关问题