欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 教育 > 锐评 > 如何使用python保存字典

如何使用python保存字典

2025/10/22 12:20:33 来源:https://blog.csdn.net/qq_52964132/article/details/147702401  浏览:    关键词:如何使用python保存字典

在Python中,可以通过多种方式将字典(dict)保存到文件中,并能够随时读取恢复。以下是几种常见的方法:


1. 使用 json 模块(推荐)
适用场景:需要人类可读的文件格式,且数据不包含Python特有对象(如自定义类)。

import json# 保存dict到文件
data = {"name": "Alice", "age": 25, "skills": ["Python", "Java"]}
with open("data.json", "w", encoding="utf-8") as f:json.dump(data, f, indent=4)  # indent参数使文件更易读# 从文件读取dict
with open("data.json", "r", encoding="utf-8") as f:loaded_data = json.load(f)print(loaded_data)  # 输出: {'name': 'Alice', 'age': 25, 'skills': ['Python', 'Java']}

优点:
• 文件为纯文本,可手动编辑。

• 跨语言兼容(几乎所有语言都支持JSON)。

缺点:
• 无法直接保存Python特有对象(如datetime或自定义类)。


2. 使用 pickle 模块
适用场景:需要保存Python特有对象或复杂数据结构。

import pickle# 保存dict到文件
data = {"key": "value", "nested": {"a": 1, "b": 2}}
with open("data.pkl", "wb") as f:pickle.dump(data, f)# 从文件读取dict
with open("data.pkl", "rb") as f:loaded_data = pickle.load(f)print(loaded_data)  # 输出原字典

优点:
• 支持几乎所有Python对象。

• 文件为二进制格式,不易被篡改。

缺点:
• 文件不可读,且可能存在安全风险(反序列化恶意数据)。

• 仅限Python使用。


3. 使用 yaml 模块(需安装 pyyaml
适用场景:需要更人性化的配置文件格式。

import yaml  # 需安装: pip install pyyaml# 保存dict到文件
data = {"name": "Bob", "languages": ["Python", "C++"]}
with open("data.yaml", "w", encoding="utf-8") as f:yaml.safe_dump(data, f)# 从文件读取dict
with open("data.yaml", "r", encoding="utf-8") as f:loaded_data = yaml.safe_load(f)print(loaded_data)

优点:
• 文件可读性极强,支持注释。

• 适合配置文件。

缺点:
• 需要安装第三方库(pyyaml)。

• 性能不如JSON或pickle。


4. 使用 shelve 模块
适用场景:需要类似字典的持久化存储,支持动态读写。

import shelve# 保存dict到文件
with shelve.open("shelve_data") as db:db["user"] = {"id": 1, "name": "Charlie"}# 从文件读取dict
with shelve.open("shelve_data") as db:loaded_data = db["user"]print(loaded_data)  # 输出: {'id': 1, 'name': 'Charlie'}

优点:
• 像操作字典一样读写数据。

• 支持动态增删键值。

缺点:
• 文件为数据库格式,不可直接编辑。

• 跨平台兼容性可能受限。


5. 使用 csv 模块(仅限简单字典)
适用场景:字典结构简单(扁平化键值对),需与表格软件兼容。

import csv# 保存dict到文件
data = {"name": "David", "age": 30}
with open("data.csv", "w", encoding="utf-8") as f:writer = csv.writer(f)writer.writerow(data.keys())   # 写入表头writer.writerow(data.values()) # 写入值# 读取csv为dict
with open("data.csv", "r", encoding="utf-8") as f:reader = csv.reader(f)headers = next(reader)values = next(reader)loaded_data = dict(zip(headers, values))print(loaded_data)  # 输出: {'name': 'David', 'age': '30'}

缺点:
• 仅适合单层字典,嵌套结构需额外处理。


总结建议
• 通用性/可读性:用 json(首选)。

• Python特有对象:用 pickle

• 配置文件:用 yaml

• 动态键值存储:用 shelve

• 表格兼容:用 csv

在这里插入图片描述

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词