YAML 简介
YAML 是一种数据序列化语言,专门用于以人类可读的形式存储信息。它的名字最初代表 "Yet Another Markup Language",后来改为 "YAML Ain't Markup Language"(YAML 不是一种标记语言),以此区别于传统的标记语言。
核心特点
- 简洁易读:语法简洁,减少了 JSON、XML 中大量的引号、括号等格式噪音;
- 非编程语言:主要用于存储配置信息,不具备编程逻辑;
- 缩进敏感:缩进规则类似 Python,通过缩进来表示层级关系;
- 区分大小写:对键名、值的大小写严格区分;
- 禁用 Tab 键:不允许使用制表符缩进,需通过空格实现(部分编辑器可配置 Tab 自动转为空格)。
数据类型及语法对比
YAML 文件后缀名为 .yaml 或 .yml,支持多种数据类型。其语法与 JSON 的对比如下:
| 数据类型 | YAML 语法 | JSON 语法 |
|---|---|---|
| 简单标量值 | key: value | {"key": "value"} |
| 整数和浮点数 | int_key: 123\nfloat_key: 123.456 | {"int_key": 123, "float_key": 123.456} |
| 布尔值 | bool_key: true | {"bool_key": true} |
| 字符串 | string_key: "This is a string" | {"string_key": "This is a string"} |
| 列表 | list_key:\n- item1\n- item2\n- item3 | {"list_key": ["item1", "item2", "item3"]} |
| 映射(字典) | map_key:\nsub_key1: sub_value1\nsub_key2: sub_value2 | {"map_key": {"sub_key1": "sub_value1", "sub_key2": "sub_value2"}} |
| 嵌套结构 | nested_key:\nlist_key:\n- item1\n- item2\nmap_key:\nsub_key1: sub_value1\nsub_key2: sub_value2 | {"nested_key": {"list_key": ["item1", "item2"], "map_key": {"sub_key1": "sub_value1", "sub_key2": "sub_value2"}}} |
Python 环境下的使用
在 Python 中使用 YAML 需借助 PyYAML 库,主要用于读取、写入、清空 YAML 配置文件,适用于接口自动化测试中的参数存储、配置管理等场景。
安装 PyYAML 库
pip install PyYAML
安装后可通过 pip list 查看是否安装成功。
核心操作(读取、写入、清空)
追加写入 YAML 文件
向指定 YAML 文件追加数据(若文件不存在则自动创建)。这里要注意路径拼接和安全写入:
yaml
os
():
file_path = os.getcwd() + + filename
(file_path, encoding=, mode=) f:
yaml.safe_dump(data, stream=f, allow_unicode=)


