使用 Python 解析配置文件

第一步是使用选择配置文件的格式:INI、JSON、解析YAML 或 TOML。配置
有时,文件程序需要足够的使用参数,将它们全部作为命令行参数或环境变量既不让人愉快也不可行。解析 在这些情况下,配置你将需要使用配置文件。文件
有几种流行的使用配置文件格式。其中包括古老的解析(虽然有时定义不明确)INI 格式,虽然流行但有时难以手写的配置 JSON 格式,使用广泛但有时在细节方面令人意外的文件 YAML 格式,以及很多人还没有听说过的使用最新出现的 TOML。
你的解析首要任务是选择一种格式,然后记录该选择。配置解决了这个简单的部分之后就是时候解析配置了。
有时,在配置中拥有一个与“抽象“数据相对应的类是一个不错的想法。免费信息发布网因为这段代码不会对配置做任何事情,所以这是展示解析逻辑最简单的方式。
想象一下文件处理器的配置:它包括一个输入目录、一个输出目录和要提取的文件。
配置类的抽象定义可能类似于:
from __future__ import annotations import attr@attr.frozenclass Configuration: @attr.frozen class Files: input_dir: str output_dir: str files: Files @attr.frozen class Parameters: patterns: List[str] parameters: Parameters为了使特定于格式的代码更简单,你还需要编写一个函数来从字典中解析此类。请注意,这假设配置将使用破折号,而不是下划线。 这种差异并不少见。
def configuration_from_dict(details): files = Configuration.Files( input_dir=details["files"]["input-dir"], output_dir=details["files"]["output-dir"], ) parameters = Configuration.Paraneters( patterns=details["parameters"]["patterns"] ) return Configuration( files=files, parameters=parameters, )JSON
JSON(JavaScript Object Notation)是一种类似于 JavaScript 的格式。
以下是 JSON 格式的示例配置:
json_config = """{ "files": { "input-dir": "inputs", "output-dir": "outputs" }, "parameters": { "patterns": [ "*.txt", "*.md" ] }}"""解析逻辑使用 json 模块将 JSON 解析为 Python 的内置数据结构(字典、列表、字符串),然后从字典中创建类:
import jsondef configuration_from_json(data): parsed = json.loads(data) return configuration_from_dict(parsed)INI
INI 格式,最初只在 Windows 上流行,之后成为配置标准格式。
这是与 INI 相同的配置:
ini_config="""[files]input-dir = inputsoutput-dir = outputs[parameters]patterns = [*.txt, *.md]"""Python 可以使用内置的 configparser 模块解析它。云服务器提供商解析器充当类似 dict 的对象,因此可以直接传递给 configuration_from_dict:
import configparserdef configuration_from_ini(data): parser = configparser.ConfigParser() parser.read_string(data) return configuration_from_dict(parser)YAML
YAML(Yet Another Markup Language)是 JSON 的扩展,旨在更易于手动编写。为了实现了这一点,部分原因是有一个很长的规范。
以下是 YAML 中的相同配置:
yaml_config = """files: input-dir: inputs output-dir: outputsparameters: patterns: - *.txt - *.md"""要让 Python 解析它,你需要安装第三方模块。最受欢迎的是PyYAML(pip install pyyaml)。 YAML 解析器还返回可以传递给 configuration_from_dict 的内置 Python 数据类型。但是,YAML 解析器需要一个字节流,因此你需要将字符串转换为字节流。
import ioimport yamldef configuration_from_yaml(data): fp = io.StringIO(data) parsed = yaml.safe_load(fp) return configuration_from_dict(parsed)TOML
TOML(Toms Own Markup Language)旨在成为 YAML 的轻量级替代品。其规范比较短,已经在一些地方流行了(比如 Rust 的包管理器 Cargo 就用它来进行包配置)。
这是与 TOML 相同的配置:
toml_config = """[files]input-dir = "inputs"output-dir = "outputs"[parameters]patterns = [ "*.txt", "*.md",]"""为了解析 TOML,你需要安装第三方包。最流行的高防服务器一种被简单地称为 toml。 与 YAML 和 JSON 一样,它返回基本的 Python 数据类型。
import tomldef configuration_from_toml(data): parsed = toml.loads(data) return configuration_from_dict(parsed)总结
选择配置格式是一种微妙的权衡。但是,一旦你做出决定,Python 就可以使用少量代码来解析大多数流行的格式。
相关文章
如何强制解除BitLocker加密?(教你有效解锁BitLocker加密的方法和步骤)
摘要:BitLocker是Windows操作系统自带的一款全磁盘加密工具,可以保护用户的数据安全。然而,在某些情况下,用户可能需要强制解除BitLocker加密,例如忘记密码或遗失恢复密...2025-11-05- 摘要:在计算机维护和修复过程中,有时我们可能需要重新安装操作系统。本文将介绍如何使用PEPre-installationEnvironment)工具来安装XP系统,通过以下15个步骤,...2025-11-05
一键U盘装机系统激活教程(简单易行的系统激活方法,让装机更方便)
摘要:在进行电脑装机的过程中,系统激活一直是一个让人头疼的问题。不仅需要购买激活码,还需要进行繁琐的操作。然而,现在有了一键U盘装机系统激活的方法,让整个过程更加简单易行。本文将为大家详...2025-11-05VivoY55A(探索VivoY55A的特点和优势,为你带来极致的使用体验)
摘要:在如今智能手机市场竞争激烈的背景下,VivoY55A以其卓越的性能和优秀的用户体验,成为了消费者们的首选。本文将深入探讨VivoY55A的特点和优势,带您了解这款智能手机的真正魅力...2025-11-05- 摘要:如今,在信息时代的浪潮下,电脑已经成为人们日常生活和工作中必不可少的工具。而电脑分屏技术的出现,更是大大提高了人们的工作效率。然而,很多人对于电脑分屏驱动的安装和设置还存在一定的困...2025-11-05
技嘉主板刷BIOS教程(DOS环境下如何安全刷写技嘉主板的BIOS)
摘要:技嘉主板作为一款优质的硬件设备,它的BIOS固件升级是用户提升硬件性能和修复错误的重要手段之一。然而,BIOS升级操作需要慎重进行,不当的操作可能会导致系统无法启动或主板无法正常工...2025-11-05

最新评论