【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(对象,文件,[使用协议]) 作用:将要持久化的数据“对象”,保存到“文件中” ...
随机推荐
- Ubuntu系统下Xen虚拟机的基本安装方法(代码创建)
Ubuntu上Xen安装虚拟机方法一dd一个空的磁盘sudo dd if=/dev/zero of=/home/vm1.img bs=1G count=8 下载Xen VM通用配置文件 sudo wg ...
- Microsoft Visual C++ Compiler for Python 2.7
Extest.c文件:#include <stdio.h> #include <stdlib.h>#include <string.h>#include " ...
- PHP 爬取网页中表格数据
public function spider_j($page) { $url="http://aaa/bbb".$page."_0/"; $fcontents= ...
- C#求任意范围内的质数
class Program { public static List<int> list; static void Main(string[] args) { Console.WriteL ...
- MSSQL如何在没有主键的表中删除重复数据
为了对重复数据进行实验,下面建一个设计不太好(没有主键)表并插入了一些重复数据: create database testdb use testdb ; go create table DupsNoP ...
- 获得触发hover事件的元素id
例: <div class="menu"> <ul> <li> <a id="menu1"></a> ...
- swf格式文件如何修改里面的动作路径或者动作脚本(没有源文件的情况)
一.UrlActionEditor汉化版,这个工具是非常的简单和使用,直接把你需要需要修改的swf格式的flash文件在这里面打开 二.如果需要更加详细的修改可以下载一个SWFDecompiler4. ...
- JavaScript中本地对象、内置对象和宿主对象
链接:http://www.cnblogs.com/luckyXcc/p/5892896.html(Milk.╮的博客园提供) 其中内置对象只有两种:ECMA-262 只定义了两个内置对象,即 Glo ...
- yii 初步安装
第一步: window下点击>开始 >运行CMD命令. 第二步:进入Yiic文件的目录 (例如在D盘里面 D:/yii/framework) 第三步:D:\yii\framework& ...
- Scrollview嵌套listview
//建立Scrollview类 public class MyScrollView extends ScrollView { public MyScrollView(Context context, ...