Python之JSON库中序列化和反序列化常用方法

1、为什么需要序列化与反序列化

我们知道,当两个进程进行网络通信时,可以相互发送各种类型的数据,包括文本、图片、音频、视频等, 而这些数据都会以二进制序列的形式在网络上传送。不能直接传输Python对象。

那么当两个进程进行通信时,能否实现进程间的对象传送呢?答案是可以的!如何做到呢?这就需要序列化与反序列化了!

换句话说,一方面,发送方需要把这个Python对象转换为字节序列,然后在网络上传送,这就是序列化;另一方面,接收方需要从字节序列中恢复为Python对象,这就是反序列化。

当我们明晰了为什么需要序列化和反序列化后,我们很自然地会想序列化的好处。其好处一是实现了数据的持久化,通过序列化才可以把数据永久地保存到硬盘上(通常存放在文件里),二是,利用序列化实现远程通信,即在网络上传送对象的字节序列。

总的来说可以归结为以下几点:

(1)永久性保存对象,保存对象的字节序列到本地文件或者数据库中;
(2)通过序列化以字节流的形式使对象在网络中进行传递和接收;
(3)通过序列化在进程间传递对象;
———————
序列化(serialization):数据转换成二进制的有序的过程,把内存中数据保存到文件中。文件是一个字节序列,所以必须把数据转换成字节序列,输出到文件。这就是序列化

反序列化(deserialization):将有序的二进制序列转换成某种对象(字典,列表等)称为反序列化。例如将文件的一个个字节恢复成内存中对象。

持久化:序列化保存到文件就是持久化,序列化未必会持久化,序列化往往是传输或存储。可以将数据序列化后持久化,或者网络传输,也可以将从文件或网络接受到的字节序列反序列化。
————————————————
Python中序列化和反序列化常用方法
dumps,转换成二进制序列,序列化
dump,转换成二进制序列后存入文件,序列化
loads,将二进制序列转化为原来模式,反序列化
load,将文件转换成原来模式,反序列化
一、JSON是什么
JSON 是用于存储和交换数据的语法。JSON (JavaScript Object Notation)最初是用 JavaScript 对象表示法编写的文本,但随后成为了一种常见格式,被包括Python在内的众多语言采用。

1、json库的一些方法

json.dumps()	将python对象编码成Json字符串
json.loads()	将Json字符串解码成python对象
json.dump()	将python中的对象转化成json储存到文件中
json.load()	将文件中的json的格式转化成python对象提取出来
二、json.dump()和json.dumps()的区别
json.dumps()是把python对象转换成json对象的一个过程,生成的是字符串。(把字典转为字符串)
json.dump()是把python对象转换成json对象生成一个fp的文件流,和文件相关。

1.json.dumps()
在使用json方法的时候要记住先引进这个库,用import json

import json

x = {'name':'你猜','age':19,'city':'四川'}

#用dumps将字典对象转换成json字符串
print(json.dumps(x))

这里我用的中文,我觉得看差别就比较大。
然后就可以得到:

{"name": "\u4f60\u731c", "age": 19, "city": "\u56db\u5ddd"}

这里就还有一个区别,注意我上面python字符串专门用的单引号,转化以后,json就用的是双引号了。


2.json.dump()
这个方法结合了文件的操作,把转换后的json储存在了文件里。

import json

x = {'name':'你猜','age':19,'city':'四川'}

#讲python编码成json放在那个文件里
filename = 'pi_x.txt'
with open (filename,'w') as f:
    json.dump(x,f)

然后我们打开文件,就能看到编码后储存进去的json码:

 

3.dumps的一些参数(重点)
因为dumps编码以后的json格式输出比较的紧凑,如果不止一行看起来就不是特别好看,就像一堆乱码似的。所以,就推出了一些可选参数来让json码的可读性更高。当然,不用,就像我上面那样子也是OK滴。
参数如下:
json.dumps(obj, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, encoding="utf-8", default=None, sort_keys=False, **kw)



obj:就是你要转化成json的对象。
sort_keys =True:是告诉编码器按照字典排序(a到z)输出。如果是字典类型的python对象,就把关键字按照字典排序。

indent:参数根据数据格式缩进显示,读起来更加清晰。

ensure_ascii=True:默认输出ASCLL码,如果把这个该成False,就可以输出中文。


import json

x = {'name':'你猜','age':19,'city':'四川'}

#用dumps将python编码成json字符串
y = json.dumps(x)
print(y)

z = json.dumps(x, indent=2)
print(z)

输出:
{"name": "\u4f60\u731c", "age": 19, "city": "\u56db\u5ddd"}
{
  "name": "\u4f60\u731c",
  "age": 19,
  "city": "\u56db\u5ddd"
}
三、json.load()和json.loads()的区别
json.loads()是针对字节流,将string转换为dict。
json.load()针对文件,将json格式的字符转换为dict,从文件中读取 (将string转换为dict)

import json

x = {'name':'你猜','age':19,'city':'四川'}

#用dumps将python编码成json字符串
x = json.dumps(x)
print(x)

#用loads将json编码成python
print(json.loads(x))

输出:

{"name": "\u4f60\u731c", "age": 19, "city": "\u56db\u5ddd"}
{'name': '你猜', 'age': 19, 'city': '四川'}
# json.load()
import json

x = {'name':'你猜','age':19,'city':'四川'}

filename = 'pi_x.txt'
with open (filename,'w') as f:
    json.dump(x,f)
with open (filename) as f_1:
    print(json.load(f_1))

输出:

{'name': '你猜', 'age': 19, 'city': '四川'}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值