开发者

关于如何把Python对象存储为文件的方法详解

目录
  • 加载和保存
  • 注意事项
  • copyreg
  • 命令行工具

加载和保存

pickle中有两组加载和保存函数

保存加载
交互文件dumpload
交互字节码dumpsloads

例如

x = [i**2 for i in range(10)]
import pickle
s = pickle.www.devze.comdumps(x)
print(s)
# b'\x80\x0android4\x95\x19\x00\x00\x00\x00\x00\x00\x00]\x94(K\x00K\x01K\x04K\tK\x10K\x19K$K1K@KQe.'
with open("test.pickle", 'wb') as f:
   pickle.dump(x, f)        # 将x存为f

x存储为文件之后,还可以重新打开

with open("test.pickle", 'rb') as f:
    y = pickle.load(f)

print(y)
# [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]

注意事项

除了不够安全之外,使用pickle另外一个需要注意的是,到目前为止,pickle已经有6个版本,其中v0v1过于古老,基本没什么能用的地方;v3以后的版本则不再支持python2,下表列出了自v2v5的一些更新特性

引入版本文档
v2Python 2.3PEP307为 新式类 提供了更高效的封存机制。
v3Python 3.0显式地支持字节对象

为Python 3.0-3编程客栈.7lvAnZAqTOc 的默认协议。

v4Python 3.4PEP 3154支持存储较大对象,并针对数据格式进行了优化

Python 3.8使用的默认协议。

v5Python 3.8PEP 574增加对带外数据的支持,并可加速带内数据处理

理论上讲,pickle可以封装一切python对象,所以对于一些比较耗时的算法,可以通过pickle来保存当前的状态。但要注意,尽管pickle可以封存函数,但并不能封存匿名函数

test = lambda x : x
s = pickle.dumps(test)  # 报错
def test(x):
    print(x)

s = pickle.dumps(test)
print(s)
#b'\x80\x04\x95js\x15\x00\x00\x00\x00\x00\x00\x00\x8c\x08__main__\x94\x8c\x04test\x94\x93\x94.'

copyreg

python标准库中还提供了copyreg模块,可以注册一个封存函数,在对某个对象进行封存时可调用。示例如下

import copyreg, pickle
class C:
    def __init__(self, a):
        self.a = a

def pickle_c(c):
    print("您封存了一个C对象")
    return C, (c.a,)

copyreg.pickle(C, pickle_c)
c = C(1)

p = pickle.dumps(c)
# 您封存了一个C对象

在通过copyreg.pickle对类型C注册函数pickle_c之后,再去用pickle.dumps对c的对象进行封存,就会调用pickle_c,从而打印出预设的字符串。

在copyreg.pickle中注册的函数,必须返回一个字符串或包含二至六个元素的元组。

命令行工具

python标准库还提供了pickle的命令行工具,调用格式如下,其中x.pickle是一个封装了python对象的二进制文件。

python -m pickle x.pickle

常见的命令行选项如下表

指令说明
-a–annotate使用简短的操作码描述来标注每一行。
-o–output=<file>输出应当写入到的文件名称。
-l–indentlevel=<num>一个新的 MARK 层级所需缩进的空格数。
-m–memo当反汇编多个对象时,保留各个反汇编的备忘记录。
-p–preamble=<preamble>当指定一个以上的 pickle 文件时,在每次反汇编之前打印给定的前言。

以上就是关于如何把Python对象存储为文件的方法详解的详细内容,更多关于Python对象存储为文件的资料请关注编程客栈(www.devze.com)其它相关文章!

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新开发

开发排行榜