文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python数据序列化的pickle模块怎么用

2023-06-29 09:51

关注

这篇文章主要介绍了Python数据序列化的pickle模块怎么用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python数据序列化的pickle模块怎么用文章都会有所收获,下面我们一起来看看吧。

前言:

在英语中 pickle 名词是泡菜,动词是腌渍的意思。可以理解为把东西腌起来保存成文件,要用的时候读出来洗洗再用。

pythonpickle模块实现了基本的数据序列化和反序列化。

序列化对象可以在磁盘上保存对象,并在需要的时候读取出来。任何对象都可以执行序列化操作。

pickle的本质是将Python数据还原为内存中的二进制数据,供用户转移、储存。

pickle模块通常会在2种场景下使用:

1 将Python数据存储为本地文件

设计一个程序,输出产物是Excel工作簿output.xlsx,工作簿中有一个工作表out_sheet 是从 标准文档input.xlsx中的 in_sheet 中复制而来。

工作表in_sheet 的内容很庞大,难以用手动重现,通常我们会选择将 标准文档 input.xlsx 作为程序的引用素材放在工程里。程序运行过程中将工作表 in_sheet复制到工作表out_sheet中。

如果我们要求不能明文存储 工作表 in_sheet文件,只能存储工作表对应的Worksheet()数据 ,将使用到pickle模块

① 存储过程

import picklefrom openpyxl import load_workbook# 创建类数据wb = load_workbook('input.xlsx')ws = wb['in_sheet']# 将 in_sheet 复制到 out_sheet# 注意,这里的 usr_copy_sheet() 是自定义方式,openpyxl自带的copy_sheet()不能复制不同workbook中的worksheetusr_copy_sheet(ws, out_ws)# 将out_ws转化为二进制数据obj = pickle.dumps(out_ws)# 将二进制数据存到本地文件,必须使用二进制写入with open(file='data.txt', mode='wb') as f:    f.write(obj)

此时,ws被存储到本地文件 data.txt,打开是二进制乱码

② 加载过程

import picklefrom openpyxl.worksheet.worksheet import Worksheet# 创建空的类数据准备接收数据,如果类有parent属性,必须和要接收的数据保持一致out_ws= Worksheet(parent=out_wb)# 将本地文件数据加载到类数据上,必须使用二进制打开文件with open(file='data.txt', mode='rb') as f:    out_ws= pickle.loads(f.read())

便可以省去读取 工作表in_sheet,复制到工作表 out_sheet等等过程

2 将Python数据存储为程序的一部分

如果我们要求 工作表in_sheet文件的数据不但不能明文存储,还不能作为外部文件,必须作为 程序.exe 的一部分,以防丢失。有些小程序一共只有一个 exe文件,外挂一个文件不方便,此时可使用到pickle模块

① 存储过程

import picklefrom openpyxl import load_workbook# 创建类数据wb = load_workbook('input.xlsx')ws = wb['in_sheet']# 将 in_sheet 复制到 out_sheet# 注意,这里的 usr_copy_sheet() 是自定义方式,openpyxl自带的copy_sheet()不能复制不同workbook中的worksheetusr_copy_sheet(ws, out_ws)# 将out_ws转化为二进制数据obj = pickle.dumps(out_ws)# 将二进制数据存为py文件,必须使用文本写入with open(file='out_sheet.py', mode='w') as f:    # 将二进制数据转为 b'''xxx''' 字符串写入 py文件    data = 'data=' + str(obj).replace('b\'', 'b\'\'\'') + '\'\''    f.write(data)

此时,out_ws 被存储到本地文件out_sheet.py,内容是一串二进制码:

data=b'''\x80\x04......'''

② 加载过程

将生成的out_sheet.py 加载到程序中,直接读取数据

import picklefrom openpyxl.worksheet.worksheet import Worksheetimport out_sheet# 创建空的类数据准备接收数据,如果类有parent属性,必须和要接收的数据保持一致out_ws= Worksheet(parent=out_wb)# 直接读取out_sheet.py文件中的data变量out_ws= pickle.loads(out_sheet.data)

out_sheet.py最终会被编译为程序的一部分

关于“Python数据序列化的pickle模块怎么用”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“Python数据序列化的pickle模块怎么用”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