python中序列化模块json和pickle
json模块:json是第三方包,不是系统内置模块,以字符串序列
常用操作有:
json.dumps() # 将变量序列化,即将功能性字符转化为字符串
例:
>>> import json
>>> name = {"name":"egon","age":18}
>>> res = json.dumps(name)
>>> print(res)
{"name": "egon", "age": 18}
>>> print(res,type(res))
{"name": "egon", "age": 18} <class 'str'>
json.loads() #将字符串反序列化成功能性字符
例:
>>> import json
>>> name = "[1,2,3]"
>>> print(type(name))
<class 'str'>
>>> res = json.loads(name)
>>> print(res,type(res))
[1, 2, 3] <class 'list'>
>>>
json.dump(dump_obj,write_file) 将dump_obj序列化后写入文件write_file
例:
>>> tom = {"tom":{"age":19,"score":89}}
>>> f = open(r"C:\Users\DELL\PycharmProjects\untitled1\four week\user.info","w",encoding="utf-8")
>>> json.dump(tom,f) #序列化到文件
>>> f.close()
>>> f = open(r"C:\Users\DELL\PycharmProjects\untitled1\four week\user.info","r",encoding="utf-8")
>>> res = f.read()
>>> print(res)
{"tom": {"age": 19, "score": 89}}
>>>
json.load(file) 将file中的内容反序列化返回
>>> f = open(r"C:\Users\DELL\PycharmProjects\untitled1\four week\user.info","r",encoding="utf-8")
>>> res = json.load(f)
>>> print(res)
{'tom': {'age': 19, 'score': 89}}
>>> print(type(res)) #查看res类型
<class 'dict'>
>>>
pickle模块:以二进制序列
pickle.dumps(obj) 将对象obj序列化为二进制bytes类型
例:
>>> print(res)
{'tom': {'age': 19, 'score': 89}}
>>> pic_res = pickle.dumps(res)
>>> print(pic_res,type(pic_res))
b'\x80\x03}q\x00X\x03\x00\x00\x00tomq\x01}q\x02(X\x03\x00\x00\x00ageq\x03K\x13X\x05\x00\x00\x00scoreq\x04KYus.' <class 'bytes'>
>>>
pickle.loads(b_str) 将二进制字符串反序列化为obj对象
>>> print(pic_res,type(pic_res))
b'\x80\x03}q\x00X\x03\x00\x00\x00tomq\x01}q\x02(X\x03\x00\x00\x00ageq\x03K\x13X\x05\x00\x00\x00scoreq\x04KYus.' <class 'bytes'>
>>> res = pickle.loads(pic_res)
>>> print(res,type(res))
{'tom': {'age': 19, 'score': 89}} <class 'dict'>
>>>
pickle.dump(obj,write_file) 将对象obj序列化为二进制后存在文件中
>>> print(res)
{'tom': {'age': 19, 'score': 89}}
>>> f = open(r"C:\Users\DELL\PycharmProjects\untitled1\four week\user.info","wb")
>>> pickle.dump(res,f)
>>> f.close()
>>> f = open(r"C:\Users\DELL\PycharmProjects\untitled1\four week\user.info","rb")
>>> k = f.read()
>>> print(k,type(k))
b'\x80\x03}q\x00X\x03\x00\x00\x00tomq\x01}q\x02(X\x03\x00\x00\x00ageq\x03K\x13X\x05\x00\x00\x00scoreq\x04KYus.' <class 'bytes'>
>>>
pinkle.load(file) 将文件中的二进制反序列化为obj对象
>>> f = open(r"C:\Users\DELL\PycharmProjects\untitled1\four week\user.info","rb")
>>> res = pickle.load(f)
>>> print(res,type(res))
{'tom': {'age': 19, 'score': 89}} <class 'dict'>
>>>
总结:json和pickle都是将对象序列化,不同之处是json是将对象序列化为Unicode字符串,而pickle是将对象序列化为二进制字符串,也就是bytes类型
在不同语言中对数据的处理和认识是不同的,但每种语言都有一个共同的认识,那就是字符串,在跨平台跨语言传递数据时,序列化是非常常见的
python中序列化模块json和pickle的更多相关文章
- python序列化模块json和pickle
序列化相关 1. json 应用场景: json模块主要用于处理json格式的数据,可以将json格式的数据转化为python的字典,便于python处理,同时也可以将python的字典或列表等对象转 ...
- python 数据序列化(json、pickle、shelve)
本来要查一下json系列化自定义对象的一个问题,然后发现这篇博客(https://www.cnblogs.com/yyds/p/6563608.html)很全面,感谢作者,关于python序列化的知识 ...
- 常用模块一(os模块、序列化模块(json和pickle))
一.os模块 os模块是与操作系统交互的一个接口. import os # 和文件和文件夹的操作有关 os.makedirs('dirname1/dirname2') # 可生成多层递归目录 os.r ...
- 20,序列化模块 json,pickle,shelve
序列化模块 什么叫序列化? 将原本的字典,列表等内容转换成一个字符串的过程叫做序列化. 序列化的目的? 数据结构 通过序列化 转成 str. str 通过反序列化 转化成数据结构. json: jso ...
- 2019-7-18 collections,time,random,os,sys,序列化模块(json和pickle)应用
一.collections模块 1.具名元组:namedtuple(生成可以使用名字来访问元素的tuple) 表示坐标点x为1 y为2的坐标 注意:第二个参数可以传可迭代对象,也可以传字符串,但是字 ...
- Python中模块json与pickle的功能介绍
json & pickle & shelve 1. json的序列化与反序列化 json的使用需要导入该模块,一般使用import json即可. json的序列化 方法1:json. ...
- python 全栈开发,Day25(复习,序列化模块json,pickle,shelve,hashlib模块)
一.复习 反射 必须会 必须能看懂 必须知道在哪儿用 hasattr getattr setattr delattr内置方法 必须能看懂 能用尽量用__len__ len(obj)的结果依赖于obj. ...
- 序列化模块— json模块,pickle模块,shelve模块
json模块 pickle模块 shelve模块 序列化——将原本的字典.列表等内容转换成一个字符串的过程就叫做序列化. # 序列化模块 # 数据类型转化成字符串的过程就是序列化 # 为了方便存储和网 ...
- 【转】Python之数据序列化(json、pickle、shelve)
[转]Python之数据序列化(json.pickle.shelve) 本节内容 前言 json模块 pickle模块 shelve模块 总结 一.前言 1. 现实需求 每种编程语言都有各自的数据类型 ...
随机推荐
- vs相同变量高亮显示
https://blog.csdn.net/sinat_33718563/article/details/79241129 在VS2010中调试工程中,常常需要观察相同变量名在不同代码处的位置,VS默 ...
- onsubmit 事件
onsubmit 事件 Event 对象 定义和用法 onsubmit 事件会在表单中的确认按钮被点击时发生. 语法 onsubmit="SomeJavaScriptCode" 参 ...
- luogu3426 [POI2005]SZA-Template 后缀树
链接 bzoj不能auto https://www.luogu.org/problemnew/show/P3426 思路 这个要求的串一定是S的前缀和S的后缀. 转化一下 建立出来fail树(fail ...
- [shell]输出内容到剪切板
commandline和GUI下的clipboard的交互Mac下echo $PATH | pbcopy,copy to clipboardecho "$(pbpaste -Prefer t ...
- [笔记] SQL性能优化 - 避免使用 IN 和 NOT IN
WHY? IN 和 NOT IN 是比较常用的关键字,为什么要尽量避免呢? 1.效率低 可以参看我之前遇到的一个例子([小问题笔记(九)] SQL语句Not IN 效率低,用 NOT EXISTS试试 ...
- Ubuntu 16.04上搭建CDH5.16.1集群
本文参考自:<Ubuntu16.04上搭建CDH5.14集群> 1.准备三台(CDH默认配置为三台)安装Ubuntu 16.04.4 LTS系统的服务器,假设ip地址分布为 192.168 ...
- Virtualbox安装增强功能时显示【未能加载虚拟光盘】
我之前在安装Virtualbox时进行到安装增强功能时弹出了一个窗口,提示我"未能加载虚拟光盘到虚拟电脑",如下图 我尝试了多次都是这个情况,经过上网学习我找到了问题所在,我在第一 ...
- laravel 资源篇
转自:https://github.com/qianyugang/learn-laravel # Learn-Laravel — 学习资料和开源项目集 ## Laravel 学习资料 ### 官方网站 ...
- js的event事件对象汇总
JavaScript事件对象是浏览器默认传入的,但是对于浏览器的兼容问题,我们需要对事件对象进行兼容.但是jQuery已经帮我们解决了所有兼容性的问题,并且给我们添加了很多有用的方法.已经是比较历史的 ...
- Android测试(一)——Apk文件结构以及Android组件介绍
APK文件结构: assests目录:一般存放的是不会被编译处理的文件,一般是资源性质的文件或者配置文件: libs目录:程序依赖的native库,包含针对特定处理器软件层的编译代码: res目录:存 ...