У меня проблемы с wtforms selectfields, когда я использую сообщение с колбой

Я довольно новичок в wtforms и колбе и возился с selectfields и получил ошибку. Сама форма отлично работает без selectfield, но с ней я получаю следующую ошибку:

ошибка:

....fields.py", line 386, in pre_validate
    for v, _ in self.choices: TypeError: 'NoneType' object is not iterable

Я вижу selectfield так это рендерится. Я подозреваю, что каким-то образом идентификатор не проверяется должным образом на POST и не возвращает его. Или это как-то связано с возвращением моего кортежа selectfield ? Также поле ID я использование извлекается из автоматического ключа ndb GAE().id (), который довольно длинный и неприятный. Это может быть длина id, используемая для selectfield, слишком длинная ?

Googling не предоставил много с точки зрения точной проблемы, поэтому я подумал, что опубликую здесь. Соответствующий код ниже. Если я что-то пропустил, пожалуйста, дайте мне знать

views.py код:

@app.route('/new/post', methods = ['GET', 'POST'])
@login_required
def new_post():

    form = PostForm()
    if form.validate_on_submit():
        post = Post(title = form.title.data,
                    content = form.content.data,
                    hometest = form.hometest.data,
                    author = users.get_current_user())
        post.put()
        flash('Post saved on database.')
        return redirect(url_for('list_posts'))
    form.hometest.choices = [ (h.key.id(),h.homename)for h in Home.query()]

    return render_template('new_post.html', form=form)

myforms.py:

class PostForm(Form):
    title = wtf.TextField('Title', validators=[validators.Required()])
    content = wtf.TextAreaField('Content', validators=[validators.Required()])
    hometest = wtf.SelectField(u'Home Name List', coerce=int,validators=[validators.optional()])

new_post.HTML-код:

{% extends "base.html" %}

{% block content %}
    <h1 id="">Write a post</h1>
    <form action="{{ url_for('new_post') }}" method="post" accept-charset="utf-8">
        {{ form.csrf_token }}
        <p>
            <label for="title">{{ form.title.label }}</label><br />
            {{ form.title|safe }}<br />
            {% if form.title.errors %}
            <ul class="errors">
                {% for error in form.title.errors %}
                <li>{{ error }}</li>
                {% endfor %}
            </ul>
            {% endif %}
        </p>
        <p>
            <label for="title">{{form.hometest.label}}</label><br/>
            {{form.hometest}}
            {% if form.hometest.errors %}
        <ul class="errors">
            {% for error in form.hometest.errors %}
            <li>{{ error }}</li>
            {% endfor %}
        </ul>
        {% endif %}
        </p>
        <p>
            <label for="title">{{ form.content.label }}</label><br />
            {{ form.content|safe }}<br />

            {% if form.content.errors %}
            <ul class="errors">
                {% for error in form.content.errors %}
                <li>{{ error }}</li>
                {% endfor %}
            </ul>
            {% endif %}
        </p>
        <p><input type="submit" value="Save post"/></p>
    </form>
{% endblock %}

2 ответов


вы должны установить свой выбор до вы называете validate_on_submit as form.validate попытается проверить предоставленное значение (если есть) против списка вариантов (который является None перед choices):

form = PostForm()
form.hometest.choices = [(h.key.id(), h.homename) for h in Home.query()]

if form.validate_on_submit():
    # form is valid, continue

вы должны предоставить