当前位置: 首页 > backend >正文

如何使用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

在这里插入图片描述

http://www.xdnf.cn/news/3952.html

相关文章:

  • **马小帅面试记:Java技术问答**
  • 邮件协议、签名与推送
  • Learning vtkjs之MultiSliceImageMapper
  • 【C++】Docker常用语法
  • VTK入门指南
  • Leetcode 3538. Merge Operations for Minimum Travel Time
  • Spring AI版本1.0.0-M6和M8效果比较
  • Shell-流程控制-判断
  • 过采样处理
  • educoder平台课-Python程序设计-6.序列类型
  • 【翻译、转载】【转载】LLM 的函数调用与 MCP
  • Linux 的网络卡
  • ST-LINKV2仿真器下载
  • Java基于SaaS模式多租户ERP系统源码
  • 四年级数学知识边界总结思考-上册
  • GCC 使用指南
  • 具身系列——Q-Learning算法实现CartPole游戏(强化学习)
  • 实时操作系统与AI Agent的协同进化:重塑人形机器人产业格局
  • 「分享」学术工具
  • vae笔记
  • P4549 【模板】裴蜀定理
  • Android第三次面试总结之Java篇补充
  • 不定长滑动窗口(求最短/最小)
  • [运维]Linux安装、配置并使用atop监控工具
  • Spring MVC常见注解详解
  • 力扣1128题解
  • sql错题(1)
  • ssh连接云服务器记录
  • 一种实波束扫描雷达角超分辨方法——论文阅读
  • Delphi创建IIS虚拟目录的方法