python IO编程:序列化

在Python的IO编程中,序列化(Serialization)是指将数据结构或对象转换为一种格式(如JSON、XML、二进制等),以便可以将其保存到磁盘、通过网络传输或存储在内存中。反序列化(Deserialization)则是将这种格式转换回原始的数据结构或对象。

Python提供了多种序列化方法,其中最常见的是使用pickle模块进行二进制序列化,以及使用json模块进行JSON格式的序列化。

使用pickle进行序列化

pickle模块可以将Python对象序列化为字节流,并且可以从字节流中反序列化回Python对象。

示例:使用pickle
复制代码

python复制代码

|---|----------------------------------------|
| | import pickle |
| | |
| | # 定义一个简单的数据结构 |
| | data = { |
| | 'name': 'Alice', |
| | 'age': 30, |
| | 'is_student': False, |
| | 'courses': ['Math', 'Science'] |
| | } |
| | |
| | # 序列化数据为字节流 |
| | with open('data.pkl', 'wb') as file: |
| | pickle.dump(data, file) |
| | |
| | # 从字节流中反序列化数据 |
| | with open('data.pkl', 'rb') as file: |
| | loaded_data = pickle.load(file) |
| | |
| | print(loaded_data) |

使用json进行序列化

json模块可以将Python数据结构(主要是字典和列表)序列化为JSON格式的字符串,并且可以从JSON字符串中反序列化回Python数据结构。

示例:使用json
复制代码

python复制代码

|---|------------------------------------------------------------|
| | import json |
| | |
| | # 定义一个简单的数据结构 |
| | data = { |
| | 'name': 'Alice', |
| | 'age': 30, |
| | 'is_student': False, |
| | 'courses': ['Math', 'Science'] |
| | } |
| | |
| | # 序列化数据为JSON格式的字符串 |
| | json_data = json.dumps(data, indent=4) # indent=4 用于美化输出 |
| | print(json_data) |
| | |
| | # 将JSON格式的字符串写入文件 |
| | with open('data.json', 'w') as file: |
| | file.write(json_data) |
| | |
| | # 从文件中读取JSON格式的字符串并反序列化 |
| | with open('data.json', 'r') as file: |
| | loaded_data = json.loads(file.read()) |
| | |
| | print(loaded_data) |

注意

  1. 安全性pickle模块可以序列化几乎所有的Python对象,但这也意味着它可能执行不安全的代码,特别是当反序列化不可信的数据时。因此,在处理不可信的数据源时,应避免使用pickle,而使用更安全的序列化格式,如JSON。

  2. 兼容性:JSON是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成。它基于JavaScript的一个子集,但是JSON是独立于语言的,并且很多编程语言都支持JSON格式。这使得JSON成为一种非常流行的跨平台数据交换格式。

  3. 性能pickle通常比json更快,并且能够序列化更复杂的数据结构。然而,对于需要在不同编程语言之间交换数据的场景,JSON通常是更好的选择。

  4. 文件操作 :在序列化数据时,应始终使用with语句来打开文件,以确保文件在操作完成后正确关闭。

相关推荐
东方不败之鸭梨的测试笔记2 分钟前
多进程、多线程、分布式测试支持-pytest-xdis插件
python
明月看潮生12 分钟前
青少年编程与数学 02-004 Go语言Web编程 01课题、Web应用程序
开发语言·青少年编程·编程与数学·goweb
数据龙傲天21 分钟前
API接口性能优化:提升电商数据处理速度的关键
爬虫·python·性能优化·数据分析·api
cwtlw28 分钟前
SpringMVC的使用
java·开发语言·笔记·学习·其他
明月看潮生39 分钟前
青少年编程与数学 02-004 Go语言Web编程 07课题、WebSockets
开发语言·青少年编程·golang·编程与数学
SoraLuna41 分钟前
「Mac畅玩鸿蒙与硬件46」UI互动应用篇23 - 自定义天气预报组件
开发语言·算法·macos·ui·华为·harmonyos
Takoony1 小时前
理解 Python ProcessPoolExecutor 的序列化问题:为什么线程锁(threading.Lock)会导致异常?
linux·开发语言·python
道友老李1 小时前
【Python基础】入门(运算、输出、数据类型)
开发语言·python
missu2171 小时前
C++中如何实现单例模式?
开发语言·c++·单例模式
霍格沃兹测试开发学社测试人社区1 小时前
不同协议下的接口测试方案设计
开发语言·软件测试·测试开发·自动化