Flask-sqlalchemy 转JSON

目前Flask-sqlalchemy查询出来的值 一般是对象或者数组包着对象,如果想转json还很麻烦,目前有一种方法。

在Models里添加to_json()方法:

class Test(db.Model):
    __tablename__ = 'test'
    id = db.Column(db.INT, primary_key=True)
    a1 = db.Column(db.String(40), unique=False,nullable=False)
    a2 = db.Column(db.String(200), unique=False,nullable=False)
    a3 = db.Column(db.DECIMAL(16,2), unique=False, nullable=False, default=0)
    a4 = db.Column(db.DECIMAL(16,2), unique=False, nullable=False, default=0)
    a5 = db.Column(db.DECIMAL(16,2), unique=False, nullable=False, default=0)
    def __init__(self, a1, a2):
        self.a1 = a1
        self.a2 = a2
    def to_json(self):
        json_data = {
            'id': self.id,
            'a1': self.a1,
            'a2': self.a2,
            'a3': self.a3,
            'a4': self.a4,
            'a5': self.a5
        }
        return json.dumps(json_data,cls=DateEncoder)
    def __repr__(self):
        return '<Test %r>' % self.id

如果有类型问题还需要类型转换的类DateEncoder:

class DateEncoder(json.JSONEncoder):
    def default(self,obj):
        if isinstance(obj, datetime.datetime):
            return obj.strftime(DATETIME)
        elif isinstance(obj,datetime.date):
            return obj.strftime(DATE)
        elif isinstance(obj,Decimal):
            return str(obj)
        else:
            return json.JSONEncoder.default(self,obj)

调用:

data = Test.query.first()

return data.to_json()

 

转载于:https://my.oschina.net/ilovetao/blog/2248807

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值