python中json模块的使用
Python自带json模块,它有loads、dumps、load和dump这4个功能,用于Json格式字符串和Python数据类型间进行转换。
一、json.loads()
把Json格式字符串解码转换成Python对象
Json中的对象和数组类型字符串会转换成Python中的字典和列表
示例
In [1]: import json #导入json模块 In [2]: json_list_str = '[1,2,3,4]' #数组类型json字符串 In [3]: json.loads(json_list_str) #返回python列表
Out[3]: [1, 2, 3, 4] In [4]: json_dict_str = '{"name":"张三","age":30}'#对象类型json字符串 In [5]: json.loads(json_dict_str) #返回Python字典
Out[5]: {'name': '张三', 'age': 30}
二、json.dumps()
实现python类型转化为json字符串
Python中的列表或元组会转换成Json数组类型字符串,字典会转化成对象类型字符串
示例
In [6]: tuple = (1,2,3,4,5) In [7]: list = [1,2,3,4,5] In [8]: dict = {"name":"张三","age":30} In [9]: json.dumps(tuple) #python元组会转化成json中数组类型字符串
Out[9]: '[1, 2, 3, 4, 5]' In [10]: json.dumps(list) #python列表转换成json中数组类型字符串
Out[10]: '[1, 2, 3, 4, 5]' In [11]: json.dumps(dict) #python字典转换成json对象类型字符串,序列化时默认采用ascii编码
Out[11]: '{"name": "\\u5f20\\u4e09", "age": 30}' In [12]: json.dumps(dict,ensure_ascii=False) #将ensure_ascii参数设为False,采用utf-8编码
Out[12]: '{"name": "张三", "age": 30}'
三、json.dump()
将Python内置类型序列化为json对象后写入文件
示例
In [13]: python_data = [{"name":"张三","age":30},{"name":"李四","age":40}] In [14]: json.dump(python_data,open('json_data.json','w'),ensure_ascii=False) #将python类型数据转换成json类型,并写入文件json_data.json In [15]: with open('json_data.json') as f: #查看写入文件中的json数据
...: print(f.read())
...:
[{"name": "张三", "age": 30}, {"name": "李四", "age": 40}]
四、json.load()
读取文件中json形式的字符串,并转化成python类型
示例
In [16]: json.load(open('json_data.json')) #读取文件json_data.json中的json字符串,并转换成python中的列表类型
Out[16]: [{'name': '张三', 'age': 30}, {'name': '李四', 'age': 40}] In [17]: type(json.load(open('json_data.json'))) #python中的列表类型
Out[17]: list
python中json模块的使用的更多相关文章
- 解决python中json模块loads出来的结构都是unicode的问题
在使用python的json模块对json字串反序列化成python对象的时候出现的字符串都是unicode类型,而不是python内置的str类型.在某种使用场景下用户必须做显式的转换才能正常使用, ...
- [ Python入门教程 ] Python中JSON模块基本使用方法
JSON (JavaScript Object Notation)是一种使用广泛的轻量数据格式,Python标准库中的json模块提供了一种简单的方法来编码和解码JSON格式的数据.用于完成字符串和p ...
- python中json格式数据输出实现方式
python中json格式数据输出实现方式 主要使用json模块,直接导入import json即可. 小例子如下: #coding=UTF-8 import json info={} info[&q ...
- python 历险记(五)— python 中的模块
目录 前言 基础 模块化程序设计 模块化有哪些好处? 什么是 python 中的模块? 引入模块有几种方式? 模块的查找顺序 模块中包含执行语句的情况 用 dir() 函数来窥探模块 python 的 ...
- python中json操作了解
什么是接口? 交换数据 http://openweathermap.org/current json简介 JSON 是存储和交换文本信息的语法.类似 XML JSON 语法是 JavaScript 语 ...
- Python中json的简单读写操作
Python中json的简单读写操作 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的 ...
- Python中optionParser模块的使用方法[转]
本文以实例形式较为详尽的讲述了Python中optionParser模块的使用方法,对于深入学习Python有很好的借鉴价值.分享给大家供大家参考之用.具体分析如下: 一般来说,Python中有两个内 ...
- python中threading模块详解(一)
python中threading模块详解(一) 来源 http://blog.chinaunix.net/uid-27571599-id-3484048.html threading提供了一个比thr ...
- 【转】关于python中re模块split方法的使用
注:最近在研究文本处理,需要用到正则切割文本,所以收索到了这篇文章,很有用,谢谢原作者. 原址:http://blog.sciencenet.cn/blog-314114-775285.html 关于 ...
随机推荐
- RocketMQ源码分析 broker启动,commitlog、consumequeue、indexfile、MappedFileQueue、MappedFile之间的关系以及位置说明
目录 1.MappedFile类属性说明 1.1.MappedFile类属性如下 1.2.MappedFile构造器说明 2.MappedFileQueue类说明 2.1.属性说明 2.2.Mappe ...
- IIS添加应用程序和虚拟目录
右键添加应用程序 别名就是虚拟路径 比如本来路径是http://localhost:44336/main.html 别名为 qwer 那么就可以访问http://localhost:4433 ...
- 【磁盘/文件系统】第二篇:标准磁盘分区流程针对fdisk(硬盘容量小于2T且分区数不能大于15个分区)
前奏:先插上一块磁盘(做了RAID的磁盘才能分区) 查看磁盘连上服务器没有,或者说是可以进行分区前奏 [root@PandaLi ~]# ll /dev/sd sda sda1 sda2 sda3 s ...
- iOS崩溃治理--开篇
去年我开始负责iOS崩溃治理的工作,从原来的万分之五崩溃率,一直到现在的万分之一左右的崩溃率,期间踩了很多坑,因此想和大家分享一下,希望能对大家有所帮助,也欢迎大家私信交流. 如果你打算开始治理崩溃的 ...
- windows 10放大125%后字体模糊(已解决)、win10 文字放大之后变模糊 解决办法
windows 10放大125%后字体模糊解决办法 百度搜索 "Windows10_DPI_FIX" 或者用这个地址下载下载地址 https://gallery.technet ...
- 如果对象为空,java函数String.valueOf(Object obj)返回"null"字符串
源码如下: public static String valueOf(Object obj) { return (obj == null) ? "null" : obj.toStr ...
- hadoop3.2+Centos7+5个节点主从模式配置
准备工作: hadoop3.2.0+jdk1.8+centos7+zookeeper3.4.5 以上是我搭建集群使用的基础包 一.环境准备 master1 master2 slave1 slave2 ...
- Spring Cloud是什么鬼?
研究了一段时间Spring Boot了准备向Spring Cloud进发,公司架构和项目也全面拥抱了Spring Cloud.在使用了一段时间后发现Spring Cloud从技术架构上降低了对大型系统 ...
- cmake的安装
安装cmake有2种方式 安装方式1:源码安装 1.下载cmake源码包(https://cmake.org/download/),解压后进入解压目录 2.执行安装配置命令:配置软件二进制安装到/us ...
- Spark学习进度-Spark环境搭建&Spark shell
Spark环境搭建 下载包 所需Spark包:我选择的是2.2.0的对应Hadoop2.7版本的,下载地址:https://archive.apache.org/dist/spark/spark-2. ...