Python3 json模块之编码解码方法讲解

作者:WDC 时间:2021-07-15 17:29:15 

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它基于ECMAScript的一个子集。 JSON采用完全独立于语言的文本格式,这些特性使JSON成为理想的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成,在接口数据开发和传输中非常常用。

Python3中我们利用内置模块json解码和编码JSON对象。json模块提供了四个功能:

dumpsdumploadsload

dumps 把数据类型转换成字符串 

dump  把数据类型转换成字符串并存储在文件中

loads 把字符串转换成数据类型  

load  把文件打开从字符串转换成数据类型

dumps编码

我们利用 dumps 将Python对象编码为 JSON对象 ,当然 dumps 只完成了序列化为str,而 dump 必须传文件描述符,将序列化的str保存到文件中。

编码字典


import json
odata = {'www': 1, 'jb51.net': 2, 'Python3': 3}
jdata = json.dumps(odata)
print(jdata)

示例结果:

{"www": 1, "jb51.net": 2, "Python3": 3}

编码列表


import json
ldata = [100, 'Python2', {'www': 1, 'jb51.net': 2, 'Python3': 3}]
jdata = json.dumps(ldata)
print(jdata)

示例结果:

[100, "Python3", {"www": 1, "jb51.net": 2, "Python3": 3}]

编码字符串


import json
sdata = 'Python3'
jdata = json.dumps(sdata)
print(jdata)

示例结果:

"Python3"

格式化输出JSON

将下面的数组,转化为标准的json格式


import json
ldata = ['Python3', 100, {'www': 1, 'jb51.net': 2, 'Python3': 3}, True]
jdata = json.dumps(ldata, sort_keys=True, indent=4)
print(jdata)

示例结果:


[
"Python3",
100,
{
 "Python3": 3,
 "jb51.net": 2,
 "www": 1
},
true
]

参数解析: 

sort_keys=True 那么字典的输出会以键的顺序排序

indent=4 表示缩进为4,如果 indent 是一个非负整数或者字符串,那么 JSON 数组元素和对象成员会被美化输出为该值指定的缩进等级。

转换关系对照表

下面为Python原始类型向JSON对象的转化对照表:

PythonJSON
dictobject
list, tuplearray
str, unicodestring
int, long, floatnumber
Truetrue
Falsefalse
Nonenull

loads解码

我们利用 loads 用于解码 JSON对象 。解码结果即与之对应的 Python对象 类型。当然 loads 只完成了反序列化, load 只接收文件描述符,完成读取文件和反序列化。

比如我们用来解码上个示例的数据


import json
jsondata = '''
[
"Python3",
100,
{
 "Python3": 3,
 "jb51.net": 2,
 "www": 1
},
true
]
'''
ldata = json.loads(jsondata)
print(type(ldata))
print(ldata)

示例结果:

<class 'list'>

['Python3', 100, {'Python3': 3, 'jb51.net': 2, 'www': 1}, True]

可以看到我们成功对上个例子中的JSON对象进行了解码,并且最终的解码结果为Python列表对象类型,符合Python对象JSON对象对照表的结果。

总结

Python3中的json解析和编码模块json使用起来非常简单, 功能也非常齐全,完全能够满足我们日常的需求。更多关于Python json模块解析和编码的文章请点击下面的相关链接

标签:Python,json
0
投稿

猜你喜欢

  • Mysql自增主键id不是以此逐级递增的处理

    2024-01-19 03:07:55
  • Python破解网站登录密码脚本

    2022-09-29 23:21:38
  • asp实现新评论自动发短信提示的代码

    2011-03-07 10:38:00
  • 用SQL统计SQLServe表存储空间大小的代码

    2012-06-06 19:52:22
  • python解析库Beautiful Soup安装的详细步骤

    2023-06-23 04:29:21
  • 识别操作系统是不是vista的js代码

    2013-10-20 19:08:25
  • Python 内置高阶函数详细

    2022-07-26 11:02:07
  • 解决pandas read_csv 读取中文列标题文件报错的问题

    2023-04-16 06:54:37
  • python下os模块强大的重命名方法renames详解

    2021-05-12 17:19:34
  • php获取referer防非法访问

    2023-08-20 11:30:58
  • JavaScript获取一个范围内日期的方法

    2024-04-28 09:50:33
  • Python实现读取txt文件并画三维图简单代码示例

    2023-06-11 15:44:18
  • Scrapy-Redis结合POST请求获取数据的方法示例

    2023-08-25 06:31:56
  • 判断数据库表是否存在以及修改表名的方法

    2024-01-22 09:21:24
  • Pytorch平均池化nn.AvgPool2d()使用方法实例

    2023-09-30 02:49:35
  • mysql 8.0.22 winx64安装配置方法图文教程

    2024-01-16 01:03:20
  • Python远程视频监控程序的实例代码

    2021-02-08 14:26:22
  • 使用cx_freeze把python打包exe示例

    2021-06-10 05:36:20
  • Sql 批量查看字符所在的表及字段

    2024-01-15 02:53:36
  • AJAX初体验之上手篇

    2007-08-23 08:50:00
  • asp之家 网络编程 m.aspxhome.com