博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python 序列化(JSON)
阅读量:4216 次
发布时间:2019-05-26

本文共 877 字,大约阅读时间需要 2 分钟。

参考廖雪峰:

JSON的序列化和反序列化:
可选参数
default
就是把任意一个对象变成一个可序列为JSON的对象,我们只需要为
Student
专门写一个转换函数,再把函数传进去即可:
不过,下次如果遇到一个Teacher类的实例,照样无法序列化为JSON。我们可以偷个懒,把任意class的实例变为dict
print(json.dumps(s, default=lambda obj: obj.__dict__))#写成这样也是可以的(个别不含有内置__dict__的不可以)
import jsondef stu2dict(std):#Student实例首先被student2dict()函数转换成dict,然后再被顺利序列化为JSON:    return {        'name':std.name,        'age':std.age,        'score':std.score    }def dict2stu(d):#反序列化辅助函数    return Student(d['name'],d['age'],d['score'])class Student(object):    def __init__(self,name,age,score):        self.name = name        self.age = age        self.score = scores = Student('Bob',20,88)print(json.dumps(s,default=stu2dict))json_str = '{"age": 20, "score": 88, "name": "Bob"}'#如果我们要把JSON反序列化为一个Student对象实例,loads()方法首先转换出一个dict对象,# 然后,我们传入的object_hook函数负责把dict转换为Student实例:print(json.loads(json_str,object_hook=dict2stu))

转载地址:http://xhimi.baihongyu.com/

你可能感兴趣的文章
中断API之__tasklet_schedule
查看>>
中断API之enable_irq
查看>>
中断API之disable_irq
查看>>
nova 中的guestfs
查看>>
nova中的localfs
查看>>
utils/rpm_build.sh
查看>>
查看模块参数
查看>>
udev重命名网口
查看>>
pgrep
查看>>
test-definitions/blob/master/toolset/util/parallel_cmds.py
查看>>
中断API之irq_activate
查看>>
中断API之tasklet_disable_nosync/tasklet_trylock/tasklet_unlock
查看>>
中断API之tasklet_init/tasklet_kill
查看>>
内存管理API之__free_pages
查看>>
内存管理API之__get_free_pages
查看>>
内存管理API之__get_vm_area
查看>>
内存管理API之krealloc
查看>>
内存管理API之ksize
查看>>
内存管理API之alloc_pages
查看>>
linux performance tool
查看>>