pickle、shelve,python私有,支持所有python数据类型

一、pickle

dic={'name':'egon','age':18}

print(pickle.dumps(dic))    ##得到的是一个bets类型数据

with open('d.pickle','wb') as f:      #bets类型需要用wb模式打开
f.write(pickle.dumps(dic)) #序列化 ##反序列化
with open('d.pickle','rb') as f: #bets类型需要用b模式打开
data=pickle.loads(f.read())
print(data['name'])

简单版本: 


##1、第一步
dic = {'name': 'egon', 'age': 18}
pickle.dump(dic, open('e.pickle', 'wb')) ##第二步,可以在其它py程序中实现反序列化
data = pickle.load(open('e.pickle', 'rb'))
print(data['name'])

用json来序列化函数?
def func():
print('from func') import json json.dump(open('s.json','w')) 注意报错:说,函数不是一个json可序列化的对象
用plckle来序列化函数?

def func():
print('from func') import pickle print(pickle.dumps(func)) #b'\x80\x03c__main__\nfunc\nq\x00.' :pickle可以序列化函数 pickle.dump(func,open('func.pickle','wb')) #序列化函数 ###然后去 pickle_反序列化.py文件里把函数反序列化出来

 

报错AttributeError: Can't get attribute 'func' on <module '__main__' from 
'D:/python-笔记/day5/pickle_module/pickle_反序列化.py'> 注意:序列化的时候是序列化的内存地址,没有把函数的值序列化进去,如果反序列化的时候找不到内存地址,会报错。

 

序列化类

# class Foo:
# pass
#
#
# obj1=Foo()
# obj2=Foo()
#
# #### print(obj1 is obj2) #False
# #### 需求:把两个对象保存下来
#
# pickle.dump(obj1,open('class_obj1.pickle','wb'))
# pickle.dump(obj2,open('class_obj2.pickle','wb')) #成功序列化类 问题来了,反序列化怎么做,把上面的class Foo,obj1=Foo()obj2=Foo() 全部注释掉 import pickle pickle.load(open('class_obj1.pickle','rb')) #报错,因为Foo不存在了,无法反序列化

二、shelve

1、shelve_模块从文件中取数据

import shelve

obj=shelve.open(r'sheve.shl')    #取数据的时候只需要记住文件名,打开这个文件会得到一个对象,赋值给obj
print(obj['xiechao'])
print(obj['wangyanli']) for i in obj:
print(i,obj[i]) #得出来的是字典的k,v obj.close() #最后别忘记了关闭

二、shelve_模块保存数据到文件

shelve模块是一个简单的k,v将内存数据通过文件持久化的模块,可以持久化任何pickle可支持的python数据格式

注意:shelve只支持python ,不能跨平台

import shelve

f = shelve.open(r'sheve.shl')  #可以写一个文件路径

##需要把谢超的信息永久存放下来

f['xiechao']={'age':18,'pwd':'0621'}
f['wangyanli']={'age':22,'pwd':'0621'}
f['zhujingjing']={'age':34,'pwd':'0621'}
f['jingjingzhu']={'age':44,'pwd':'0621'}
f['jingjingZH']={'age':43,'pwd':'0621'} #写完直接自动保存到文件里去了 f.close()

shelve模块比pickle模块简单,只有一个open函数,返回类似字典的对象,可读可写;key必须为字符串,而值可以是python所支持的数据类型  

import shelve

f=shelve.open(r'sheve.txt')
# f['stu1_info']={'name':'egon','age':18,'hobby':['piao','smoking','drinking']}
# f['stu2_info']={'name':'gangdan','age':53}
# f['school_info']={'website':'http://www.pypy.org','city':'beijing'} print(f['stu1_info']['hobby'])
f.close()

  

  

