Python读写YAML配置文件应使用PyYAML库,推荐用yaml.safe_load()安全读取、yaml.dump()配合default_flow_style=False等参数规范写入,并注意避免自动类型转换、注入风险及编码问题。

Python 中读写 YAML 配置文件,核心靠 PyYAML 库。它轻量、易用、支持主流 YAML 语法,是配置管理的常用选择。关键在于正确安装、安全加载、规范写入,避免常见坑(比如自动类型转换、注入风险)。
先用 pip 安装:
pip install pyyaml
读取 YAML 文件推荐使用 yaml.safe_load(),它只解析安全的 YAML 标签(不执行任意代码),适合配置场景:
立即学习“Python免费学习笔记(深入)”;
yaml.YAMLError,建议加 try/except示例:
import yaml
with open("config.yaml", "r", encoding="utf-8") as f:
data = yaml.safe_load(f)
print(data["database"]["host"]) # 如输出 'localhost'
用 yaml.dump() 将 Python 数据写入 YAML 文件。默认输出可能缩进混乱、带引号或省略空行,可通过参数优化可读性:
default_flow_style=False:禁用内联格式,强制块状结构(更易读)allow_unicode=True:保留中文等非 ASCII 字符,不转义indent=2:设置缩进空格数(默认为 2,可显式指定)sort_keys=False:保持字典原有键序(Python 3.7+ 默认有序,但显式设为 False 更稳妥)示例:
with open("config.yaml", "w", encoding="utf-8") as f:
yaml.dump(data, f, default_flow_style=False, allow_unicode=True, indent=2, sort_keys=False)
实际项目中常遇到几类典型情况:
dev.yaml / prod.yaml),或在单文件中用锚点(&common)和引用(*common)复用配置password: ${DB_PASSWORD}),再结合 os.getenv() 运行时替换ruamel.yaml 替代(功能更强,但依赖稍重)几个高频问题需注意:
yaml.load()(无 safe 版本)——存在反序列化漏洞,尤其加载不受信内容时yes/no/on/off 会被自动转成布尔值,如需字符串,请加单/双引号:status: "on"
encoding="utf-8"
以上就是PythonYAML配置文件读写方法_pyyaml实战讲解【指导】的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号