YAML 语法

来源:互联网 发布:js做99乘法表 编辑:程序博客网 时间:2024/05/21 22:40

原文链接: http://www.cnblogs.com/woshimrf/p/5415818.html


实例参考:http://www.cnblogs.com/huzi007/tag/yaml/


YAML 语法

来源:yaml

这个页面提供一个正确的 YAML 语法的基本概述, 它被用来描述一个 playbooks(我们的配置管理语言).

我们使用 YAML 是因为它像 XML 或 JSON 是一种利于人们读写的数据格式. 此外在大多数变成语言中有使用 YAML 的库.

Attention

几个语法要点很简单,然而没有分号的语法需要注意缩进规则:同一层的变量要有相同的缩进,不然会将\t或\n当做字符串。注意空格。

基本的 YAML

对于 Ansible, 每一个 YAML 文件都是从一个列表开始. 列表中的每一项都是一个键值对, 通常它们被称为一个 “哈希” 或 “字典”. 所以, 我们需要知道如何在 YAML 中编写列表和字典.

YAML 还有一个小的怪癖. 所有的 YAML 文件(无论和 Ansible 有没有关系)开始行都应该是 ---. 这是 YAML 格式的一部分, 表明一个文件的开始.

 

列表

列表中的所有成员都开始于相同的缩进级别, 并且使用一个 "- " 作为开头(一个横杠和一个空格):

---# 一个美味水果的列表- Apple- Orange- Strawberry- Mango

注:列表对应java里的list。在使用snakeyaml解析的结果就是一个List.

 

字典

一个字典是由一个简单的 键:  的形式组成(这个冒号后面必须是一个空格):

---# 一位职工的记录name: Example Developerjob: Developerskill: Elite

字典也可以使用缩进形式来表示, 如果你喜欢这样的话:

---# 一位职工的记录{name: Example Developer, job: Developer, skill: Elite}

Ansible并不是太多的使用这种格式, 但是你可以通过以下格式来指定一个布尔值(true/fase):

---create_key: yesneeds_agent: noknows_oop: Truelikes_emacs: TRUEuses_cvs: false

让我们把目前所学到的 YAML 例子组合在一起:

---# 一位职工记录name: Example Developerjob: Developerskill: Eliteemployed: Truefoods:    - Apple    - Orange    - Strawberry    - Mangolanguages:    ruby: Elite    python: Elite    dotnet: Lame

这就是你开始编写 Ansible playbooks 所需要知道的所有 YAML 语法.

Gotchas

尽管 YAML 通常是友好的, 但是下面将会导致一个 YAML 语法错误:

foo: somebody said I should put a colon here: so I did

你需要使用引号来包裹任何包含冒号的哈希值, 像这样:

foo: "somebody said I should put a colon here: so I did"

此外, Ansible 使用 “{{ var }}” 来引用变量. 如果一个值以 “{” 开头, YAML 将认为它是一个字典, 所以我们必须引用它, 像这样:

foo: "{{ variable }}"
So do it,and change it,no regret!

原创粉丝点击