Flask - WTForm - 将表单数据作为NoneType获取而不是String

时间:2016-03-08 18:09:36

标签: python flask sqlalchemy wtforms flask-wtforms

为了解决这个问题,我一直在互联网上搜索一段时间。

我正在研究概念验证,一个简单的输入输出数据输入应用程序。

但是,我正在使用的表单不​​会输出我的NoneType值,因为我尝试使用filters来执行此操作,如此stackoverflow线程所示:Get None from a Fields data in instead of an empty string < / p>

然而,结果并不像预期的那样,因为我仍然只收到字符串。

我的表格

class MyForm(Form):
    event_date = DateField('Event Date:', format='%Y-%m-%d', validators=[DataRequired()], filters=[lambda x: x or None])
    person = StringField('Person', filters=[lambda x: x or None])
    office = QuerySelectField(query_factory=get_all_offices, allow_blank=True,
                              filters=[lambda x: x or None])
    event_type = QuerySelectField(query_factory=get_all_event_types, allow_blank=True, filters=[lambda x: x or None])
    submit = SubmitField('Search')

渲染

@app.route('/myform', methods=['GET', 'POST'])
def myform():
    if request.method == 'GET':
        form = MyForm()
        return render_template('my_form.html', form=form)
    else:
        print(request.form)
        context = {}
        event_date = request.form['event_date']
        office = request.form['office']
        person = request.form['person']
        event_type = request.form['event_type']
        print(person)
        print(event_date)
        print(type(office))
        print(event_type)

输入

enter image description here

输出

enter image description here

如您所见,office和事件类型作为String对象传递,其值为&#34; __ None&#34;。

是否可以让表单处理'''__None'到内置NoneType的翻译?

编辑:人/办公室的架构

class Person(Base):
    __tablename__ = 'people'

    id = Column(Integer, primary_key=True, autoincrement=True)
    name = Column(String(64), nullable=False)
    political_party = Column(String(64), nullable=False)
    ap_candidate_id = Column(String(64), nullable=False)

    def __repr__(self):
        return self.name


class Office(Base):
    __tablename__ = 'offices'

    id = Column(Integer, primary_key=True, autoincrement=True)
    desc = Column(String(64), nullable=False)

    def __repr__(self):
        return self.desc


class Event(Base):
    __tablename__ = 'events'

    id = Column(Integer, primary_key=True, autoincrement=True)
    event_date = Column(DateTime, nullable=False)
    office_id = Column(Integer, ForeignKey(Office.id))
    office = relationship('Office', backref='events')
    winner_id = Column(Integer, ForeignKey(Person.id))
    winner = relationship('Person', foreign_keys=winner_id, backref='events_won')
    loser_id = Column(Integer, ForeignKey(Person.id))
    loser = relationship('Person', foreign_keys=loser_id, backref='events_lost')
    event_type_id = Column(Integer, ForeignKey(EventType.id))
    event_type = relationship('EventType', backref='events')
    state_id = Column(Integer, ForeignKey(State.id))
    state = relationship('State', backref='state_events')

    def __repr__(self):
        return '{0} - {1}'.format(self.office, self.event_date)

2 个答案:

答案 0 :(得分:1)

你在做什么

print request.form['event_date']

所以基本上你只是打印浏览器发布的数据。您甚至没有使用您创建的MyForm类。您需要将request.form数据传递给MyForm类,以便它可以解析它。然后使用你的MyForm类实例。

您需要执行类似

的操作
def myform():
    if request.method == 'GET':
        form = MyForm()
        return render_template('my_form.html', form=form)
    else:
        form = MyForm(request.form)
        if form.validate():
            print form.event_date.data
            print form.office.data
            print form.person.data
            print form.event_type.data

有关详情,请参阅docs,了解如何处理视图中的表单。

答案 1 :(得分:0)

您的过滤器需要考虑该值可能是字符串值"__None",目前您的过滤器只是检查该值是否不存在。以下内容应该有效(未经测试)。

 person = StringField('Person', filters=[lambda x: x or None, lambda x: None if x == '__NONE' else x])