1. json模块介绍

json是python自带的操作json的模块。

python序列化为json时的数据类型转换关系:

python格式 json格式
dict(复合类型) object
list, tuple(集合类型) array
int, long, float(数值类型) number
str, unicode string
True true
False false
None null

json反序列化为python数据类型对照关系:

json格式 python格式
object dict
array list
string unicode
number(int) int, long
numer(real) float
true True
false False
null None

2. 如何使用

json库提供了几个API:

json.dumps(): 将字典序列化为json字符串

json.loads(): 将json字符串反序列化为字典

json.dump(): 将字典序列化到一个文件,是文本文件,就是相当于将序列化后的json字符串写入到一个文件

json.load(): 从文件中反序列出字典

总结: 不带s的是序列到文件或者从文件中反序列化,带s的是都在内存中操作不涉及到持久化

一个简单使用的例子如下:

#! /usr/bin/python

import json

if __name__ == '__main__':
cc = {
"name": "CC11001100",
"age": 22,
"money": 9.9,
"car": "Feng-Huang Bicycle",
"house": "祖宅",
"girl friend": None,
"hobby": "thinking..."
} # 序列化为字符串
json_string = json.dumps(cc)
print(json_string)
# 从字符串中反序列化
json_dict = json.loads(json_string)
print(json_dict) # 序列化到文件中
with open('D:/cc.json', 'w') as json_file:
json.dump(cc, json_file)
# 从文件中反序列化
with open('D:/cc.json', 'r') as json_file:
json_dict = json.load(json_file)
print(json_dict)

py对象序列化为json的时候会接受的几个参数:

indent: 即缩进量是几个空格,当需要格式化输出的时候一般设为4个空格

一个指定indent的小例子:

#! /usr/bin/python

import json

if __name__ == '__main__':
cc = {
"name": "CC11001100",
"age": 22,
"money": 9.9,
"car": "Feng-Huang Bicycle",
"house": "祖宅",
"girl friend": None,
"hobby": "thinking..."
}
print(json.dumps(cc, indent=4))

输出:

{
"name": "CC11001100",
"age": 22,
"money": 9.9,
"car": "Feng-Huang Bicycle",
"house": "\u7956\u5b85",
"girl friend": null,
"hobby": "thinking..."
}

separators: 生成的json子串所使用的分隔符,就是用来代替分隔多个k/v对的,和分隔k/v的:

一个指定了separators的小例子:

#! /usr/bin/python

import json

if __name__ == '__main__':
cc = {
"name": "CC11001100",
"age": 22,
"money": 9.9,
"car": "Feng-Huang Bicycle",
"house": "祖宅",
"girl friend": None,
"hobby": "thinking..."
}
print(json.dumps(cc, indent=4, separators=('↓', '→')))

输出:

{
"name"→"CC11001100"↓
"age"→22↓
"money"→9.9↓
"car"→"Feng-Huang Bicycle"↓
"house"→"\u7956\u5b85"↓
"girl friend"→null↓
"hobby"→"thinking..."
}

sort_keys:是否对key进行排序,目前还没感觉出有啥用

3. 自带json模块的局限性

使用自带的json模块虽然很方便,但是序列化自定义类型的时候就会抛出一个TypeError的异常:

TypeError: Object of type 'Person' is not JSON serializable

对于自定义类型的序列化,一般都是使用第三方库,当然这个是另外的内容了。

参考资料:

1. https://docs.python.org/2/library/json.html

