python 序列化,反序列化
附:
pickle 有大量的配置选项和一些棘手的问题。对于最常见的使用场景,你不需要去担心这个,是如果你要在一个重要的程序中使用pickle 去做序列化的话,最好去查阅一下官方文档。
https://docs.python.org/3/library/pickle.html
----定义
通过将对象序列化可以将其存储在变量或者文件中,可以保存当时对象的状态,实现其生命周期的延长。并且需要时可以再次将这个对象读取出来。
----pickle模块
存变量里
--1--序列化对象,然后存储在变量中
>>> dic={'age':23,'job':'student'}
>>> byte_data=_pickle.dumps(dic)
>>> print(byte_data)
b'\x80\x03}q\x00(X\x03\x00\x00\x00jobq\x01X\x07\x00\x00\x00studentq\x02X\x03\x00\x00\x00ageq\x03K\x17u.'
>>>
--2--反序列化,把变量转换成对象
>>> obj=_pickle.loads(byte_data)
>>> print(obj)
{'job': 'student', 'age': 23}
>>>
存文件里
--1--序列化,把对象存储在文件中
Class Person:
def __init__(self,name,age,job):
self.name=name
self.age=age
self.job=job def work(self):
print(self.name,'is working....') >>> with open(r'c:\Temp\Person.pkl','wb') as f:
pickle.dump(r'c:\Temp\Person.py',f) >>>
--1--反序列化,把文件内容恢复成对象
with open('person.pkl', 'rb') as f:
    Person = pickle.load(f)
    aa = Person('gg', 23, '6')
    aa.work()
(type error:str object is not callable)老是这个错,不知道啥原因
json模块
json是更标准的格式,有更好的可读性和跨平台性
--序列化成字符串
dic = {'age': 23, 'job': 'student'}
dic_str = json.dumps(dic)
print(type(dic_str), dic_str)
# out: <class 'str'> {"age": 23, "job": "student"}
dic_obj = json.loads(dic_str)
print(type(dic_obj), dic_obj)
# out: <class 'dict'> {'age': 23, 'job': 'student'}
dumps函数将对象转换成了字符串。loads函数又将其恢复成字典。
--存储为文件
class Person:
def __init__(self, name, age, job):
self.name = name
self.age = age
self.job = job def work(self):
print(self.name, 'is working...')
aa = Person('Bob', 23, 'Student')
with open('abc.json', 'w', encoding='utf-8') as f:
    json.dump(aa, f) # 报错
Object of type 'Person' is not JSON serializable此时dump函数里传一个参default就可以了,这个参数接受一个函数,这个函数可以将对象转换为字典。
def person2dict(person):
return {'name': person.name,
'age': person.age,
'job': person.job}
这样返回的就是一个字典了,对象实例有个方法可以简化这一过程。直接调用实例的__dict__。例如 print(aa.__dict) # {'name': 'Bob', 'age': 23, 'job': 'Student'}
同时在读取的时候load出来的是一个字典,再转回对象就可,同样需要一个object_hook参数,该参数接收一个函数,用于将字典转为对象。
def dict2person(dic):
return Person(dic['name'], dic['age'], dic['job'])
with open('abc.json', 'w', encoding='utf-8') as f:
    json.dump(aa, f, default=person2dict)
with open('abc.json', encoding='utf-8') as f:
    obj = json.load(f, object_hook=dict2person)
    print(obj.name, obj.age, obj.job)
    obj.work()
由于可以使用__dict__代替person2dict函数,再使用lambda函数简化。
with open('abc.json', 'w', encoding='utf-8') as f:
   json.dump(aa, f, default=lambda obj: obj.__dict__)
shelve模块
通常使用一个open就好。shelve以键值对的形式存储数据
with shelve.open('aa', writeback=True) as f:
    dic = {'age': 23, 'job': 'student'}
    f['person'] = dic
    dic['age'] = 44
    f['person'] = dic
相当于赋值了两次,这种方法是可以改变值的。
默认情况下直接使用f['person']改变其中的值之后,不会更新已存储的值,也就是没有把更新写回到文件,即使是文件被close后。如果有此需要,在open函数中添加一个参数writeback=True。再次运行下看看年龄就被改变了。
写入自定义对象
依然使用上面的Person对象
with shelve.open('aa') as f:
    f['class'] = Person
# 写入类本身
with shelve.open('aa') as f:
    Person = f['class']
    a = Person('Bob', 23, 'Student')
    a.work()
上面的例子说明shelve也可以序列化类本身。当然序列化实例肯定可以。
with shelve.open('aa') as f:
    a = Person('God', 100, 'watch')
    f['class'] = a
with shelve.open('aa') as f:
    god = f['class']
    god.work()
参考
https://www.cnblogs.com/sun-haiyu/p/7087088.html
python 序列化,反序列化的更多相关文章
- python: 序列化/反序列化及对象的深拷贝/浅拷贝
		一.序列化/反序列化 python中内置了很多序列化/反序列化的方式,最常用的有json.pickle.marshal这三种,示例用法如下: import json import pickle imp ... 
