Python 官方文档:入门教程 => 点击学习
小编给大家分享一下python JSON中load和loads区别有哪些,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一、相同点dump 和 dumps 都实现了序列化load 和 loads 都实现反序列化变量从内存中变
小编给大家分享一下python JSON中load和loads区别有哪些,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
dump
和 dumps
都实现了序列化
load
和 loads
都实现反序列化
变量从内存中变成可存储或传输的过程称之为序列化序列化是将对象状态转化为可保存或可传输格式的过程。
变量内容从序列化的对象重新读到内存里称之为反序列化反序列化是流转换为对象。
load:针对文件句柄,将json
格式的字符转换为dict
,从文件中读取 (将string
转换为dict
)
a_json = json.load(open('demo.json','r'))
loads:针对内存对象,将string
转换为dict
(将string转换为dict)
a = json.loads('{'a':'1111','b':'2222'}')
dump:将dict类型转换为json
字符串格式,写入到文件 (易存储)
a_dict = {'a':'1111','b':'2222'}json.dump(a_dict, open('demo.json', 'w')
dumps:将dict转换为string
(易传输)
a_dict = {'a':'1111','b':'2222'}a_str = json.dumps(a_dict)
总结:
根据序列化和反序列的特性
loads: 是将string
转换为dict
dumps: 是将dict
转换为string
load: 是将里json
格式字符串转化为dict
,读取文件
dump: 是将dict
类型转换为json
格式字符串,存入文件
# 使用class对象的__dict__方法class Student(object): def __init__(self, name, age, score): self.name = name self.age = age self.score = scoreimport jsons = Student('Bob', 20, 88)print(json.dumps(s, default=lambda obj: obj.__dict__))
#Python学习交流群:531509025def dict2student(d): return Student(d['name'], d['age'], d['score'])json_str = '{"age": 20, "score": 88, "name": "Bob"}'print(json.loads(json_str, object_hook=dict2student))
Python
提供两个模块来实现序列化:cPickle
和pickle
。这两个模块功能是一样的,区别在于cPickle
是C语言写的,速度快,pickle
是纯Python
写的,速度慢。
变量从内存中变成可存储或传输的过程称之为序列化,在Python
中叫pickling
变量内容从序列化的对象重新读到内存里称之为反序列化,即unpickling
try: import cPickle as pickleexcept ImportError: import pickle
a = dict(a=1, b=2, c=3)pickle.dumps(a) # 将对象序列化为str然后存入文件a = dict(a=1, b=2, c=3)pickle.dump(a, open('a.txt', 'wb')) # 使用dump直接把对象序列化为file-like Object,注意是二进制存储
pickle.load(open('a.txt', 'rb')) #从file-like Object中直接反序列化出对象
看完了这篇文章,相信你对“Python json中load和loads区别有哪些”有了一定的了解,如果想了解更多相关知识,欢迎关注编程网Python频道,感谢各位的阅读!
--结束END--
本文标题: Python json中load和loads区别有哪些
本文链接: https://www.lsjlt.com/news/304991.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0