python3之json模块使用的更多相关文章

  1. python3.7 json模块

    #!/usr/bin/env python __author__ = "lrtao2010" #python3.7 json模块 ''' 要在不同的编程语言之间传递对象,就必须把对 ...

  2. Python3之json模块

    概念: 序列化(Serialization):将对象的状态信息转换为可以存储或可以通过网络传输的过程,传输的格式可以是JSON,XML等.反序列化就是从存储区域(JSON,XML)读取反序列化对象的状 ...

  3. python3中json模块的用法

    __author__ = "JentZhang" import json user_info = {"} # 将字典转换为JSON字符串 json_str = json. ...

  4. python3.5和python3.6关于json模块的区别

    python3.5中 无法反序列化bytes数据必须decode成str才可以 >>> import json >>> a = b'{"username& ...

  5. Python 第三篇(上):python文件基础操作、json模块、lambda、map、filter、reduce和函数位置参数

    python一切皆对象,linux一切皆文件,python操作文件是很常见的O/I操作,其内置来open()函数可以完成文件的基本操作: 一:使用内置open()函数操作文件,基本语法如下: with ...

  6. 【Python3之常用模块】

    一.time 1.三种表达方式 在Python中,通常有这几种方式来表示时间: 时间戳(timestamp):通常来说,时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量.命令如下 ...

  7. Python 3 中的json模块使用

    1. 概述 JSON (JavaScript Object Notation)是一种使用广泛的轻量数据格式. Python标准库中的json模块提供了JSON数据的处理功能. Python中一种非常常 ...

  8. 洗礼灵魂,修炼python(70)--爬虫篇—补充知识:json模块

    在前面的某一篇中,说完了pickle,但我相信好多朋友都不懂到底有什么用,那么到了爬虫篇,它就大有用处了,而和pickle很相似的就是JSON模块 JSON 1.简介 1)JSON(JavaScrip ...

  9. 序列化模块— json模块,pickle模块,shelve模块

    json模块 pickle模块 shelve模块 序列化——将原本的字典.列表等内容转换成一个字符串的过程就叫做序列化. # 序列化模块 # 数据类型转化成字符串的过程就是序列化 # 为了方便存储和网 ...

随机推荐

  1. 使用Log4在测试过程中打印执行日志 及配置log4j.properties!

    http://zengxiantao.iteye.com/blog/1881706 1.环境配置:到网上下载log4j-1.2.17.jar包!完后 添加到 项目的build path 中即可! 2. ...

  2. [乱搞]hdu 6406 Taotao picks apples 笛卡尔树+倍增

    题目链接 Problem Description There is an apple tree in front of Taotao's house. When autumn comes, n app ...

  3. android面试(2)----组件

    1.anroid:id的作用? android:id是作为控件的唯一标示符.可以使用与releativelayout中,也可以再Activity中通过findviewbyid来获得指定的控件. 2.a ...

  4. 个人博客开发-01-nodeJs项目搭建

    // window系统下 1.nodeJs 安装 nodeJs 安装 看  这里 , 先下载再下一步下一步就OK了,我的是在C盘里安装的. 安装完以后 按 win + R ,在弹出的小框框里输入 CM ...

  5. logstash收集MySQL慢查询日志

    #此处以收集mysql慢查询日志为准,根据文件名不同添加不同的字段值input { file { path => "/data/order-slave-slow.log" t ...

  6. RabbitMQ 使用详细介绍

    1. 实现最简单的队列通信 2. producer端 # !/usr/bin/env python import pika #通过这个实例,先去建立一个socket,默认端口15672 connect ...

  7. 【BZOJ1226】学校食堂(动态规划,状态压缩)

    [BZOJ1226]学校食堂(动态规划,状态压缩) 题面 BZOJ 洛谷 题解 发现\(b\)很小,意味着当前这个人最坏情况下也只有后面的一小部分人在他前面拿到饭. 所以整个结果的大致顺序是不会变化的 ...

  8. 【Python简介】

    一.Python的简介 1.什么是python? Python(发音:[ 'paiθ(ə)n; (US) 'paiθɔn ]),是一种面向对象的解释性的计算机程序设计语言,也是一种功能强大而完善的通用 ...

  9. 日志分割工具——cronolog

    使用cronolog可以格式化日志文件的格式,比如按时间分割,易于管理和分析. 1.下载软件 http://cronolog.org/download/index.html 用法见 lighttpd配 ...

  10. Adaboost 算法的原理与推导——转载及修改完善

    <Adaboost算法的原理与推导>一文为他人所写,原文链接: http://blog.csdn.net/v_july_v/article/details/40718799 另外此文大部分 ...