python3 json序列化问题
Posted 小学生运维
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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)
以上是关于python3 json序列化问题的主要内容,如果未能解决你的问题,请参考以下文章