YAML是什么
"YAML Ain't Markup Language"(简称YAML)是一种专为人类设计的数据序列化语言,适用于多种现代编程语言,可广泛应用于各类日常任务。它是一种以人类可读形式呈现的、适用于多种语言的Unicode数据序列化标准。它基于敏捷编程中常见的本地数据结构,广泛应用于配置文件、互联网消息传递、对象持久化以及数据审计等多个领域。遵循Unicode标准、
YAML设计目标
YAML的设计目标包括简洁性、人类友好、数据序列化、可移植性、灵活性、高效性和跨平台性。它使用Unicode可打印字符,通过最小化结构字符数量,并允许数据以自然和有意义的方式显示,实现独特的简洁性。目标主要包括以下几点:
数据结构
有各种类型的数据结构,但它们都可以用三个基本原语来充分表示:映射(哈希/字典)、序列(数组/列表)和标量(字符串/数字)。
使用场景
虽然编程语言繁多,但用于存储和传输数据的语言却为数不多。尽管YAML的潜力巨大,但它的设计初衷是为了满足一些常见的应用场景。 如:配置文件、日志文件、进程间消息传递、跨语言数据共享、对象持久性以及复杂数据结构的展示。当数据变得易于查看和理解时,编程工作也会变得更加轻松。
模型案例
接下来,我们将简要了解YAML的表达能力。不必强求每位初次读者都通读所有示例,相反,这些精选示例旨在为规范的后续部分提供启发和参考。
注意,YAML对缩进非常敏感,通常使用空格进行缩进,并且要求同一层级的元素具有相同的缩进量。在编写YAML文件时,确保正确的缩进是非常重要的。
模型基本结构
YAML语法的集合结构主要包括块集合和流序列两种形式。
-
块集合通过缩进来定义元素,每个元素占据一行,且元素前面带有破折号和空格。这种结构主要用于表示键值对,其中键和值之间使用冒号和空格分隔。
-
流序列则使用逗号分隔的列表形式表示,可以包含任意数量的元素,每个元素占据一行。这种结构主要用于表示列表、数组等线性数据结构。
列表结构
对应的Java中Collection
块序列
使用破折号和空格表示每个条目,每个条目占据一行。例如:
yaml
fruits:
- apple
- banana
- orange
流序列
使用逗号分隔的列表形式表示,每个元素占据一行。例如:
yaml
fruits: [apple, banana,orange]
数组结构
对应的Java中Array
块序列
每个元素前面都带有一个破折号(-
),并且每个元素都从新的一行开始,通过缩进来表示它们属于同一个集合或列表。
yaml
fruits:
- apple
- banana
- orange
流序列
使用方括号表示,元素之间使用空格分隔。例如:
yaml
fruits: [apple, banana,orange]
哈希结构
在YAML中,可以使用键值对的形式来表示Map(映射)。每个键值对由键和值组成,键和值之间使用冒号(:)分隔,并且通常将每个键值对放在不同的行上以增加可读性。以下是一个示例:
对应的Java中Map
yaml
myMap:
key1: value1
key2: value2
key3: value3
在这个例子中,myMap
是映射的名称,而key1
、key2
和key3
是键,对应的value1
、value2
和value3
是值。请注意,在实际使用中,应根据具体的需求来替换键和值。
另外,YAML还支持使用花括号({})来表示映射,特别是在行内表示时。例如:
yaml
myMap: {key1: value1, key2: value2, key3: value3}
然而,使用花括号的形式在YAML中并不常见,因为它可能会与其他数据格式(如JSON)混淆。通常推荐使用换行和缩进的形式来表示映射,以保持YAML的可读性和清晰度。
哈希-列表结构
Java中的 Map<String, List<String>> 类型
块序列
yaml
american:
- Boston Red Sox
- Detroit Tigers
- New York Yankees
national:
- New York Mets
- Chicago Cubs
- Atlanta Braves
流序列
yaml
{american: [Boston Red Sox,Detroit Tigers,New York Yankees], national: [New York Mets,Chicago Cubs,Atlanta Braves]}
这种数据结构可以对应到Java中的 Map<String, List> 类型。american 和 national 是Map的键(Key);每个键后面跟着的短横线 - 开头的结构表明这是一个列表(List),代表Map的值(Value)。例如,用Java代码表示就是:
代码实现
java
Map<String, List<String>> baseballTeams = new HashMap<>();
baseballTeams.put("american", Arrays.asList("Boston Red Sox", "Detroit Tigers", "New York Yankees"));
baseballTeams.put("national", Arrays.asList("New York Mets", "Chicago Cubs", "Atlanta Braves"));
此YAML结构中的每个列表项都可能代表一个具体的棒球队。american
和 national
可能分别代表美国棒球大联
列表-哈希结构
yaml
-
name: Mark McGwire
hr: 65
avg: 0.278
-
name: Sammy Sosa
hr: 63
avg: 0.288
可以被看做是一个对象的数组或者在Java中的 List<Map<String, Object>>
类型。例如,我们使用Java代码将其表示如下:
java
List<Map<String, Object>> players = new ArrayList<>();
Map<String, Object> player1 = new HashMap<>();
player1.put("name", "Mark McGwire");
player1.put("hr", 65);
player1.put("avg", 0.278);
players.add(player1);
... ...
流序列
yaml
[{name: Mark McGwire,hr: 65,avg: 0.278},{name: Sammy Sosa,hr: 63,avg: 0.288}]
列表-列表结构
混合结构
yaml
- [name , hr, avg ]
- [Mark McGwire, 65, 0.278]
- [Sammy Sosa , 63, 0.288]
哈希-哈希结构
混合结构
yaml
Mark McGwire: {hr: 65, avg: 0.278}
Sammy Sosa: { hr: 63, avg: 0.288 }
最后总结
YAML利用这些原语,并添加了一个简单的类型系统和别叠机制,以形成一种用于序列化任何数据结构的完整语言。虽然大多数编程语言都可以使用YAML来进行数据序列化,但YAML擅长于那些从基本意义上讲是围绕这三个基本原语构建的语言。这些语言包括新一波的敏捷语言,如:Java、Perl、Python、PHP、Ruby和Javascript等。