python3序列化_python3 json序列化问题

问题:

python3中使用json.dumps(dicts)序列化字典时,如果字典中含有自定义的项时报错:TypeError: Object of type 'bytes' is not JSON serializable。

发现字典中含有bytes类型的数据,所以序列化失败。

后来查阅相关资料才发现,默认的编码函数很多数据类型都不能编码,因此可以自己写一个encoder去继承jsonencoder ,这样就能够进行编码了。

比如说上面的这个问题,是因为json.dumps函数发现字典里面有bytes类型的数据,因此无法编码,只要在编码函数之前写一个编码类就行了,只要检查到了是bytes类型的数据就把它转化成str类型。

解决方法:

在编码函数之前写一个编码类,只要检查到了是bytes类型的数据就把它转化成str类型。

class MyEncoder(json.JSONEncoder):

def default(self, obj):

"""

只要检查到了是bytes类型的数据就把它转为str类型

:param obj:

:return:

"""

if isinstance(obj, bytes):

return str(obj, encoding='utf-8')

return json.JSONEncoder.default(self, obj)

将字典进行序列化时使用如下方法:

data = json.dumps(data,cls=MyEndoder)

或者将上述类写进一个文件中MyEncoder.py中在其他文件需要使用时进行引入即可:

from MyEncoder import MyEncoder

data = json.dumps(data,cls=MyEndoder)

问题延伸:

后面在编码的时候发现出现类似问题:

TypeError: Object of type 'ndarray' is not JSON serializable

这样也是一样的处理方式,当检查到了ndarray数据,把它转化成list数据就行:

class MyEncoder(json.JSONEncoder):

def default(self, obj):

if isinstance(obj, np.ndarray):

return obj.tolist()

elif isinstance(obj, bytes):

return str(obj, encoding='utf-8');

return json.JSONEncoder.default(self, obj)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值