序列化

定义:程序运行时所有变量都存在内存中,把变量从内存中变成可存储或可传输的过程称为序列化pickling,在其他语言中称为serialization,marshalling,flattening等等,都是一个意思。

作用:序列化后可把序列化的内容存到磁盘,或者通过网络传输到其他机器上。

实现方式:cPickle和pickle,前者是c语言写的速度更快。

#用pickle.dumps()把任意对象序列化成一个str

try:

import cPickle as pickle

except ImportError:

import pickle

>>> d = dict(name='Bob', age=20, score=88)

>>> pickle.dumps(d)

"(dp0\nS'age'\np1\nI20\nsS'score'\np2\nI88\nsS'name'\np3\nS'Bob'\np4\ns."

#用pickle.dump(d,f)d = dict(name ='Bob',age=23, score=90)

f = open('py.txt','wb’)#在当前目录下新建了一个py.txt文件并将用wb方式处理文件

pickle.dump(d,f)

f.close()

反序列化unplickling:把序列化之后的内容重新读入内存中。

#如果是用一个str保存之前序列化后的内容,则用pickle.loads(str)得到反序列化后的内容:

d = dict(name='Bob',age=20,score = 90)

pd = pickle.dumps(d)

upd = pickle.loads(pd)

print upd

#如果用的是文件保存序列化后的内容,用pickle.load()反序列化

f =open('py.txt','rb')

d = pickle.load(f)

f.close()

print d

注意:pickle后的结果只能用于python且与py的版本有关,否则不兼容。所以pickle只能用到不重要的内容上。

JSON

定义:序列化的一种标准格式。python也内置了json模块。

作用:如果我们要在不同的编程语言之间传递对象,就必须把对象序列化为标准格式,比如XML,但更好的方法是序列化为JSON,因为JSON表示出来就是一个字符串,可以被所有语言读取,也可以方便地存储到磁盘或者通过网络传输。

#用json.dumps()把python对象序列化为json格式的str

import json

d = dict(name='Jane',age=23,score=90)

js = json.dumps(d)

print js

#用json.dump()把python对象标准序列化到指定文件

d = dict(name='Jane',age=23,score=90)

f = open('py.txt','wb')

json.dump(d,f)

f.close()

#用json.loads()和json.load()将json格式的内容反序列化

>>> json_str = '{"age": 20, "score": 88, "name": "Bob"}'

>>> json.loads(json_str)

u'age'20u'score'88u'name'u'Bob’格式默认utf-8编码

将类序列化为json与反序列化

#将定义一个dict的类序列化为json格式的str

import json

class Student(object):

def __init__(self,name,age,score):

self.name = name

self.age = age

self.score = score

s = Student('Jane',20,90)

def class2dict(inst):

return {

'name':inst.name,

'age':inst.age,

'score':inst.score

}

sjson = json.dumps(s,default=class2dict)#这时s先化为dict再被序列化为json

print sjson

#更简洁通用地让类实例序列化为dict

json.dumps(t,default=lambda obj:obj.__dict__)

#使用lambda时直接用一个语句定义函数+得到返回值

#每个类都有一个__dict__方法,用来储存各实例变量,除了一些定义了__slots__的class

#将json格式的类的实例反序列化为dict

import json

class Stu(object):

def __init__(self,name,age,score):

self.name = name

self.age=age

self.score=score

def dict2inst(i):

return Stu(i['name'],i['age'],i['score'])

json_dict = '{"score":90,"age":20,"name":"Jane"}'

print json.loads(json_dict,object_hook=dict2inst)

#先将dict转化为实例,再反序列化

廖雪峰Python学习笔记——序列化的更多相关文章

  1. 廖雪峰Python学习笔记——类和实例

    Class MyList(list): __metaclass__ = ListMetaclass #它表示在创建MyList这个类时,必须通过 ListMetaclass这个元类的LIstMetac ...

  2. 廖雪峰Python学习笔记——使用元类

    元类(MetaClasses) 元类提供了一个改变Python类行为的有效方式. 元类的定义是“一个类的类”.任何实例是它自己的类都是元类. class demo(object): pass obj ...

  3. python学习笔记 序列化

    在程序运行的过程中,所有的变量都是在内存中,比如,定义一个dict: d = dict(name='Bob', age=20, score=88) 可以随时修改变量,比如把name改成'Bill',但 ...

  4. 廖雪峰 JavaScript 学习笔记(字符串、数组和对象)

    字符串 1.和python一样,也是用' '或" "括起来的字符表示.但多行字符串是用反引号(esc下键)``,与之相对的是Python用''' '''三引号表示: 2.转义字符: ...

  5. 廖大大python学习笔记1

    列表classmates = ['Michael', 'Bob', 'Tracy']classmates.append('tom')print classmates# classmates.inser ...

  6. 《Git教程-廖雪峰》学习笔记

    一.创建版本库 ①初始化一个Git仓库:git init ②添加文件到Git仓库:1.git add<file> ;  2.git commit 二.时光机穿梭 ①查看工作区状态,文件是否 ...

  7. 廖雪峰 JavaScript 学习笔记(函数)

    JavaScript中,定义函数的方式如下: function abs(x) { if (x >= 0) { return x; } else { return -x; } } 上述abs()函 ...

  8. 廖雪峰 JavaScript 学习笔记(判断、循环)

    条件判断  固定格式:if () { ... } else { ... } ,else可选 1.多行条件判断,通常把else if连写在一起,来增加可读性 例子: var age = 3; if (a ...

  9. 廖雪峰JavaScript学习笔记(基础及数据类型、变量)

    先睹为快 alert('我要学JavaScript!'); Run: 基本语法: 1.每个语句以;结束,不强制 2.语句块用{...} 3.//单行注释,/*...*/ 多行注释 数据类型: 1.不区 ...

随机推荐

  1. php Pthread 多线程 (一) 基本介绍

    我们可以通过安装Pthread扩展来让PHP支持多线程.   线程,有时称为轻量级进程,是程序执行的最小单元.线程是进程中的一个实体,是被系统独立调度和分派的基本单位,线程自己不拥有系统资源,它与同属 ...

  2. Canvas游戏计算机图形教程

    TechbrooD   主站 WOW 登录   注册 0首页 1简介 1.1WWW 技术变迁和生态 1.2WWW 学习建议 1.3WWW 互联网基础知识 1.4WWW Web 1.5 WWW Web ...

  3. 开发中常遇到的Python陷阱和注意点-乾颐堂

    最近使用Python的过程中遇到了一些坑,例如用datetime.datetime.now()这个可变对象作为函数的默认参数,模块循环依赖等等. 在此记录一下,方便以后查询和补充. 避免可变对象作为默 ...

  4. Java 中>>和>>>的区别

    Java 中>>和>>>的区别 Java中的位运算符: >>表示右移,如果该数为正,则高位补0,若为负数,则高位补1: >>>表示无符号右移 ...

  5. URL编码转换函数:escape()、encodeURI()、encodeURIComponent()

          函数出现时间:                      escape()                                javascript 1.0           ...

  6. hdu-1142(记忆化搜索+dij)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1142 思路:1.不是求最短路径,而是求如果两个点A,B直接相连,且A到终点的距离大于B到终点的距离,求 ...

  7. 对于Serializable id类型的数据的测试

    今天编写了一个这样的例子,然后进行了Junit测试,但是发现类型总是不匹配,最后测出如下 public <T> void deleteEntry(Class<T> t, Ser ...

  8. (最小生成树)Constructing Roads -- poj -- 2421

    链接: http://poj.org/problem?id=2421 Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 2113 ...

  9. [转] ubuntu安装Sublime Text 3并使用SublimeClang插件

    原文地址:https://blog.csdn.net/cywosp/article/details/32721011 3. 安装强大的SublimeClang插件 SublimeClang是Subli ...

  10. genymotion无法连接相机问题

    genymotion模拟器即时打开了相机的开关,也无法连接到相机.这是因为其他进程占用了相机,虚拟设备无法获得,可以尝试: 1.不关闭模拟器,重启adt的Eclipse 2.重启ADB,adb kil ...