【python】pickle模块
序列化:
变量从内存中变成可存储或传输的过程称之为序列化。序列化之后,就可以把序列化后的内容写入磁盘,或者通过网络传输到别的机器上。叫pickling。把python的对象编码转换为json格式的字符串
反序列化:
反过来,把内容从序列化的对象重新读到内存里称之为反序列化,即unpickling。把json格式字符串解码为python数据对象。
pickle模块
1.序列化到文件并反序列化到变量
pickle.dumps(obj)
方法把任意对象序列化成bytes
,然后对byte进行操作
pickle.loads(byte)
方法把bytes反序列化为对象
,然后对对象进行操作
- d = dict(name="张三", age=16, grade="五年级", score="90")
- # 把序列化后的内容保存在变量中,把dict序列化为byte流,然后保存到变量中
- print(d)
- #>>>{'name': '张三', 'age': 16, 'grade': '五年级', 'score': '90'}
- data = pickle.dumps(d)
- print(type(data))
- #>>><class 'bytes'>
- print("序列化:{}".format(data))
- #>>>序列化:b'\x80\x03}q\x00(X\x04\x00\x00\x00nameq\x01X\x06\x00\x00\x00\xe5\xbc\xa0\xe4'
- # 把序列化后的数据还原为对象(反序列化),把byte流反序列化为dict对象,然后加载到内存
- obj = pickle.loads(data)
- print(type(obj))
- #>>><class 'dict'>
- print("反序列化:{}".format(obj))
- #>>>反序列化:{'name': '张三', 'age': 16, 'grade': '五年级', 'score': '90'}
2.序列化到文件并反序列化
pickle.dump()
直接把对象序列化后写入一个文件,进行持久化保存。
pickle.load()
方法从一个文件
中直接反序列化出对象。
由于pickle写入的是二进制数据,所以打开方式需要以wb
和rb
的模式。pickle可序列化用户自定义对象。
- import pickle
- #自定义类
- class Student(object):
- def __init__(self, name, age, grade, score):
- self.name = name
- self.age = age
- self.grade = grade
- self.score = score
- def study(self):
- print(self.name + "正在学习...")
- # 序列化自定义的类、对象
- # 将类本身序列化到文件中
- with open("json_pickle_Student_class.txt", "wb") as f:
- pickle.dump(Student, f)
- ##从文件中直接反序列化为类本身
- with open("json_pickle_Student_class.txt", "rb") as f:
- Stu=pickle.load(f)
- s = Stu("小明", 18, "高二", "135")
- s.study()
- a1 = 'apple'
- b1 = {1: 'One', 2: 'Two', 3: 'Three'}
- c1 = ['fee', 'fie', 'foe', 'fum']
- f1 = open('temp.pkl', 'wb')
- import pickle
- pickle.dump(a1, f1, True)
- pickle.dump(b1, f1, True)
- pickle.dump(c1, f1, True)
- f1.close()
- f2 = open('temp.pkl', 'rb')
- a2 = pickle.load(f2)
- print(a2)
- b2 = pickle.load(f2)
- print(b2)
- c2 = pickle.load(f2)
- print(c2)
- f2.close()
json模块
如果我们要在不同的编程语言之间传递对象,就必须把对象序列化为标准格式,比如XML,但更好的方法是序列化为JSON,因为JSON表示出来就是一个字符串。可以被所有语言读取,也可以方便地存储到磁盘或者通过网络传输。
json.dumps: 序列化,dumps()方法返回一个str,内容就是标准的JSON
json.loads: 反序列化,把JSON的字符串反序列化
- import json
- # 把对象转换为Json字符串
- t = [2018, "21届世界杯", '俄罗斯']
- # 核心代码,使用前要先导入json模块,此处是json.dumps(t)方法,区别于方法json.dump(t,f)
- json_str = json.dumps(t) ##把序列对象转换为json字符串
- t1=json.loads(json_str) ##把json字符串反序列化为序列对象
- print(t)
- #>>>[2018, '21届世界杯', '俄罗斯']
- print(json_str)
- #>>>[2018, "21\u5c4a\u4e16\u754c\u676f", "\u4fc4\u7f57\u65af"]
- print(t1)
- #>>>[2018, '21届世界杯', '俄罗斯']
json.dump(t,f)
,只是将对象序列化为文本文件。
json.load(f):从文件中读取字符串并反序列化
- import json
- # 直接把对象以Json字符串写入文件
- t = [2018, "21届世界杯", '俄罗斯']
- with open('file_write_json.txt','w') as f:
- json_str = json.dump(t,f)
- with open('file_write_json.txt','r') as f:
- data = json.load(f)
- print(data)
【python】pickle模块的更多相关文章
- [转]python pickle模块
持久性就是指保持对象,甚至在多次执行同一程序之间也保持对象.通过本文,您会对 Python对象的各种持久性机制(从关系数据库到 Python 的 pickle以及其它机制)有一个总体认识.另外,还会让 ...
- python pickle 模块的使用
用于序列化的两个模块 json:用于字符串和Python数据类型间进行转换 pickle: 用于python特有的类型和python的数据类型间进行转换 json提供四个功能:dumps,dump,l ...
- python pickle模块的使用/将python数据对象序列化保存到文件中
# Python 使用pickle/cPickle模块进行数据的序列化 """Python序列化的概念很简单.内存里面有一个数据结构, 你希望将它保存下来,重用,或者发送 ...
- Python pickle模块
python的pickle模块实现了基本的数据序列和反序列化.通过pickle模块的序列化操作我们能够将程序中运行的对象信息保存到文件中去,永久存储:通过pickle模块的反序列化操作,我们能够从文件 ...
- Python pickle 模块
转自:https://www.cnblogs.com/lincappu/p/8296078.html pickle可以存储的数据类型 所有python支持的原生类型:布尔值,整数,浮点数,复数,字符串 ...
- python -pickle模块、re模块学习
pickel模块 import pickle #pickle可以将任何数据类型序列化,json只能列表字典字符串数字等简单的数据类型,复杂的不可以 #但是pickle只能在python中使用,json ...
- python pickle模块的用法
pickle用于python特有的类型,和python的数据类型间进行转换,提供四个功能 dumps,dump,loads,load. pickle 的用法 #pickle.dumps 将数据通过特殊 ...
- python——pickle模块的详解
pickle模块详解 该pickle模块实现了用于序列化和反序列化Python对象结构的二进制协议. “Pickling”是将Python对象层次结构转换为字节流的过程, “unpickling”是反 ...
- python pickle 模块的使用详解
用于序列化的两个模块 json:用于字符串和Python数据类型间进行转换 pickle: 用于python特有的类型和python的数据类型间进行转换 json提供四个功能:dumps,dump,l ...
- Python——pickle模块(永久存储)
一.作用 讲字典.列表.字符串等对象进行持久化,存储到磁盘上,方便以后使用. 二.dump()方法 pickle.dump(对象,文件,[使用协议]) 作用:将要持久化的数据“对象”,保存到“文件中” ...
随机推荐
- win7 解决IE浏览器不能打开网页的问题
网络连接和网络映射正常,ping命令正常,但是无法上网. 以管理员身份运行命令行,在弹出的窗口中运行如下命令: netsh winsock reset catalog netsh int ip res ...
- c++unsigned char的输出问题
unsigned char的范围是0~255,在用cout输出的时候要显示数字的话记得进行int的强制转化才可以,否则都是输出的字符,除此之外的所有比较转换成整数在做比较吧 除此之外,在最近的项目里由 ...
- 回文数组(Rotate Array (JS))
旋转一个数组. function rotate(array,n){ var l =array.length,a=array.map(function(x){return x}),arr=[]; n=n ...
- Java高级规范之三
三十一.如果变量名要加注释,说明命名不是很准确. 不规范示例:暂无 规范实例:暂无 解析:暂无 三十二.任何类字段除非必要,否则都要私有化 不规范示例: public class Person{ St ...
- T卡热插拔
1.配置: GPIO 管脚 GPIO方向 Debounce polarity Sensitive_level Host1 CDpin (EINT16) 16 INPUT PULL UP Enable ...
- 《JavaScript_DOM编程艺术第二版(中文)》整书笔记
目录 第3章:DOM 第4章:案例研究 第5章:最佳实践 第6章:案例改进 第7章:动态创建标记 第8章:充实文档的内容 第9章:CSS-DOM 第3章:DOM 文档:DOM中的"D&quo ...
- android 5.0以下版本使用atof报错解决
经过测试,如果手机系统在5.0之下,项目project.properties的target若在5.0以上(android-20), NDK 使用atof就会报错: cannot locate symb ...
- 《剑指offer》面试题11: 数值的整数次方
面试题11: 数值的整数次方 剑指offer面试题11,题目如下 实现函数double power(double base,int exponent),求base的exponent次方, 不得使用库 ...
- js日期时间计算天数
var stime = new Date('2016-03-14'); //开始时间 var etime = new Date('2016-03-20'); //结束时间 var times = et ...
- linux curl 下载jdk
进入orecle官网,找到需要的安装包 需要cookie同意相关协议才能下载 curl -L "http://download.oracle.com/otn-pub/java/jdk/8u1 ...