Python3.5中Json与pickle如何实现数据序列化与反序列化操作
导读:本文共1680.5字符,通常情况下阅读需要6分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要: 具体如下:1、Json:不同语言之间进行数据交互。(1)JSON数据序列化:dumps()JSON数据是一种轻量级的数据交换格式,序列化:将内存数据对象变成字符串。#!/usr/bin/envpython#-*-coding:utf-8-*-#Author:ZhengzhengLiuimportjsoninfo={"name":&q... ...
目录
(为您整理了一些要点),点击可以直达。具体如下:
1、Json:不同语言之间进行数据交互。
(1)JSON数据序列化:dumps()
JSON数据是一种轻量级的数据交换格式,序列化:将内存数据对象变成字符串。
#!/usr/bin/envpython#-*-coding:utf-8-*-#Author:ZhengzhengLiuimportjsoninfo={"name":"liu","age":25,"sex":"girl"}f=open("test.txt","w")print(json.dumps(info))f.write(json.dumps(info))f.close()
运行结果如下图:
(2)JSON数据反序列化:loads()
#!/usr/bin/envpython#-*-coding:utf-8-*-#Author:ZhengzhengLiuimportjsonf=open("test.txt","r")data=json.loads(f.read())print(data['age'])
运行结果 :
25
(3)Json序列化——多次dumps;反序列化——不能实现多次loads
#!/usr/bin/envpython#-*-coding:utf-8-*-#Author:ZhengzhengLiuimportjsoninfo={"name":"liu","age":32}f=open("test.txt","w")f.write(json.dumps(info))#序列化info["age"]=21f.write(json.dumps(info))f.close()
运行结果:
总结:Json只能处理一些简单的数据类型,如:列表、字典。字符串等。XML正在被Json逐步取代。
Json以后使用只dumps一次,loads一次即可。
2、pickle:通过pickle模块的序列化操作我们能够将程序中运行的对象信息保存到文件中去,永久存储;
通过pickle模块的反序列化操作,我们能够从文件中创建上一次程序保存的对象。
只能在Python语言中用,不能用于其他的语言。
(1)pickle数据序列化:
#!/usr/bin/envpython#-*-coding:utf-8-*-#Author:ZhengzhengLiuimportpickledefsayhi(name):print("hello",name)info={"name":"liu","age":32,"func":sayhi}f=open("test.txt","wb")print()f.write(pickle.dumps(info))f.close()
运行结果如下图:
(2)pickle数据反序列化:
#!/usr/bin/envpython#-*-coding:utf-8-*-#Author:ZhengzhengLiuimportpickledefsayhi(name):print("hello",name)f=open("test.txt","rb")data=pickle.loads(f.read())print(data["func"]("liu"))
运行结果:
hello liu
None
</div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
Python3.5中Json与pickle如何实现数据序列化与反序列化操作的详细内容,希望对您有所帮助,信息来源于网络。