模块讲解----pickle模块(只在python用的序列化与反序列化)
特点
import pickle
#dumps
li = [11,22,33]
r = pickle.dumps(li)
print(r) #loads
result = pickle.loads(r)
print(result)
二、文本中操作:
#dump:
li = [11,22,33]
pickle.dump(li,open('db','wb')) #load
ret = pickle.load(open('db','rb'))
print(ret)
三、练习:
pickle的序列化:
格式:pickle.dumps(序列化对象)
#!/usr/bin/env python
# -*- coding:utf8 -*-
# Author:Dong Ye import pickle test = r'test.txt' #反序列化代码中也要定义相同的函数名称,函数体没限制
def sayhi(name):
print("hello",name) info = {
'':'',
'age':32,
'func':sayhi
} print(pickle.dumps(info)) with open(test,'wb') as f:
f.write( pickle.dumps(info) )
pickle返序列化:
格式:pickle.loads(读取文件逐行记录)
#!/usr/bin/env python
# -*- coding:utf8 -*-
# Author:Dong Ye import pickle test = r'test.txt' #需要定义序列化代码中同样的函数名,函数体没限制
def sayhi(name):
print("hello",name)
print("hello2",name) with open(test,'rb') as f:
data = pickle.loads(f.read())
print('data>>>',data) print(data['func']("Alex")) 显示结果:
data>>> {'': '', 'age': 32, 'func': <function sayhi at 0x00000000007DF1E0>}
hello Alex
hello2 Alex
None 注意:
1、print(data['func']("Alex"))时,调用了pickle的反序列化变量data。 2、需要在序列化和反序列化定义相同的函数名称,但内容可以不一样。否则报错如下:
E:\python35\python.exe D:/软件/pychar/data/s13/序列化与反序列化/pickle反序列化.py
Traceback (most recent call last):
File "D:/软件/pychar/data/s13/序列化与反序列化/pickle反序列化.py", line 16, in <module>
data = pickle.loads(f.read())
AttributeError: Can't get attribute 'sayhi' on <module '__main__' from 'D:/软件/pychar/data/s13/序列化与反序列化/pickle反序列化.py'>
原因是反序列化脚本中,没有sayhi函数的内存地址: 3、由于pickle序列化是序列了整个对象,而非某个内存地址,因此在反序列化时,也调用了整个序列对象。所以反序列化对象时,sayhi函数的函数体可以不一样。
写入文件并序列化
import pickle test = r'test.txt' #反序列化代码中也要定义相同的函数名称,函数体没限制
def sayhi(name):
print("hello",name) info = {
'':'',
'age':32,
'func':sayhi
} print(pickle.dumps(info)) with open(test,'wb') as f:
#f.write( pickle.dumps(info) )
pickle.dump(info,f) #跟上面的f.write( pickle.dumps(info) )语意完全一样。
import pickle test = r'test.txt' #需要定义序列化代码中同样的函数名,函数体没限制
def sayhi(name):
print("hello",name)
print("hello2",name) with open(test,'rb') as f:
# data = pickle.loads(f.read())
data = pickle.load(f) #跟上面的data = pickle.loads(f.read())语意完全一样。
print('data>>>',data) print(data['func']("Alex"))
模块讲解----pickle模块(只在python用的序列化与反序列化)的更多相关文章
- Python基础(12)_python模块之sys模块、logging模块、序列化json模块、pickle模块、shelve模块
5.sys模块 sys.argv 命令行参数List,第一个元素是程序本身路径 sys.exit(n) 退出程序,正常退出时exit(0) sys.version 获取Python解释程序的版本信息 ...
- python中序列化json模块和pickle模块
内置模块和第三方模块 json模块和pickle 模块(序列化模块) 什么是序列化? 序列化就是将内粗这种的数据类型转成另一种格式 序列化:字典类型——>序列化——>其他格式——>存 ...
- Python之路(第十五篇)sys模块、json模块、pickle模块、shelve模块
一.sys模块 1.sys.argv 命令行参数List,第一个元素是程序本身路径 2.sys.exit(n) 退出程序,正常退出时exit(0) 3.sys.version . sys.maxint ...
- Python 入门之 内置模块 -- 序列化模块(json模块、pickle模块)
Python 入门之 内置模块 -- 序列化模块(json模块.pickle模块) 1.序列化 Python中这种序列化模块有三种: json模块 : 不同语言都遵循的一种数据转化格式,即不同 ...
- Python库:序列化和反序列化模块pickle介绍
1 前言 在“通过简单示例来理解什么是机器学习”这篇文章里提到了pickle库的使用,本文来做进一步的阐述. 通过简单示例来理解什么是机器学习 pickle是python语言的一个标准模块,安装pyt ...
- python学习第四十八天json模块与pickle模块差异
在开发过程中,字符串和python数据类型进行转换,下面比较python学习第四十八天json模块与pickle模块差异. json 的优点和缺点 优点 跨语言,体积小 缺点 只能支持 int st ...
- json模块和pickle模块
json模块和pickle模块 一.json模块 作用:用python写了一个程序,用java写了一门程序,这两个程序需要数据之间交流,就产生了一种多种语言通用的数据类型,json串. 序列化:把对象 ...
- Json模块和Pickle模块的使用
在对数据进行序列化和反序列化是常见的数据操作,Python提供了两个模块方便开发者实现数据的序列化操作,即 json 模块和 pickle 模块.这两个模块主要区别如下: json 是一个文本序列化格 ...
- python类库32[序列化和反序列化之pickle]
一 pickle pickle模块用来实现python对象的序列化和反序列化.通常地pickle将python对象序列化为二进制流或文件. python对象与文件之间的序列化和反序列化: pi ...
随机推荐
- java连接数据库的基本操作
ResultSet保存查询的table数据,就像mysql的客户端显示的查询类容,但这中间还是藏有很多信息.
- H - The Frog's Games
The annual Games in frogs' kingdom started again. The most famous game is the Ironfrog Triathlon. On ...
- hadoop 使用ip配置导致hdfs启动失败
dataNode 有守护进行,但hdfs web页面上显示没有live node. 错误日志: 2017-06-21 17:44:59,513 ERROR org.apache.hadoop.hdfs ...
- [No0000147]深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing)理解堆与栈4/4
前言 虽然在.Net Framework 中我们不必考虑内在管理和垃圾回收(GC),但是为了优化应用程序性能我们始终需要了解内存管理和垃圾回收(GC).另外,了解内存管理可以帮助我们理解在每一个程 ...
- 线上bug处理
http:response X-Frame-Options是什么? x-frame-options是一个HTTP响应头,用来告诉浏览器这个网页是否可以放在iframe内. x-frame-option ...
- 2017年蓝桥杯省赛A组c++第6题(字符串匹配算法填空)
/* 标题:最大公共子串 最大公共子串长度问题就是: 求两个串的所有子串中能够匹配上的最大长度是多少. 比如:"abcdkkk" 和 "baabcdadabc" ...
- iOS-原生纯代码约束总结(一)之 AutoresizingMask
一,概述 iOS有两大自动布局利器:autoresizing 和 autolayout(autolayout是IOS6以后新增).autoresizing是UIView的属性,一直存在,使用也比较简单 ...
- Xcode报错Expected selector for Objective-C and Expected method body
昨天把键盘拿起来拍一下清清灰,然后就发现Xcode报错了,Xcode报错Expected selector for Objective-C and Expected method body,也不知道什 ...
- java 网络编程(四)TCP通讯
客户端: package cn.sasa.TcpDemo; import java.io.IOException; import java.io.InputStream; import java.io ...
- 洛谷P3295 萌萌哒 [SCOI2016] 倍增+并查集
正解:倍增+并查集 解题报告: 传送门! 首先不难想到暴力?就考虑把区间相等转化成对应点对相等,然后直接对应点连边,最后求有几个连通块就好辣 然后看下复杂度,修改是O(n2)查询是O(n),就比较容易 ...