我们把对象(变量)从内存中变成可存储的过程称之为序列化,比如XML,在Python中叫pickling,在其他语言中也被称之为serialization,marshalling,flattening等等,都是一个意思。    序列化后,就可以把序列化后的内容写入磁盘,或者通过网络传输到其他服务器上,    反过来,把变量内容从序列化的对象重新读到内存里称之为反序列化,即unpickling

json(JavaScript Object Notation)    一种轻量级的数据交换格式。它基于ECMAScript的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C、C++、Java、JavaScript、Perl、Python等)。这些特性使JSON成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成(一般用于提升网络传输速率)。    如果我们要在不同的变成语言之间传递对象,就必须把对象序列化为标准格式,比如XML,但更好的方法是序列化为JSON,因为JSON表示出来就是一个字符串,可以被所有语言读取,也可以方便地存储到磁盘或者通过网络传输,JSON不仅是标准格式,并且比XML更快,而且可以直接在Web页面中读取,非常方便,JSON表示的对象就是标准的JavaScript语言的对象。使用方法如下:
import json
# 序列化写(json.dumps())
with open('test.txt', 'w') as f:f.write(json.dumps(dic))
# 序列化读(json.loads)
with open('test.txt', 'r') as f:print(json.loads(f.read()))import json
dic = {'name': 'fanjinbao'}
# 序列化写(json.dump())
with open('test.txt', 'w') as f:json.dump(dic, f)
# 序列化读(json.load())
with open('test.txt', 'r') as f:print(json.load(f))

pickle    python的pickle模块实现了python的所有数据序列和反序列化。基本上功能使用和JSON模块没有太大区别,方法也同样是dumps/dump和loads/load。cPickle是pickle模块的C语言编译版本相对速度更快。与JSON不同的是pickle不是用于多种语言间的数据传输,它仅作为python对象的持久化或者python程序间进行互相传输对象的方法,因此它支持了python所有的数据类型。pickle反序列化后的对象与原对象是等值的副本对象,类似与deepcopy。使用方法如下:
import pickle
dic = {'name': 'fanjinbao'}
# 序列化写(pickle.dump())
with open('test.txt', 'wb') as f:f.write(pickle.dumps(dic))
# 序列化读(pickle.loads())
with open('test.txt', 'rb') as f:print(pickle.loads(f.read()))import pickle
dic = {'name': 'fanjinbao'}
# 序列化写(pickle.dump())
with open('test.txt', 'wb') as f:pickle.dump(dic, f)
# 序列化读(pickle.load())
with open('test.txt', 'rb') as f:print(pickle.load(f))

转载于:https://www.cnblogs.com/fansik/p/7692201.html

Python基础-序列化(json/pickle)相关推荐

  1. Python(序列化json,pickle,shelve)

    序列化 参考:https://www.cnblogs.com/yuanchenqi/articles/5732581.html 1 # dic = str({'1':'111'}) 2 # 3 # f ...

  2. python模块之json,pickle

    序列化是指把内存里的数据转变成字符串,以使其能保存到硬盘上或者通过网络输送到远程. 序列化的两个模块: json:只能把python中的int/str/list/tuple/dict类型的数据,可以在 ...

  3. python基础序列化文件的读取(十六)

    主要第三方库是pickle import pickle # python对象的序列化 class Peoper:def __init__(self,name,age):self.name=namese ...

  4. Python基础(十)--文件相关

    目录 Python基础(十)--文件相关 1 读写文件 1.1 获取文件对象 1.2 文件读取 1.3 文件写入 1.4 文件定位 2 文件与路径的操作 2.1 os模块 2.2 os.path模块 ...

  5. python基础 -文件和异常

    文章目录 一.从文件中读取数据 1.读取整个文件 2.只读 3.路径 4.读操作 二.写入文件 1.写模式 2.读写模式 3.写读模式 4.修改文件内容 5.其他相关操作 三.异常 1.什么是异常 2 ...

  6. Python基础4 迭代器,生成器,装饰器,Json和pickle 数据序列化

    本节内容 迭代器&生成器 装饰器 Json & pickle 数据序列化 软件目录结构规范 作业:ATM项目开发 1.列表生成式,迭代器&生成器 列表生成式 孩子,我现在有个需 ...

  7. Python基础 day4 迭代器生成器 装饰器 Json pickle 数据序列化 软件目录结构规范 作业:ATM项目开发...

    本节内容 迭代器&生成器 装饰器 Json & pickle 数据序列化 软件目录结构规范 作业:ATM项目开发 列表生成器 1.列表生成式,迭代器&生成器 列表生成式 孩子, ...

  8. Python-Day4 Python基础进阶之生成器/迭代器/装饰器/Json pickle 数据序列化

    一.生成器 通过列表生成式,我们可以直接创建一个列表.但是,受到内存限制,列表容量肯定是有限的.而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果我们仅仅需要访问前面几个元素,那后面 ...

  9. python之序列化与反序列化用法介绍json、pickle

    1.什么是序列化和反序列化 序列化就是将内存中的数据结构转换成一种中间格式存储到硬盘或者基于网络传输 反序列化就是硬盘中或者网络传来的一种数据格式转换成内存中数据结构 2.为啥有呢?   1.可以保存 ...

  10. Python基础知识点拾遗---文件IO(os、filecmp、shutil库)、sys库、序列化(pickle)、类

    Python基础知识点拾遗 文件IO 文本 目录 os 获取文件的创建.修改及最近访问时间 获取当前文件的大小 获取当前的登录用户名称 获取当前的cpu核数 调用操作系统底层的random生成器 sh ...

最新文章

  1. 使用服务器测量网站性能,使用服务器时序测量网站性能
  2. 正式开放 | 阿里云 10 亿级镜像服务正式支持 Helm Charts,云原生交付再加速!
  3. 【研究院】滴滴研究院,都在做什么
  4. 三维数据平滑处理_你该如何正确的处理思看科技三维扫描仪得到的数据?
  5. 常见危险文件列表 以及清除方法
  6. docker 安装 oracle 11g
  7. api代理提取_了解提取API
  8. 最近项目中遇到的一个算法挑战
  9. mysql序列号生成_超详细的mysql数据库GTID介绍—概念、优缺点、原理、生命周期等
  10. 如何保证进程间同步工作_系统设计硬核知识(2)——操作系统的进程管理
  11. 苹果手机录屏软件_手机录屏高清软件下载-手机录屏高清 安卓版v1.0.0
  12. ghost版32位win10系统,win10系统下载地址
  13. 【SLAM学习】(三)激光雷达原理及分类
  14. Kubernetes Events介绍(中)
  15. 常用域名管理后台网址
  16. 自动驾驶将产生比互联网更大的产值
  17. java制作进度条,Java制作进度条
  18. java抢红包_Java实现抢红包功能
  19. fprintf函数的的用法
  20. 我对软件分层设计的思考

热门文章

  1. 2018年大数据趋势丨大数据的黄金时代
  2. jmeter 线程执行顺序_JMeter基础之--元件的作用域与执行顺序
  3. 数据之路 - Python爬虫 - Requests库
  4. Gitlab分支保护
  5. 基于卷积神经网络的人脸识别项目_使用Tensorflow-gpu+dilib+sklearn
  6. 从最小样本中识别鸟类
  7. module_param()函数
  8. 不用代码隐藏自定义列表
  9. iphone 开发第四天 - 字符串
  10. C# Winform关于控件TabControl闪烁的问题