колба-зефир сбрасывая десятичную точку - PullRequest
0 голосов
/ 23 июня 2019

Я использую flask-marshmallow и flask-sqlalchemy, и я хочу сериализовать набор данных, который содержит числовое поле, все значения имеют десятичные разряды, т.е. 2,5, но когда зефир выводит его в json, он обрезает десятичный разряд(изменяется с 2,5 на 2) где я ошибаюсь?

ma.py

from flask_marshmallow import Marshmallow

ma = Marshmallow()

app.py

import ma
import db
from flask_restful import Api
.....
api = Api(app)

api.add_resource(LookupActivities, '/lookup_activity_by_type/<string:activity_type>')

if __name__ == "__main__":
    db.init_app(app)
    ma.init_app(app)
    app.run(port=5000, debug=True)

model / lookup.py

from db import db

class LookupModel(db.Model):
    __tablename__ = "asmirt_cpd_point_lookup"
    __table_args__ = {"schema": "radcpd"}

    asmirt_activity_id = db.Column(db.Integer, primary_key=True)
    activity_type = db.Column(db.String(255))
    activity = db.Column(db.String(255))
    alt_text = db.Column(db.String(255))
    activity_points = db.Column(db.Integer)
    per_unit = db.Column(db.String(255))

    @classmethod
    def find_by_activity_type(cls, activity_type: str):
        return cls.query.filter_by(activity_type=activity_type).all()

schema / lookup.py

from ma import ma
from models.lookup import LookupModel


class LookupSchema(ma.ModelSchema):
    class Meta:
        model = LookupModel
        dump_only = ("asmirt_activity_id",)

resource / lookup.py

from flask_restful import Resource
from models.lookup import LookupModel
from schemas.lookup import LookupSchema
from flask_jwt_extended import jwt_required
from flask import jsonify

class LookupActivities(Resource):
    @classmethod
    def get(cls, activity_type):
        data = LookupModel.find_by_activity_type(activity_type=activity_type)
        print(data)
        print(data[1].activity)
        if data:
            return {"activities": lookup_schema_list.dump(data)}, 200

        return {'message', 'No activities in that group'}

В этом примере он изменит значение 2,5 в базе данных, но выведет 2.В других примерах я получу сообщение об ошибке Object Decimal не сериализуемо.Кто-нибудь знает, что вызывает это и как это исправить?

1 Ответ

1 голос
/ 23 июня 2019

Столбцы вашей модели не имеют десятичной декларации.Я предполагаю, что вы пытаетесь вставить / получить десятичные данные в / из целочисленных объявленных столбцов.Попробуйте объявить столбец как десятичный.

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