序列化:

变量从内存中变成可存储或传输的过程称之为序列化。序列化之后,就可以把序列化后的内容写入磁盘,或者通过网络传输到别的机器上。叫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写入的是二进制数据,所以打开方式需要以wbrb的模式。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模块的更多相关文章

  1. [转]python pickle模块

    持久性就是指保持对象,甚至在多次执行同一程序之间也保持对象.通过本文,您会对 Python对象的各种持久性机制(从关系数据库到 Python 的 pickle以及其它机制)有一个总体认识.另外,还会让 ...

  2. python pickle 模块的使用

    用于序列化的两个模块 json:用于字符串和Python数据类型间进行转换 pickle: 用于python特有的类型和python的数据类型间进行转换 json提供四个功能:dumps,dump,l ...

  3. python pickle模块的使用/将python数据对象序列化保存到文件中

    # Python 使用pickle/cPickle模块进行数据的序列化 """Python序列化的概念很简单.内存里面有一个数据结构, 你希望将它保存下来,重用,或者发送 ...

  4. Python pickle模块

    python的pickle模块实现了基本的数据序列和反序列化.通过pickle模块的序列化操作我们能够将程序中运行的对象信息保存到文件中去,永久存储:通过pickle模块的反序列化操作,我们能够从文件 ...

  5. Python pickle 模块

    转自:https://www.cnblogs.com/lincappu/p/8296078.html pickle可以存储的数据类型 所有python支持的原生类型:布尔值,整数,浮点数,复数,字符串 ...

  6. python -pickle模块、re模块学习

    pickel模块 import pickle #pickle可以将任何数据类型序列化,json只能列表字典字符串数字等简单的数据类型,复杂的不可以 #但是pickle只能在python中使用,json ...

  7. python pickle模块的用法

    pickle用于python特有的类型,和python的数据类型间进行转换,提供四个功能 dumps,dump,loads,load. pickle 的用法 #pickle.dumps 将数据通过特殊 ...

  8. python——pickle模块的详解

    pickle模块详解 该pickle模块实现了用于序列化和反序列化Python对象结构的二进制协议. “Pickling”是将Python对象层次结构转换为字节流的过程, “unpickling”是反 ...

  9. python pickle 模块的使用详解

    用于序列化的两个模块 json:用于字符串和Python数据类型间进行转换 pickle: 用于python特有的类型和python的数据类型间进行转换 json提供四个功能:dumps,dump,l ...

  10. Python——pickle模块(永久存储)

    一.作用 讲字典.列表.字符串等对象进行持久化,存储到磁盘上,方便以后使用. 二.dump()方法 pickle.dump(对象,文件,[使用协议]) 作用:将要持久化的数据“对象”,保存到“文件中” ...

随机推荐

  1. Elasticsearch学习之入门2

    关于Elasticsearch的几个概念: 1)在Elasticsearch中,文档归属于类型type,而类型归属于索引index,为了方便理解,可以把它们与传统关系型数据库做类比: Relation ...

  2. PKU 1003解题

    首先庆祝一下,今天连A了3题.感觉后面这题太简单了.. 由于英文不好 ,找了个翻译: 若将一叠卡片放在一张桌子的边缘,你能放多远?如果你有一张卡片,你最远能达到卡片长度的一半.(我们假定卡片都正放在桌 ...

  3. NSURLSession使用说明及后台工作流程分析

    原文摘自http://www.cocoachina.com/industry/20131106/7304.html NSURLSession是iOS7中新的网络接口,它与咱们熟悉的NSURLConne ...

  4. JAVA 语法基础综合练习——学生成绩管理系统

    代码如下:package com.lovo.manager; import java.util.Scanner; /** * 学生管理 * * @author Administrator * */ p ...

  5. Activity packagename has leaked window android.widget.PopupWindow$PopupDecorView{4f92660 V.E...... .......D 0,0-455,600} that was originally added here

    原因是在销毁Activity时,Activity中的popupwindow还处于显示状态. 解决方法是重写Activity的onDestroy()方法,在Activity销毁前调用popupWindo ...

  6. BZOJ 2743 树状数组

    不能用分块. #include <bits/stdc++.h> using namespace std; ; struct Info{int l,r,Id;}Q[Maxn]; int a[ ...

  7. Freemark基本语法知识(转)

    FreeMarker的模板文件并不比HTML页面复杂多少,FreeMarker模板文件主要由如下4个部分组成: 1,文本:直接输出的部分 2,注释:<#-- ... -->格式部分,不会输 ...

  8. Shiro安全登录框架

    环境准备 本文使用Maven构建,因此需要一点Maven知识.首先准备环境依赖: <dependencies> <dependency> <groupId>juni ...

  9. Math类常用方法(Java)

    三角函数: public static double sin (double radians) public static double cos(double radians) public stat ...

  10. LINQ To SQL

    议程 1.LINQ To SQL概述 2.LINQ To SQL对象模型 3.LINQ To SQL查询 用到的数据库 SQL Server 2005,数据库名为Test. 两张表,分别为Studen ...