Python json.load/loads以及json.dump/dumps有什么区别?

2024-01-19 18:08

本文主要是介绍Python json.load/loads以及json.dump/dumps有什么区别?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

序列化

序列化(Serialization)是将对象的状态信息转换为可以存储或传输的形式的过程。在序列化期间,对象将其当前状态写入带临时性或持久性存储区。之后,可以通过从存储区读取或者反序列化对象的状态,重建该对象。
序列化可以使其他代码可以查看或者修改,那些不序列化便无法访问的对象实例数据。

简单而言:

  • 序列化:将对象转换为字节序列的过程
  • 反序列化:将字节恢复为对象的过程

网络传输是一种常见的数据传输场景,在传输前,我们先将编程语言对象序列化为json/xml文件;在传输后,在将json/xml文件反序列化为对应语言的对象。

为什么要进行序列化?

  • 序列化之后的对象可以从内存存储到硬盘中(即实现持久化)
  • 通过序列化可以在进程间传递对象
  • 序列化以后的字节流可以进行网络传输(二进制形式,具备保真性)

特别指出一点,在不同语言之间的对象传递能进一步凸显序列化的重要,比如客户端使用Java或者OC,服务端使用Go/Python,这种场景下编程语言都不同,你把Java的HashMap传递给Python或者Go处理毫无意义,但可以序列化之后以字节流传输,再反序列化为Python的字典或者Go的结构体,这样同样的信息就能够在不同编程语言之间传递。

所以序列化能在不同编程语言,不同主机的进程之间传递对象

有了以上背景知识之后我们再来看这个标题的问题。

json.load/loads以及json.dump/dumps有什么区别?

json.load/loadsjson.dump/dumps都来自json包,它们都是用来处理json格式的数据,也即序列化和反序列化的。

具体的讲:

  • json.dump/dumps函数将一个Python字典进行json格式的编码(即序列化,将Python字典转换成了json格式的字符串)
    -json.load/loads函数将一个json格式数据转换为字典(即反序列化,将json格式的字符串转换为Python字典)

那英文单复数形式之间又有什么区别呢?

  • 加了s的,都是直接处理流式数据,例如网络传输的场景下,使用requests的get或者post方法时,传入json格式数据使用的是json.dumps,拿到请求的返回后,将返回里面的json数据转化为字典使用的是json.loads。
  • 不加s的,处理的是文件类型的数据,例如要加Python字典存储到json类型的文件中(即持久化),则需要使用json.dump(json_object, file_object),而将json文件中的数据读取为Python能直接处理的字典类型,则需要使用json.load(file_object)

参考文献

序列化和反序列化的详解

这篇关于Python json.load/loads以及json.dump/dumps有什么区别?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/623231

相关文章

hevc和H.264格式的区别

HEVC(High Efficiency Video Coding)和H.264(也称为Advanced Video Coding,AVC)都是视频压缩标准,但它们之间存在一些显著的区别,主要集中在压缩效率、资源需求和兼容性方面。 压缩效率 HEVC,也被称为H.265,提供了比H.264更高的压缩效率。这意味着在相同的视频质量下,HEVC能够以大约一半的比特率进行编码,从而减少存储空间需求和

Java面试题:通过实例说明内连接、左外连接和右外连接的区别

在 SQL 中,连接(JOIN)用于在多个表之间组合行。最常用的连接类型是内连接(INNER JOIN)、左外连接(LEFT OUTER JOIN)和右外连接(RIGHT OUTER JOIN)。它们的主要区别在于它们如何处理表之间的匹配和不匹配行。下面是每种连接的详细说明和示例。 表示例 假设有两个表:Customers 和 Orders。 Customers CustomerIDCus

Python 字符串占位

在Python中,可以使用字符串的格式化方法来实现字符串的占位。常见的方法有百分号操作符 % 以及 str.format() 方法 百分号操作符 % name = "张三"age = 20message = "我叫%s,今年%d岁。" % (name, age)print(message) # 我叫张三,今年20岁。 str.format() 方法 name = "张三"age

Eclipse+ADT与Android Studio开发的区别

下文的EA指Eclipse+ADT,AS就是指Android Studio。 就编写界面布局来说AS可以边开发边预览(所见即所得,以及多个屏幕预览),这个优势比较大。AS运行时占的内存比EA的要小。AS创建项目时要创建gradle项目框架,so,创建项目时AS比较慢。android studio基于gradle构建项目,你无法同时集中管理和维护多个项目的源码,而eclipse ADT可以同时打开

一道经典Python程序样例带你飞速掌握Python的字典和列表

Python中的列表(list)和字典(dict)是两种常用的数据结构,它们在数据组织和存储方面有很大的不同。 列表(List) 列表是Python中的一种有序集合,可以随时添加和删除其中的元素。列表中的元素可以是任何数据类型,包括数字、字符串、其他列表等。列表使用方括号[]表示,元素之间用逗号,分隔。 定义和使用 # 定义一个列表 fruits = ['apple', 'banana

Python应用开发——30天学习Streamlit Python包进行APP的构建(9)

st.area_chart 显示区域图。 这是围绕 st.altair_chart 的语法糖。主要区别在于该命令使用数据自身的列和指数来计算图表的 Altair 规格。因此,在许多 "只需绘制此图 "的情况下,该命令更易于使用,但可定制性较差。 如果 st.area_chart 无法正确猜测数据规格,请尝试使用 st.altair_chart 指定所需的图表。 Function signa

python实现最简单循环神经网络(RNNs)

Recurrent Neural Networks(RNNs) 的模型: 上图中红色部分是输入向量。文本、单词、数据都是输入,在网络里都以向量的形式进行表示。 绿色部分是隐藏向量。是加工处理过程。 蓝色部分是输出向量。 python代码表示如下: rnn = RNN()y = rnn.step(x) # x为输入向量,y为输出向量 RNNs神经网络由神经元组成, python

python 喷泉码

因为要完成毕业设计,毕业设计做的是数据分发与传输的东西。在网络中数据容易丢失,所以我用fountain code做所发送数据包的数据恢复。fountain code属于有限域编码的一部分,有很广泛的应用。 我们日常生活中使用的二维码,就用到foutain code做数据恢复。你遮住二维码的四分之一,用手机的相机也照样能识别。你遮住的四分之一就相当于丢失的数据包。 为了实现并理解foutain

python 点滴学

1 python 里面tuple是无法改变的 tuple = (1,),计算tuple里面只有一个元素,也要加上逗号 2  1 毕业论文改 2 leetcode第一题做出来

Python爬虫-贝壳新房

前言 本文是该专栏的第32篇,后面会持续分享python爬虫干货知识,记得关注。 本文以某房网为例,如下图所示,采集对应城市的新房房源数据。具体实现思路和详细逻辑,笔者将在正文结合完整代码进行详细介绍。接下来,跟着笔者直接往下看正文详细内容。(附带完整代码) 正文 地址:aHR0cHM6Ly93aC5mYW5nLmtlLmNvbS9sb3VwYW4v 目标:采集对应城市的