序列化

定义:程序运行时所有变量都存在内存中,把变量从内存中变成可存储或可传输的过程称为序列化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. 测试rar/bz2/tar.gz/gz压缩文档完整性

    #gz文件gzip -t *.gz#bz2文件tar jtvf archive.tar.bz2#tar.gz文件tar jtvf archive.tar.gz#rar文件unrar t 1.rar

  2. mysql 版本bug

    mysql命令gruop by报错this is incompatible with sql_mode=only_full_group_by 在mysql 工具 搜索或者插入数据时报下面错误: ERR ...

  3. CString 作为参数执行都不执行

    static int LoadUsbSDK(CString curpath ) win10系统下 CString 函数加载dll直接跳过 加载dll最好不要带参数

  4. Linux 磁盘分区存放文件和目录的数量 (inode)

    文件系统格式centos7缺省是xfs,centos6缺省是ext4,centos5缺省是ext3ext3 文件数最大支持31998个,文件系统容量最大16TB,单个文件最大2TBext4 文件数最大 ...

  5. ip白名单 通过* ? 检测IP匹配 轻量级

    #include "stdafx.h" #include <windows.h> #include <string.h> #include <asse ...

  6. winsock select 学习代码(1)

    // SelectCli.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <winsock2.h> #incl ...

  7. 【JDBC&Dbutils】JDBC&JDBC连接池&DBUtils使用方法(重要)

    -----------------------JDBC---------- 0.      db.properties文件 driver=com.mysql.jdbc.Driver url=jdbc: ...

  8. 2018.10.20 NOIP模拟 蛋糕(线段树+贪心/lis)

    传送门 听说是最长反链衍生出的对偶定理就能秒了. 本蒟蒻直接用线段树模拟维护的. 对于第一维排序. 维护第二维的偏序关系可以借助线段树/树状数组维护逆序对的思想建立权值线段树贪心求解. 代码

  9. 2018.10.17 NOIP模拟 发电机(概率dp)

    传送门 考试空间开大了爆零不然只有30分爆栈? 话说这题真的坑1e7没法写dfsdfsdfs 其实很好推式子. 考虑每个点安一个发动机的概率,推一波式子做个等比数列求和什么的可以证明出来是严格的1si ...

  10. java.sql.SQLException: null, message from server: "Host 'xxx' is not allowed to connect to this MySQL server"

    java.sql.SQLException: null,  message from server: "Host 'xxx' is not allowed to connect to thi ...