Python- JSON使用初探
JSON
在JSON格式中,{} 和 [] 是两种主要的数据结构,分别表示对象(或称为字典、哈希、map)和数组(或称为列表、序列)。
-
{} - 对象
在JSON中,对象是一组
"key": value对的集合。这些键必须是字符串,而值可以是有效的JSON数据类型(字符串、数字、对象、数组、true、false或null)。示例:
{"name": "John","age": 30,"is_student": false }这个JSON对象有三个键值对:
"name","age", 和"is_student"。 -
[] - 数组
在JSON中,数组是有序的值的集合。这些值可以是任何有效的JSON数据类型。
示例:
["apple", "banana", "cherry"]这个JSON数组有三个字符串值。
数组中的值也可以是对象或其他数组,这样可以创建复杂的嵌套结构。例如:
[{"name": "John","age": 30},{"name": "Jane","age": 25} ]在这个例子中,JSON数组包含两个对象。
总结:在JSON中,{}用于表示对象,而[]用于表示数组。这两种结构可以嵌套和组合,以创建复杂的数据表示。这些结构与Python中的字典(dict)和列表(list)非常相似,因此在Python和JSON之间进行数据转换时,这两种结构通常会相互映射。
在 JSON 中,除了对象 {} 和数组 [] 这两种主要的数据结构外,没有其他的复杂数据结构。
JSON 支持的基本数据类型有:
-
字符串 (String): 由双引号括起来的字符集合。例如:
"Hello, World!" -
数字 (Number): 可以是整数或浮点数。例如:
123,3.14,-42,0.001 -
布尔值 (Boolean): 有两个值:
true和false。 -
null: 表示一个空值或缺失值。
这些基本数据类型可以与对象 {} 和数组 [] 结合使用,形成复杂的数据结构。
例如:
{"name": "John","age": 30,"is_student": false,"scores": [95, 87, 78],"address": {"city": "New York","zip": "10001"},"friends": null
}
在这个 JSON 数据中:
"name"的值是一个 字符串。"age"的值是一个 数字。"is_student"的值是一个 布尔值。"scores"的值是一个 数组,其中包含三个数字。"address"的值是一个 对象,其中包含两个键值对。"friends"的值是 null。
这些基本数据类型和数据结构使得 JSON 能够表示大多数常见的数据结构,从简单的标量值到复杂的嵌套对象和数组。
json.loads()
json.loads() 是 Python 标准库中 json 模块提供的一个函数,它用于将一个 JSON 编码的字符串转换为一个 Python 对象。loads 是 “load string” 的缩写。
函数签名
json.loads(s, *, encoding=None, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None, **kw)
参数
- s - 这是要解析的 JSON 编码的字符串。
以下参数是可选的:
- encoding - 这个参数是已弃用的,因为 JSON 数据默认为 UTF-8。
- cls - 自定义的 JSON 解码器。
- object_hook - 如果指定了此参数,它应该是一个函数,用于将一个字典转换为另一个对象。
- parse_float - 使用此参数可以指定一个函数来解析浮点数(默认情况下使用 Python 的内置
float()函数)。 - parse_int - 使用此参数可以指定一个函数来解析整数(默认情况下使用 Python 的内置
int()函数)。 - parse_constant - 使用此参数可以指定一个函数来解析以下字符串:
-Infinity,Infinity,NaN。 - object_pairs_hook - 使用此参数可以指定一个函数,该函数接受一个键值对列表,然后返回一个对象。例如,它可以用于创建有序字典。
示例
import jsonjson_string = '{"name": "Alice", "age": 25, "is_student": false}'# 使用 json.loads() 转换字符串为字典
data = json.loads(json_string)print(type(data)) # <class 'dict'>
print(data) # {'name': 'Alice', 'age': 25, 'is_student': False}
注意事项
json.loads()只接受合法的 JSON 字符串。如果提供的字符串不是有效的 JSON,它会引发json.JSONDecodeError。- JSON 的
true,false, 和null在 Python 中分别对应为True,False, 和None。 - 从不受信任的源获取 JSON 数据时,使用
json.loads()是安全的,因为它不会执行任何潜在的危险代码。这与某些其他语言的解析器不同,这些解析器可能会执行嵌入在数据中的代码。
总的来说,json.loads() 是 Python 中处理 JSON 数据的基本工具,它简单、高效、安全。
json.dumps()
json.dumps() 是 Python 标准库中 json 模块提供的一个函数。它用于将 Python 对象序列化为 JSON 格式的字符串。dumps 是 “dump string” 的缩写。
函数签名
json.dumps(obj, *, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, default=None, sort_keys=False, **kw)
参数
- obj - 要序列化的 Python 对象。
以下参数是可选的:
- skipkeys - 默认为
False。如果设置为True,则字典的键不是基本类型 (str,int,float,bool,None) 将被跳过,而不是引发TypeError。 - ensure_ascii - 默认为
True。如果为True,则输出保证仅包含 ASCII 字符。如果 Python 对象包含非ASCII字符,它们将被转义。如果为False,则这些字符将以UTF-8编码输出。 - check_circular - 默认为
True。检查循环引用。 - allow_nan - 默认为
True。指定是否允许序列化非数值的浮点值(例如:Infinity,-Infinity,NaN)。 - cls - 自定义的 JSON 编码器。
- indent - 可以是整数或字符串,指定缩进级别以美化输出的JSON。例如,
indent=4会使输出具有 4 个空格的缩进。 - separators - 一个元组,指定用于分隔项目和键值对的字符串。
- default - 指定一个函数,用于序列化那些不能默认序列化的 Python 对象。
- sort_keys - 默认为
False。如果为True,则输出的 JSON 字符串的字典键将被排序。
示例
import jsondata = {"name": "Alice","age": 25,"is_student": False
}# 使用 json.dumps() 将字典转换为字符串
json_string = json.dumps(data, indent=4)print(json_string)
输出:
{"name": "Alice","age": 25,"is_student": false
}
注意事项
- Python 的字典顺序在 Python 3.7+ 中是有保证的,但在此之前的版本中并不保证。如果需要保证键的顺序,可以使用
sort_keys=True。 - 并非所有的 Python 对象都可以被序列化为 JSON。例如,Python 的
set类型或自定义对象默认是不能被序列化的。但可以提供一个default函数来自定义这些类型的序列化方法。 - 在将数据序列化为 JSON 时,请注意大小写。JSON 键通常为小写,而 Python 的命名惯例可能与之不同。
总的来说,json.dumps() 是 Python 中处理 JSON 数据的基本工具,允许开发者以灵活和可控的方式将 Python 对象转换为 JSON 格式的字符串。
综合案例
下面这个例子展示了如何结合使用 json.dumps() 和 json.loads() 在 Python 对象和 JSON 格式的字符串之间进行转换,以及如何将 JSON 数据保存到文件和从文件中读取。
让我们考虑一个简单的场景:有一个 Python 字典,其中包含用户的一些信息,我们想将其保存到一个 JSON 文件中,并从该文件中读取信息。
首先,我们使用 json.dumps() 将字典转换为 JSON 格式的字符串并将其写入文件。然后,我们从文件中读取 JSON 字符串并使用 json.loads() 将其解析回 Python 对象。
示例
import json# 定义一个字典,其中包含用户的信息
user_data = {"name": "John Doe","age": 30,"email": "johndoe@example.com","is_member": True
}# 将 Python 字典转换为 JSON 字符串并写入文件
with open("user_data.json", "w") as file:json_string = json.dumps(user_data, indent=4)file.write(json_string)# 从文件中读取 JSON 字符串并转换为 Python 对象
with open("user_data.json", "r") as file:data = file.read()parsed_data = json.loads(data)print(parsed_data)print(f"User's name: {parsed_data['name']}")
运行结果如下:
majn@tiger:~$ python3 json_demo.py
{'name': 'Mario', 'age': 30, 'email': 'mario@example.com', 'is_member': True}
User's name: Mario
自定义序列化函数
case 1
当我们尝试将一些不能被直接序列化为JSON的Python对象(例如自定义对象或Python的set类型)转换为JSON时,可以使用default参数来指定如何处理这些对象。
下面的例子演示如何使用default参数来序列化一个包含自定义对象的Python列表:
import jsonclass Person:def __init__(self, name, age):self.name = nameself.age = agedef person_encoder(obj):"""自定义函数,将Person对象转换为可序列化的字典"""if isinstance(obj, Person):return {"name": obj.name, "age": obj.age}raise TypeError("Object of type 'Person' is not JSON serializable")# 创建一个Person对象列表
people = [Person("Alice", 30), Person("Bob", 25)]# 使用json.dumps()和default参数将列表转换为JSON字符串
people_json = json.dumps(people, default=person_encoder, indent=4)print(people_json)
输出:
[{"name": "Alice","age": 30},{"name": "Bob","age": 25}
]
在这个例子中,我们定义了一个person_encoder函数,用于将Person对象转换为可以序列化为JSON的字典。当json.dumps()遇到Person对象时,它会调用person_encoder函数进行处理。
这种方法允许开发者为任何不可以直接序列化为JSON的Python对象定义自定义的序列化逻辑。
case 2
当我们尝试将Python的set类型转换为JSON时,默认情况下是不支持的,因为JSON格式没有与集合相对应的数据类型。但是,我们可以使用default参数来自定义set的序列化方式。
一个常见的方法是将set转换为列表,因为列表是JSON支持的数据类型。下面是如何使用default参数将set类型转换为JSON的示例:
import jsondef set_encoder(obj):"""自定义函数,将set对象转换为列表"""if isinstance(obj, set):return list(obj)raise TypeError(f"Object of type '{type(obj).__name__}' is not JSON serializable")# 创建一个set
fruits = {"apple", "banana", "cherry"}# 使用json.dumps()和default参数将set转换为JSON字符串
fruits_json = json.dumps(fruits, default=set_encoder, indent=4)print(fruits_json)
输出:
["banana","cherry","apple"
]
注意:由于集合是无序的,所以转换为列表后的元素顺序可能会与原始集合中的顺序不同。
在这个例子中,我们定义了一个set_encoder函数,用于将set对象转换为列表。当json.dumps()遇到set对象时,它会调用set_encoder函数进行处理。这样,我们就可以将set类型成功转换为JSON字符串。
相关文章:
Python- JSON使用初探
JSON 在JSON格式中,{} 和 [] 是两种主要的数据结构,分别表示对象(或称为字典、哈希、map)和数组(或称为列表、序列)。 {} - 对象 在JSON中,对象是一组"key": value对的集合。这些键必…...
vim的配置文件
用户级别配置文件 ~/.vimrc 修改用户级别的配置文件只会影响当前用户, 不会影响其他的用户. 例如: 在用户的家目录下的.vimrc文件中添加 set tabstop4 ----设置缩进4个空格 set nu ----设置行号 set shiftwidth4 —设置ggG缩进4个空格, 默认是缩进8个空格 系统级别配置文件 /e…...
[python] pytest
在写一个项目前, 可以先编写测试模块 测试模块中包含了一个个最小的功能 当每一个功能都完善正确时 再将这些功能转换成项目运行的功能 多个项目运行的功能就组成了一个模块 多个模块就组成了一个项目服务 pytest 是一个 Python 测试框架,它提供了简单易用的语…...
【王道代码】【2.2顺序表】d1
关键字: 删除最小值最后位补齐;逆置;删除所有x;删除值为s到t区间的元素...
【Linux】【创建文件】Linux系统下在命令行中创建文件的方法
🐚作者简介:花神庙码农(专注于Linux、WLAN、TCP/IP、Python等技术方向)🐳博客主页:花神庙码农 ,地址:https://blog.csdn.net/qxhgd🌐系列专栏:Linux技术&…...
Pytorch之MobileViT图像分类
文章目录 前言一、Transformer存在的问题二、MobileViT1.MobileViT网络结构🍓 Vision Transformer结构🍉MobileViT结构 2.MV2(MobileNet v2 block)3.MobileViT block🥇Local representations🥈Transformers as Convolutions (glob…...
03在命令行环境中创建Maven版的Java工程,了解pom.xml文件的结构,了解Java工程的目录结构并编写代码,执行Maven相关的构建命令
创建Maven版的Java工程 Maven工程的坐标 数学中使用x、y、z三个向量可以在空间中唯一的定位一个点, Maven中也可以使用groupId,artifactId,version三个向量在Maven的仓库中唯一的定位到一个jar包 groupId: 公司或组织域名的倒序, 通常也会加上项目名称代表公司或组织开发的一…...
论文阅读:CenterFormer: Center-based Transformer for 3D Object Detection
目录 概要 Motivation 整体架构流程 技术细节 Multi-scale Center Proposal Network Multi-scale Center Transformer Decoder Multi-frame CenterFormer 小结 论文地址:[2209.05588] CenterFormer: Center-based Transformer for 3D Object Detection (arx…...
Arduino驱动BNO055九轴绝对定向传感器(惯性测量传感器篇)
目录 1、传感器特性 2、硬件原理图 3、控制器和传感器连线图 4、驱动程序 BNO055是实现智能9轴绝对定向的新型传感器IC,它将整个传感器系统级封装在一起,集成了三轴14位加速度计,三轴16位陀螺仪,三轴地磁传感器和一个自带算法处理的32位微控制器。...
MQTT测试工具及使用教程
一步一步来:MQTT服务器搭建、MQTT客户端使用-CSDN博客 MQTT X 使用指南_mqttx使用教程-CSDN博客...
yolov7改进优化之蒸馏(一)
最近比较忙,有一段时间没更新了,最近yolov7用的比较多,总结一下。上一篇yolov5及yolov7实战之剪枝_CodingInCV的博客-CSDN博客 我们讲了通过剪枝来裁剪我们的模型,达到在精度损失不大的情况下,提高模型速度的目的。上一…...
视频美颜SDK,提升企业视频通话质量与形象
在今天的数字时代,视频通话已经成为企业与客户、员工之间不可或缺的沟通方式。然而,由于网络环境、设备性能等因素的影响,视频通话中的画面质量往往难以达到预期效果。为了提升视频通话的质量与形象,美摄美颜SDK应运而生ÿ…...
webmin远程命令执行漏洞
文章目录 漏洞编号:漏洞描述:影响版本:利用方法(利用案例):安装环境漏洞复现 附带文件:加固建议:参考信息:漏洞分类: Webmin 远程命令执行漏洞(CV…...
docker离线安装和使用
通过修改daemon配置文件/etc/docker/daemon.json来使用加速器sudo mkdir -p /etc/docker sudo tee /etc/docker/daemon.json <<-EOF {"registry-mirrors": ["https://ullx9uta.mirror.aliyuncs.com"] } EOF sudo systemctl daemon-reload sudo syste…...
解决 MyBatis 一对多查询中,出现每组元素只有一个,总组数与元素数总数相等的问题
文章目录 问题简述场景描述问题描述问题原因解决办法 问题简述 笔者在使用 MyBatis 进行一对多查询的时候遇到一个奇怪的问题。对于笔者的一对多的查询结果,出现了这样的一个现象:原来每个组里有多个元素,查询目标是查询所查的组,…...
这应该是关于回归模型最全的总结了(附原理+代码)
本文将继续修炼回归模型算法,并总结了一些常用的除线性回归模型之外的模型,其中包括一些单模型及集成学习器。 保序回归、多项式回归、多输出回归、多输出K近邻回归、决策树回归、多输出决策树回归、AdaBoost回归、梯度提升决策树回归、人工神经网络、随…...
基于闪电连接过程优化的BP神经网络(分类应用) - 附代码
基于闪电连接过程优化的BP神经网络(分类应用) - 附代码 文章目录 基于闪电连接过程优化的BP神经网络(分类应用) - 附代码1.鸢尾花iris数据介绍2.数据集整理3.闪电连接过程优化BP神经网络3.1 BP神经网络参数设置3.2 闪电连接过程算…...
Linux性能优化--性能工具:网络
7.0 概述 本章介绍一些在Linux上可用的网络性能工具。我们主要关注分析单个设备/系统网络流量的工具,而非全网管理工具。虽然在完全隔离的情况下评估网络性能通常是无意义的(节点不会与自己通信),但是,调查单个系统在网络上的行为对确定本地配置和应用程…...
【Linux】线程互斥与同步
文章目录 一.Linux线程互斥1.进程线程间的互斥相关背景概念2互斥量mutex3.互斥量的接口4.互斥量实现原理探究 二.可重入VS线程安全1.概念2.常见的线程不安全的情况3.常见的线程安全的情况4.常见的不可重入的情况5.常见的可重入的情况6.可重入与线程安全联系7.可重入与线程安全区…...
敏捷开发中,Sprint回顾会的目的
Sprint回顾会的主要目的是促进Scrum团队的学习和持续改进。在每个Sprint结束后,团队聚集在一起进行回顾,以达到以下目标: 识别问题: 回顾会允许团队识别在Sprint(迭代)期间遇到的问题、挑战和障碍。这有助于…...
SkyWalking 10.2.0 SWCK 配置过程
SkyWalking 10.2.0 & SWCK 配置过程 skywalking oap-server & ui 使用Docker安装在K8S集群以外,K8S集群中的微服务使用initContainer按命名空间将skywalking-java-agent注入到业务容器中。 SWCK有整套的解决方案,全安装在K8S群集中。 具体可参…...
盘古信息PCB行业解决方案:以全域场景重构,激活智造新未来
一、破局:PCB行业的时代之问 在数字经济蓬勃发展的浪潮中,PCB(印制电路板)作为 “电子产品之母”,其重要性愈发凸显。随着 5G、人工智能等新兴技术的加速渗透,PCB行业面临着前所未有的挑战与机遇。产品迭代…...
Python:操作 Excel 折叠
💖亲爱的技术爱好者们,热烈欢迎来到 Kant2048 的博客!我是 Thomas Kant,很开心能在CSDN上与你们相遇~💖 本博客的精华专栏: 【自动化测试】 【测试经验】 【人工智能】 【Python】 Python 操作 Excel 系列 读取单元格数据按行写入设置行高和列宽自动调整行高和列宽水平…...
为什么需要建设工程项目管理?工程项目管理有哪些亮点功能?
在建筑行业,项目管理的重要性不言而喻。随着工程规模的扩大、技术复杂度的提升,传统的管理模式已经难以满足现代工程的需求。过去,许多企业依赖手工记录、口头沟通和分散的信息管理,导致效率低下、成本失控、风险频发。例如&#…...
#Uniapp篇:chrome调试unapp适配
chrome调试设备----使用Android模拟机开发调试移动端页面 Chrome://inspect/#devices MuMu模拟器Edge浏览器:Android原生APP嵌入的H5页面元素定位 chrome://inspect/#devices uniapp单位适配 根路径下 postcss.config.js 需要装这些插件 “postcss”: “^8.5.…...
处理vxe-table 表尾数据是单独一个接口,表格tableData数据更新后,需要点击两下,表尾才是正确的
修改bug思路: 分别把 tabledata 和 表尾相关数据 console.log() 发现 更新数据先后顺序不对 settimeout延迟查询表格接口 ——测试可行 升级↑:async await 等接口返回后再开始下一个接口查询 ________________________________________________________…...
GruntJS-前端自动化任务运行器从入门到实战
Grunt 完全指南:从入门到实战 一、Grunt 是什么? Grunt是一个基于 Node.js 的前端自动化任务运行器,主要用于自动化执行项目开发中重复性高的任务,例如文件压缩、代码编译、语法检查、单元测试、文件合并等。通过配置简洁的任务…...
【无标题】路径问题的革命性重构:基于二维拓扑收缩色动力学模型的零点隧穿理论
路径问题的革命性重构:基于二维拓扑收缩色动力学模型的零点隧穿理论 一、传统路径模型的根本缺陷 在经典正方形路径问题中(图1): mermaid graph LR A((A)) --- B((B)) B --- C((C)) C --- D((D)) D --- A A -.- C[无直接路径] B -…...
【LeetCode】3309. 连接二进制表示可形成的最大数值(递归|回溯|位运算)
LeetCode 3309. 连接二进制表示可形成的最大数值(中等) 题目描述解题思路Java代码 题目描述 题目链接:LeetCode 3309. 连接二进制表示可形成的最大数值(中等) 给你一个长度为 3 的整数数组 nums。 现以某种顺序 连接…...
高分辨率图像合成归一化流扩展
大家读完觉得有帮助记得关注和点赞!!! 1 摘要 我们提出了STARFlow,一种基于归一化流的可扩展生成模型,它在高分辨率图像合成方面取得了强大的性能。STARFlow的主要构建块是Transformer自回归流(TARFlow&am…...
