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
    评论
### 回答1: 这是一个类型错误,意思是datetime类型的对象无法被序列化为JSON格式。可能是因为你正在尝试将一个datetime对象转换为JSON字符串,但是datetime对象不是JSON可序列化的数据类型。你可以尝试将datetime对象转换为字符串或使用其他可序列化的数据类型来代替。 ### 回答2: "typeerror: object of type datetime is not json serializable" 的错误提示表示无法将datetime类型的对象转化为JSON可序列化的格式。这通常在使用json序列化时出现。 要解决这个问题,我们可以通过以下步骤来处理: 1. 首先,我们需要了解为什么datetime对象无法被JSON序列化。JSON标准规定,只有以下几种数据类型可以被序列化为JSON格式:字符串、数字、布尔值、数组、对象和null。datetime对象不在这些数据类型之内,因此不能直接被序列化。 2. 解决方法是将datetime对象转化为字符串或者其他可以被JSON序列化的数据类型。常用的方法是将datetime对象转化为字符串,可以使用strftime()方法来指定日期时间的格式,将datetime对象格式化成字符串。 3. 在序列化之前,将需要转化的datetime对象先进行格式化,然后再序列化为JSON字符串。序列化的过程可以使用json.dumps()函数进行。 例如,如果我们有一个包含datetime对象的字典data,我们可以使用下面的代码进行处理: ```python import json import datetime data = {'date': datetime.datetime.now()} # 将datetime对象转化为字符串 data['date'] = data['date'].strftime('%Y-%m-%d %H:%M:%S') # 序列化为JSON字符串 json_data = json.dumps(data) ``` 以上代码将datetime对象转化为了字符串,并成功将字典data序列化为了JSON字符串json_data,避免了"typeerror: object of type datetime is not json serializable" 的错误。 希望上述解答能对您有所帮助!如果还有其他疑问,请随时提问。 ### 回答3: 这个错误是因为尝试将datetime对象转换为JSON格式时发生了错误。在Python中,datetime对象不是JSON可序列化的对象类型。 为了解决这个问题,我们可以将datetime对象转换为其它可以被JSON序列化的类型,例如将其转换为字符串: ```python import json from datetime import datetime now = datetime.now() serialized_time = now.strftime("%Y-%m-%d %H:%M:%S") json_data = json.dumps({"time": serialized_time}) print(json_data) ``` 在上述例子中,我们使用了`strftime`函数将datetime对象转换为字符串,并将其放在一个字典中,然后使用`json.dumps`函数将字典转换为JSON格式的字符串。 另外,如果你需要将JSON数据中的时间字段反序列化为datetime对象,可以使用`strptime`函数将字符串转换为datetime对象: ```python import json from datetime import datetime json_data = '{"time": "2022-01-01 12:00:00"}' data = json.loads(json_data) serialized_time = data["time"] datetime_obj = datetime.strptime(serialized_time, "%Y-%m-%d %H:%M:%S") print(datetime_obj) ``` 在上述例子中,我们使用了`json.loads`函数将JSON格式的字符串转换为字典,然后使用`strptime`函数将时间字段的字符串值转换为datetime对象。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值