Python 3.x Flask FloatField在尝试保存数据时引发错误

Python 3.x Flask FloatField在尝试保存数据时引发错误,python-3.x,flask,flask-wtforms,wtforms,Python 3.x,Flask,Flask Wtforms,Wtforms,我创建了一个模型和表单,其中定义了一些浮点数据: class Paciente(db.Model): id = db.Column(db.Integer, primary_key=True) nombres = db.Column(db.String(40),unique=True, nullable=False) apellidos = db.Column(db.String(40),unique=True, nullable=False

我创建了一个模型和表单,其中定义了一些浮点数据:

    class Paciente(db.Model):
        id = db.Column(db.Integer, primary_key=True)
        nombres = db.Column(db.String(40),unique=True, nullable=False)
        apellidos = db.Column(db.String(40),unique=True, nullable=False)
        fecha_nacimiento = db.Column(db.DateTime,nullable=False)
        semanas_gestacion = db.Column(db.Integer,nullable=False)
        soplo_cardiaco = db.Column(db.Integer, nullable=False)
        peso = db.Column(db.Float, nullable=False)
        satO2_miembroSup = db.Column(db.Float, nullable=False)
        satO2_miembroSup24 = db.Column(db.Float, nullable=False)


class PacienteForm(FlaskForm):
    nombres = StringField('Nombres',validators=[DataRequired(), Length(min=2, max=20)])
    apellidos = StringField('Apellidos',validators=[DataRequired(), Length(min=2, max=30)])
    fecha_nacimiento = DateField('Fecha de nacimiento', format='%Y-%m-%d')
    semanas_gestacion = IntegerField('Semanas de gestacion',widget=NumberInput(),validators=[InputRequired(), NumberRange(min=0, max=50, message="Valores de 0 a 50")])
    soplo_cardiaco = SelectField('Soplo cardíaco',
                       choices=[
                           (1, 'Si'),
                           (0, 'No')])
    peso = FloatField('peso',widget=NumberInput(),default=1.0,
        validators=[NumberRange(0, 1E+20)])
    satO2_miembroSup = FloatField('Saturacion de O2 -  miembro superior al nacimiento',widget=NumberInput(),default=1.0,
        validators=[NumberRange(0, 1E+20)])
    satO2_miembroSup24 = FloatField('Saturacion de O2 - miembro superior al nacimiento 24 horas',widget=NumberInput(),default=1.0,
        validators=[NumberRange(0, 1E+20)])
    satO2_miembroSup72 = FloatField('Saturacion de O2 - miembro superior al nacimiento 72 horas',widget=NumberInput(),default=1.0,
        validators=[NumberRange(0, 1E+20)])
    satO2_miembroInf = FloatField('Saturacion de O2 - miembro inferior al nacimiento',widget=NumberInput(),default=1.0,
        validators=[NumberRange(0, 1E+20)])
    satO2_miembroInf24 = FloatField('Saturacion de O2 - miembro inferior al nacimiento  24 horas',widget=NumberInput(),default=1.0,
        validators=[NumberRange(0, 1E+20)])
但是,当我试图保存表单中的数据时,出现了一个错误,它说我应该引入一个有效值:

我已经添加了以下方法:

class CommaFloatField(FloatField):
    """
    Subclass that handles floats of this format 1.2 or 1,2.
    """

    def process_formdata(self, valuelist):
        if valuelist:
            try:
                self.data = float(valuelist[0].replace(",", "."))
            except ValueError:
                self.data = None
                raise ValueError(self.gettext('Not a valid float value'))
但我不能保存任何浮点值 我真的非常感谢你的帮助!
提前谢谢大家

您看到的是浏览器错误。如果您使用的是Chrome,您应该知道句点“.”用作小数点,而不是逗号

您可以在表单中设置
novalidate
attr以避免浏览器验证