flask 转 java_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 '' % 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()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值