TypeError: Object of type *** is not JSON serializable

这是建立在连接数据库成功的基础上

文件结构

--m_use.py

--user.py

m_use.py

以下是m_use.py文件的主要的一部分,不完整,

from flask_sqlalchemy import SQLAlchemy

db = SQLAlchemy()

class U12(db.Model):

__table_args__ = {'extend_existing': True}

__table__ =db.Table('usser1234',db.metadata,db.Column('id',db.String(11), primary_key=True),

db.Column('country', db.String(20), default=None, nullable=False, comment="国家"),

db.Column('name', db.String(20), default=None, nullable=False, comment="用户姓名"),

db.Column('phone', db.String(20), default=None, nullable=False, comment="电话"))

def find_all_user(self):

result = db.session.query(self).all()

return result

user.py

#以下是user.py文件的一部分,不完整

from module.m_users import U12

@user.route('/user')

def user_demo():

result = U12.find_all_user(U12)

return result #这是出错点 1

当你浏览器的地址栏中输入http://127.0.0.1:5000/user会出现这个错误

是因为1

返回值得形式不是json要求的数据形式(列表),

json数据形式:

[{},{},{},{}]

{[ ],[ ],[ ],[ ]}

{{},{},{},{}}

解决方案:新建一个model_list函数,用来处理查询结果,将其变为JSON要求的数据形式

def model_list(result):

list = []

for row in result:

dict = {}

for k,v in row.__dict__.items():

if not k.startswith('_sa_instance_state'):

dict[k] = v

list.append(dict)

return list

将user_demo函数变为如下形式

@user.route('/user')

def user_demo():

result = U12.find_all_user(U12)

list = model_list(result)

return list

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值