ввод выбора для приложения опроса фляги - PullRequest
2 голосов
/ 07 апреля 2011

Я создал схему базы данных для приложения опроса, которое я делаю с помощью Flask, следующим образом:

CREATE TABLE questions (
    question_id integer primary key autoincrement,
    questiontext string not null
);

CREATE TABLE choices (
    choice_id integer primary key autoincrement,
    choicetext string not null,
    question_id integer,
    FOREIGN KEY(question_id) REFERENCES questions(question_id)
);

Но я не мог понять, как я должен спрашивать (в шаблоне HTML) и вставлять варианты в базу данных. Мои 'show_polls' и 'add_polls' ниже

    @app.route('/')
def show_polls():
    cur = g.db.execute('SELECT questiontext, choicetext FROM questions q JOIN choices c ON c.question_id = q.question_id') 
    polls = [dict(question=row[0], choices=(c for c in row[1:])) for row in cur.fetchall()] 
    return render_template('show_polls.html', polls=polls)

@app.route('/add', methods=['POST'])
def add_poll():
    if not session.get('logged_in'):
        abort(401)
    g.db.execute('insert into questions (questiontext) values (?)', 
            [request.form['questiontext']])

    for i in range(4): #4 choices
        g.db.execute('insert into choices (choicetext, question_id) values(?, ?)',
                [request.form['choicetext'], 4])
    g.db.commit()
    return redirect(url_for('show_polls'))

Но это не работает. Я не уверен, что у меня неправильные представления или часть макета HTML. Может ли кто-нибудь помочь мне с этим, пожалуйста?

Вот часть HTML, которая добавляет опросы:

{% for i in range(4) %}
            <dt>Choices:
            <dd><input type=text name=choicetext>
        {% endfor %}

1 Ответ

2 голосов
/ 07 апреля 2011

Без полного шаблона или HTML, я собираюсь предположить, что HTML <form> действителен.См. HTML-формы и входные данные , если вы подозреваете проблему там.

Чтобы убедиться, что значения формы достигают вашей функции add_poll (), попробуйте использовать Режим отладки Flask (т.е.установите app.debug = True до app.run()).Для принудительного вызова отладчика вставьте ошибку в функцию add_poll () и снова отправьте форму из браузера.Копия трассировки должна появиться.Нажмите на значок «console» в последней строке трассировки (это должна быть ошибка, созданная вами в add_poll ()) и начните интерактивную проверку объекта request.form.

[console ready]
>>> request.form
werkzeug.datastructures.ImmutableMultiDict({'choicetext': u''})
>>> str(request.form)
"ImmutableMultiDict([('choicetext', u'choice1'), ('choicetext', u'choice2'), ('choicetext', u'choice3'), ('choicetext', u'choice4')])"
>>> dir(request.form)
['KeyError', '__class__', '__cmp__', '__contains__', '__copy__', '__delattr__',    '__delitem__', '__dict__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getstate__', '__gt__', '__hash__', '__init__', '__iter__', '__le__', '__len__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__setitem__', '__setstate__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'add', 'clear', 'copy', 'fromkeys', 'get', 'getlist', 'has_key', 'items', 'iteritems', 'iterkeys', 'iterlists', 'iterlistvalues', 'itervalues', 'keys', 'lists', 'listvalues', 'pop', 'popitem', 'popitemlist', 'poplist', 'setdefault',         'setlist', 'setlistdefault', 'to_dict', 'update', 'values'  ]
>>> request.form.getlist('choicetext')
[u'choice1', u'choice2', u'choice3', u'choice4']

Надеюсь, это сделаетОчистите то, что должно измениться в add_poll () и упростите будущую отладку вашего приложения.Удачи!

Для получения дополнительной информации прочитайте документацию по объектам Flask.request.form и werkzeug.datastructures.MultiDict .В качестве примера обработки проверки формы в Flask (следующий шаг после установки сантехники) этот документ Flask pattern при проверке формы может быть хорошим местом для начала.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...