- Python序列化和反序列化
		Python序列化和反序列化 通过将对象序列化可以将其存储在变量或者文件中,可以保存当时对象的状态,实现其生命周期的延长.并且需要时可以再次将这个对象读取出来.Python中有几个常用模块可实现这一功 ... 
- Python 序列化与反序列化
		序列化是为了将内存中的字典.列表.集合以及各种对象,保存到一个文件中(字节流).而反序列化是将字节流转化回原始的对象的一个过程. json库 序列化:json.dumps() 反序列化:json.lo ... 
- python序列化与反序列化(json、pickle)-(五)
		1.什么是序列化&反序列化? 序列化:将字典.列表.类的实例对象等内容转换成一个字符串的过程. 反序列化:将一个字符串转换成字典.列表.类的实例对象等内容的过程 PS:Python中常见的数据 ... 
- python_way ,day5  模块,模块3  ,双层装饰器,字符串格式化,生成器,递归,模块倒入,第三方模块倒入,序列化反序列化,日志处理
		python_way.day5 1.模块3 time,datetime, json,pickle 2.双层装饰器 3.字符串格式化 4.生成器 5.递归 6.模块倒入 7.第三方模块倒入 8.序列化反 ... 
- python 序列化之JSON和pickle详解
		JSON模块 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的文本格式,但是也使用了类 ... 
- python序列化pickle/cPickle
		一.pickle/Cpickle简介 Python序列化的概念很简单.内存里面有一个数据结构,你希望将它保存下来,重用,或者发送给其他人.你会怎么做?这取决于你想要怎么保存,怎么重用,发送给谁.很多游 ... 
- python序列化与反序列
		python序列化与反序列 在python中提供了两个模块可进行序列化.分别是pickle和json.他们两者的功能都差不多,dumps和dump都是进行序列化,而loads和load则是反序列化. ... 
- Python 序列化pickle/cPickle模块整理
		Python序列化的概念很简单.内存里面有一个数据结构,你希望将它保存下来,重用,或者发送给其他人.你会怎么做?这取决于你想要怎么保存,怎么重用,发送给谁.很多游戏允许你在退出的时候保存进度,然后你再 ... 
- Python序列化、date、random、os模块
		知识点一:序列化与反序列化(json和pickple) 01 什么是序列化/反序列化 序列化就是将内存中的数据结构转换成一种中间格式存储到硬盘或者基于网络传输 发序列化就是硬盘中或者网络中 ... 
随机推荐
- (1.9)SQL优化——mysql导入导出优化
			(1.9)SQL优化——mysql导入导出优化 1.大批量插入数据 [1.1]MyISAM: (1)如果存在表且有数据,插入前先关闭所有非唯一索引. (2)如果表是空的,默认就是先导入数据再创建索引, ... 
- iOS添加pch文件
			1.第一步,创建pch文件 第二步设置pch文件:相对地址,填写$(SRCROOT)/YTCompleteCarSell/PrefixHeader.pch $(SRCROOT)是项目地址/项目名/p ... 
- Linux下高并发socket最大连接数各种限制的调优
			1.修改用户进程可打开文件数限制 在Linux平台上,无论编写客户端程序还是服务端程序,在进行高并发TCP连接处理时,最高的并发数量都要受到系统对用户单一进程同时可打开文件数量的限制(这是因为系统为每 ... 
- 限制SSH用户访问Linux中指定的目录
			限制SSH用户访问Linux中指定的目录 http://os.51cto.com/art/201703/534895.htm#topx http://www.cnblogs.com/lykyl/arc ... 
- Ubuntu如何修改默认python版本为python3
			修改默认python版本 Ubuntu系统内置python2.7版本,默认运行python就是运行python2.7.现在很多人都是用python3作为开发语言,我们需要修改python的默认版本为p ... 
- Jmeter原理
			Jmeter结构体系及运行原理 Jmeter结构体系 把Jmeter的结构体系拆分为三维空间,如图: X1~X5:是负载模拟的一个过程,使用这些组件来完成负载的模拟: X1:选择协议,模拟用户请求 ... 
- url映射
			#include<iostream> #include<algorithm> #include<ctype.h> #include<string> #i ... 
- Redis入门到高可用(二)—— Redis启动及使用
			1. 三种启动方式 ♦️ 最简启动 ./redis-server 使用Redis默认配置进行启动; ♦️ 动态参数启动 * redis-server --port 6380 更改端口为6380并 ... 
- Cartographer源码阅读(3):程序逻辑结构
			Cartographer早期的代码在进行3d制图的时候使用了UKF方法,查看现有的tag版本,可以转到0.1.0和0.2.0查看,包含kalman_filter文件夹. 文件夹中的pose_track ... 
- Python 数据结构 链表
			什么是时间复杂度 时间频度:一个算法执行所耗费的时间,从理论上是不能算出来的,必须上机运行测试才知道.但是我们不可能也没有必要对每一个算法都进行上机测试,只需要知道那个算法花费的时间多,那个算法花费得 ... 