day6_python之pickle、shelve序列化和反序列化的更多相关文章

  1. json —— pickle 的序列化和反序列化

    前言json的序列化和反序列化 1, json 只能序列化简单的数据类型,如,列表,字典,字符串,等简单的类型,不能序列化复杂的类型. 2, json 是支持所有的语言的,多以我们跨语言的时候都是用j ...

  2. python基础学习1-json,pickle的序列化和反序列化

    import requests import json dic={'k1':'v1'} print(dic,type(dic)) result = json.dumps(dic)#调用dumps方法把 ...

  3. python:序列化与反序列化(json、pickle、shelve)

    本节内容 前言 json模块 pickle模块 shelve模块 总结 一.前言 1. 现实需求 每种编程语言都有各自的数据类型,其中面向对象的编程语言还允许开发者自定义数据类型(如:自定义类),Py ...

  4. 序列化与反序列化,json,pickle,xml,shelve,configparser模块

    序列化与反序列化 什么是序列化?序列化就是将内存中的数据结构转换成一种中间格式存储到硬盘或者基于网络传输.反序列化就是将硬盘中或者网络中传来的一种数据格式转换成内存中数据结构. 为什么要有? 1.可以 ...

  5. day5-python中的序列化与反序列化-json&pickle

    一.概述 玩过稍微大型一点的游戏的朋友都知道,很多游戏的存档功能使得我们可以方便地迅速进入上一次退出的状态(包括装备.等级.经验值等在内的一切运行时数据),那么在程序开发中也存在这样的需求:比较简单的 ...

  6. python模块--json \ pickle \ shelve \ XML模块

    一.json模块 之前学习过的eval内置方法可以将一个字符串转成一个python对象,不过eval方法时有局限性的,对于普通的数据类型,json.loads和eval都能用,但遇到特殊类型的时候,e ...

  7. 第十八天python3 序列化和反序列化

    思考: 内存中的字典.列表.集合以及各种对象,如何保存到一个文件中? 如果是自己定义的类的实例,如何保存到一个文件中? 如何从文件中读取数据,并让它们在内存中再次变成自己对应的类的实例? 要设计一套协 ...

  8. day6_python序列化之 json & pickle & shelve 模块

    一.json & pickle & shelve 模块 json,用于字符串 和 python数据类型间进行转换pickle,用于python特有的类型 和 python的数据类型间进 ...

  9. Python—序列化和反序列化模块(json、pickle和shelve)

    什么是序列化 我们把对象(或者变量)从内存中变为可存储或者可传输的过程称为序列化.在python中为pickling,在其他语言中也被称之为serialization,marshalling,flat ...

随机推荐

  1. maven打包时无法识别lombok中@Data生成的get set方法

    开发中使用了lombok,在使用maven编译打包时发现识别不了lombok通过注解@Data在实体类中生成的get,set方法.通过在网上的一篇博客找到了解决的办法,将maven-compiler- ...

  2. Java中用JXL导出Excel代码详解

    jxl是一个韩国人写的java操作excel的工具, 在开源世界中,有两套比较有影响的API可供使用,一个是POI,一个是jExcelAPI.其中功能相对POI比较弱一点.但jExcelAPI对中文支 ...

  3. Linux环境变量的种类

    按环境变量的生存周期来划分,Linux的环境变量可分为两类: 1永久的:需要修改配置文件,变量永久生效. 2临时的:使用export命令行声明即可,变量在关闭shell时失效.

  4. 洛谷P2826 [USACO08NOV]光开关Light Switching [2017年6月计划 线段树02]

    P2826 [USACO08NOV]光开关Light Switching 题目描述 Farmer John tries to keep the cows sharp by letting them p ...

  5. 洛谷P1080 [NOIP2012提高组D1T2]国王游戏 [2017年5月计划 清北学堂51精英班Day1]

    P1080 国王游戏 题目描述 恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右 手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 n 位大臣排 ...

  6. 【JZOJ3295】【SDOI2013】泉(spring)

    ╰( ̄▽ ̄)╭ 济南市"泉历史研究小组"依据济南特有的泉脉关系将济南的泉水分为六个区域,分别是市中区.历下区.天桥区.槐荫区.历城区.长清区. 作为光荣的济南泉历史研究小组中的一员 ...

  7. 转搞定python多线程和多进程

    转自https://www.cnblogs.com/whatisfantasy/p/6440585.html 1 概念梳理: 1.1 线程 1.1.1 什么是线程 线程是操作系统能够进行运算调度的最小 ...

  8. 常用css3属性

    总结一下在工作用常用到的属性设置 1.设置文本的可选择性 -webkit-user-select:none/text 2.设置背景的绘制区域 background-clip:border-box/pa ...

  9. I / O流 类

    一.概述 1 基本概念 I/O就是Input/Output的简写,也就是输入/输出的含义. I/O流就是指像流水一样源源不断地进行读写的过程.   2 基本分类   根据读写数据的单元分为:字节流 和 ...

  10. [运维]ESXI Web Client 标签: vmware运维服务器 2017-05-28 20:59 597人阅读 评论(9)

    ESXI安装完成之后,配置好ip,我们就可以使用了?那么如何使用呢?一般来说有两种方式,一种是安装专门的管理客户端,client端,另一种更加方便,就是使用web client端. 下面来介绍一下es ...