烧瓶 wtforms-alchemy QuerySelectField ValueError:解压的值太多(预期为 2)

Gof*_*tty 2 python sqlalchemy flask flask-sqlalchemy flask-wtforms

我正在尝试使用flask-wtfwtforms-alchemy 在此表单上创建注册表单我尝试创建selectfield,其值是从我的模型中查询的。但我总是收到这个错误:

 ValueError: too many values to unpack (expected 2)
Run Code Online (Sandbox Code Playgroud)

这是我的代码

from flask_wtf import FlaskForm
from wtforms_sqlalchemy.fields import QuerySelectField

def choose_domicile():
    return Domicile.query

class RegisterForm(FlaskForm):
    name = StringField('Name', validators=[DataRequired()])
    domicile = QuerySelectField(u'Domicile', query_factory=choose_domicile)


@app.route('/signup', methods=['GET', 'POST'])
    def signup():
        form = RegisterFormView()
        try:
            if form.validate_on_submit():
                new_user = Data(name=form.name.data, domicile=form.domicile.data)
                db.session.add(new_user)
                db.session.commit()
                return "Success"
        except:
            return "Failed"

        return render_template('signup.html', form=form)
Run Code Online (Sandbox Code Playgroud)

这是我的signup.html

{% block content %}
<div class="container">

  <form class="form-signin" method="POST" action="/signup">
    <h2 class="form-signin-heading">Sign Up</h2>
    {{ form.hidden_tag() }}
    {{ wtf.form_field(form.name) }}
    {{ form.domicile }}
    <button class="btn btn-lg btn-primary btn-block" type="submit">Sign Up</button>
  </form>

</div>
{% endblock %}
Run Code Online (Sandbox Code Playgroud)

我的包版本是flask-wtf==0.14.2wtforms-alchemy==0.16.7

我已经尝试按照这个为什么 Flask WTForms 和 WTForms-SQLAlchemy QuerySelectField 产生太多的值来解压?,但我仍然困惑如何做到这一点。

小智 8

您可以定义如下函数,该函数可以作为 get_pk 参数传递。

def get_pk(obj):
    return str(obj)
Run Code Online (Sandbox Code Playgroud)

然后进行以下更改

domicile = QuerySelectField(u'Domicile', query_factory=choose_domicile, get_pk=get_pk)
Run Code Online (Sandbox Code Playgroud)

我假设您已经__str__在模型类中定义else 返回 pk 在 get_pk