Почему «Объект типа Decimal не сериализуем в JSON» - при использовании зефира с автоматом SQLAlchemy? - PullRequest
1 голос
/ 12 июня 2019

Использование automap_base из sqlalchemy.ext.automap для сопоставления моих таблиц. Не в состоянии shema.dumps(result);

получение

raise TypeError(f'Object of type {o.__class__.__name__} '
TypeError: Object of type Decimal is not JSON serializable

Пробовал с использованием пользовательских декодеров JSON, но безрезультатно.

from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from sqlalchemy.orm import Session
from sqlalchemy.ext.automap import automap_base
from flask_marshmallow import Marshmallow

app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///database.db'

db = SQLAlchemy(app)
ma = Marshmallow(app)

engine = db.engine
session = Session(engine)

Base = automap_base()
Base.prepare(engine, reflect=True)

MyTable = Base.classes.my_table

class MyTableSchema(ma.ModelSchema):
    class Meta:
        model = MyTable

@app.route("/")
def api():
    all_rows = session.query(MyTable).all()
    schema = MyTableSchema(many=True)
    response = schema.dumps(all_rows)

    return response

if __name__ == '__main__':
    app.run(debug=True)

...