Python 如何将初始数据作为默认值附加到新的wtforms FormField?

Python 如何将初始数据作为默认值附加到新的wtforms FormField?,python,flask,wtforms,Python,Flask,Wtforms,我有一个带有wtform的表单,我想使用append\u entry将一个新表单JobItemForm添加到我的表单JobFormJobItemForm具有selectField名称company。我通过这样的模型添加选择字段数据 form.jobs[0].company.choices = company_list @mod.route('/edit/', methods=['GET', 'POST']) @login_required def edit_job(): """

我有一个带有
wtform
的表单,我想使用
append\u entry
将一个新表单
JobItemForm
添加到我的表单
JobForm
JobItemForm
具有
selectField
名称
company
。我通过这样的模型添加选择字段数据

form.jobs[0].company.choices = company_list
@mod.route('/edit/', methods=['GET', 'POST'])
@login_required
def edit_job():
    """
    edit job
    """
    company_list = Company.Company_list()
    form_title = "Edit job Form"
    if request.method != 'POST':
        form = JobForm()
        form.jobs[0].company.choices = company_list
        return render('form.html', form=form, form_title=form_title)
    form = JobForm(request.form)
    if form.add_job.data:
        new_item_job = form.jobs.append_entry()
        new_item_job.company.choices = company_list
        return render('form.html', form=form, form_title=form_title)

    form.validate
    if form.errors != dict():
        return render('form.html', form=form, form_title=form_title)
    # save data
    flash(_("Edit successfully!"))
    return render('registration/succesful.html')
现在我在没有任何选择的情况下使用
append\u entry
,收到一个错误。那么我如何用一些初始数据调用
append\u entry

class JobItemForm(Form):
    company = SelectField(_('company'), description=_('<a href="/education/institute/add/">new company"</a>'))
    title = TextField(_('title'), [validators.Length(min=4, max=250)])
    date_from = DateField(_("date_from"), format='%Y-%m-%d')
    date_to = DateField(_("date_to"), format='%Y-%m-%d')
    description = TextAreaField(_('description'))


class JobForm(Form):
    jobs = FieldList(FormField(JobItemForm), min_entries=3)
    add_job = SubmitField(_('Add job'))

有一种更好的方法可以做到这一点:

    form.jobs[0].company.choices = company_list
Wtforms具有对GAE、Django和SQLAlchemy的扩展,这些扩展支持orm支持的表单字段

对于sqlalchemy,其工作原理如下:

    from wtforms.ext.sqlalchemy.fields import QuerySelectField

    def fill_field():
         return Model.query

    myfield = QuerySelectField(query_factory=fill_field)
    def your_view():
        form = YourForm()
        form.fieldname.choices = choice_list
        # Here comes your code for GET and POST request both
这段代码自动填充数据库模型中的选项

(我没有你的实际错误,所以我只是在这里猜测)

添加作业后,您没有选择的原因出错,因为您仅在GET请求时填写选择。您也需要在Post请求后添加选项,如下所示:

    from wtforms.ext.sqlalchemy.fields import QuerySelectField

    def fill_field():
         return Model.query

    myfield = QuerySelectField(query_factory=fill_field)
    def your_view():
        form = YourForm()
        form.fieldname.choices = choice_list
        # Here comes your code for GET and POST request both

试着运行它,看看是否有任何错误,并张贴在这里。我认为它应该运行得很好。@codecool一开始我认为form.jobs[0].company.choices=company\u list是非常难看的代码,它必须在add\u job后的第二秒执行另一种方式,它说其中一项没有选择。如果我在每个请求后添加,但没有删除数据?不,它不会删除数据。当我第一次使用表单的这个choices属性时,我也这么认为,但它需要在每次请求时填写choice。请注意,在使用QuerySelectField时,这不是必需的。