Python实战013:如何将数据以JSON格式输出
off999 2024-10-04 00:21 30 浏览 0 评论
JSON(全称:JavaScript Object Notation) 是一种轻量级的数据交换格式,它的结构简洁、层次清晰也没有xml那么多标签描述让文件更加小巧且解析速度更快。非常适合做网络传输的数据格式,不仅可以有效地提升网络传输效率也可以降低带宽节约成本。所以我们在做开发的时候都更倾向于选择JSON来交换数据,这样对接起来方便也可以提高我们的开发效率。
JSON数据结构
JSON是一个标记符的序列,这些标记符主要有构造字符、字符串、数字和字面名。{} 双括号表示对象、[] 中括号表示数组、,逗号表示数据分隔符、"" 双引号内是属性或值、:冒号表示键值对分隔符、false表示假、null表示空值、true表示真,利用这些标记符我们可以方便快捷的生成JSON格式的数据。JSON一般有两种表示结构的数据分别是对象和数组,以”{”大括号开始,以”}”大括号结束的为对象结构,以”[”中括号开始,以”]”中括号结束的为数组结构。
定义JSON结构数据
在python中可以利用字典和列表(相当于数组)构建JSON结构的数据,Python字典包括在花括号 {} 中,每个值之间用逗号","分割,每个键值对( key:value )用冒号 ": "分割。键一般是唯一不可变的,而值则可以取任何数据类型。Python 没有内置对数组的支持但可以使用列表代替,每个列表可以包含多个值,每个值分配了一个索引,值之间用逗号","分割。
转换成JSON数据
文件中只能写字符串,所以如果我们想把JSON结构的数据写入文件就需要先将其转成JSON字符串。当然JSON字符串不能直接用key、value来取值的,所以使用前我们需要先对JSON字符串进行转换。Python中将字典转换成JSON格式非常简单,直接引入内置的json模块来对 JSON数据进行编解码。json模块提供了四个方法: dumps、dump、loads、load,dump和dumps可以将字典进行序列化编码JSON格式的字符串,load和loads反序列化将json格式字符串数据解码为字典。
dump和dumps的区别
dump和dumps都是用来序列化对象的Python对象的,可以将字典编码成JSON字符串。主要的区别在于dump函数需要传入文件描述符将序列化的JSON字符串保存到文件中,而dumps函数则可以直接生成JSON字符串,其他的参数基本一样使用。dump方便数据存储,dumps则方便数据传输。
load和loads的区别
load和loads都是用来反序列化Python对象的,可以将JSON字符串解码成Python的字典。load主要针对文件句柄可以将文件中的JSON字符串转换成Python的字典,loads主要针对内存中的对象,可以将内存中的JSON字符串转换成Python的字典。
总结:
JSON因为其体积小、结构简洁、层次清晰、快存储,易解析等特点,被广泛应用在接口交互中作为数据传输媒介。现在大部分语言和框架都支持JSON格式,所以复用率很高!以上内容是小编给大家分享的【Python实战013:如何将数据以JSON格式输出】。希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。
为了方便学习,下面附上本文用到的源码:
dict = {}
list = []
dict['name'] = 'zhangsan'
dict['age'] = 18
dict['addr'] = '衡阳'
dict['isSir'] = True
list.append(dict)
[{'name': 'zhangsan', 'age': 18, 'addr': '衡阳', 'isSir': True}]
string = json.dumps(list, indent = 2)
with open('./a.txt',mode='w+') as wf:
wf.write(string)
[
{
"name": "zhangsan",
"age": 18,
"addr": "\u8861\u9633",
"isSir": true
}
]
with open('a.json', 'w') as f:
json.dump(dict, f, indent = 2)
string = json.dumps(list, indent = 2)
with open('./a.json',mode='w') as f:
f.write(string)
with open("a.json", "r", encoding='utf-8') as f:
load_val = json.load(f) # 直接读取文件句柄
print(load_val, type(load_val))
f.seek(0) # 将文件游标移动到文件开头位置
string = f.read()
print(string, type(string))
loads_val = json.loads(string) # loads的传入参数为字符串类型
print(loads_val, type(loads_val))
=====================================================================================
{'name': 'zhangsan', 'age': 18, 'addr': '衡阳', 'isSir': True} <class 'dict'>
{"name": "zhangsan", "age": 18, "addr": "\u8861\u9633", "isSir": true} <class 'str'>
{'name': 'zhangsan', 'age': 18, 'addr': '衡阳', 'isSir': True} <class 'dict'>
相关推荐
- python入门到脱坑经典案例—清空列表
-
在Python中,清空列表是一个基础但重要的操作。clear()方法是最直接的方式,但还有其他方法也可以实现相同效果。以下是详细说明:1.使用clear()方法(Python3.3+推荐)...
- python中元组,列表,字典,集合删除项目方式的归纳
-
九三,君子终日乾乾,夕惕若,厉无咎。在使用python过程中会经常遇到这四种集合数据类型,今天就对这四种集合数据类型中删除项目的操作做个总结性的归纳。列表(List)是一种有序和可更改的集合。允许重复...
- Linux 下海量文件删除方法效率对比,最慢的竟然是 rm
-
Linux下海量文件删除方法效率对比,本次参赛选手一共6位,分别是:rm、find、findwithdelete、rsync、Python、Perl.首先建立50万个文件$testfor...
- 数据结构与算法——链式存储(链表)的插入及删除,
-
持续分享嵌入式技术,操作系统,算法,c语言/python等,欢迎小友关注支持上篇文章我们讲述了链表的基本概念及一些查找遍历的方法,本篇我们主要将一下链表的插入删除操作,以及采用堆栈方式如何创建链表。链...
- Python自动化:openpyxl写入数据,插入删除行列等基础操作
-
importopenpyxlwb=openpyxl.load_workbook("example1.xlsx")sh=wb['Sheet1']写入数据#...
- 在Linux下软件的安装与卸载(linux里的程序的安装与卸载命令)
-
通过apt安装/协助软件apt是AdvancedPackagingTool,是Linux下的一款安装包管理工具可以在终端中方便的安装/卸载/更新软件包命令使用格式:安装软件:sudoapt...
- Python 批量卸载关联包 pip-autoremove
-
pip工具在安装扩展包的时候会自动安装依赖的关联包,但是卸载时只删除单个包,无法卸载关联的包。pip-autoremove就是为了解决卸载关联包的问题。安装方法通过下面的命令安装:pipinsta...
- 用Python在Word文档中插入和删除文本框
-
在当今自动化办公需求日益增长的背景下,通过编程手段动态管理Word文档中的文本框元素已成为提升工作效率的关键技术路径。文本框作为文档排版中灵活的内容容器,既能承载多模态信息(如文字、图像),又可实现独...
- Python 从列表中删除值的多种实用方法详解
-
#Python从列表中删除值的多种实用方法详解在Python编程中,列表(List)是一种常用的数据结构,具有动态可变的特性。当我们需要从列表中删除元素时,根据不同的场景(如按值删除、按索引删除、...
- Python 中的前缀删除操作全指南(python删除前导0)
-
1.字符串前缀删除1.1使用内置方法Python提供了几种内置方法来处理字符串前缀的删除:#1.使用removeprefix()方法(Python3.9+)text="...
- 每天学点Python知识:如何删除空白
-
在Python中,删除空白可以分为几种不同的情况,常见的是针对字符串或列表中空白字符的处理。一、删除字符串中的空白1.删除字符串两端的空白(空格、\t、\n等)使用.strip()方法:s...
- Linux系统自带Python2&yum的卸载及重装
-
写在前面事情的起因是我昨天在测试Linux安装Python3的shell脚本时,需要卸载Python3重新安装一遍。但是通过如下命令卸载python3时,少写了个3,不小心将系统自带的python2也...
- 如何使用Python将多个excel文件数据快速汇总?
-
在数据分析和处理的过程中,Excel文件是我们经常会遇到的数据格式之一。本文将通过一个具体的示例,展示如何使用Python和Pandas库来读取、合并和处理多个Excel文件的数据,并最终生成一个包含...
- 【第三弹】用Python实现Excel的vlookup功能
-
今天继续用pandas实现Excel的vlookup功能,假设我们的2个表长成这样:我们希望把Sheet2的部门匹在Sheet1的最后一列。话不多说,先上代码:importpandasaspd...
- python中pandas读取excel单列及连续多列数据
-
案例:想获取test.xls中C列、H列以后(当H列后列数未知时)的所有数据。importpandasaspdfile_name=r'D:\test.xls'#表格绝对...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python自定义函数 (53)
- python进度条 (67)
- python吧 (67)
- python字典遍历 (54)
- python的for循环 (65)
- python格式化字符串 (61)
- python串口编程 (60)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python字典增加键值对 (53)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python人脸识别 (54)
- python多态 (60)
- python命令行参数 (53)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)