YAML 语言(发音 /ˈjæməl/ )的设计目标,就是方便人类读写。它实质上是一种通用的数据串行化格式。

它的基本语法规则如下。

• 大小写敏感
• 使用缩进表示层级关系
• 缩进时不允许使用Tab键,只允许使用空格。
• 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可
• yaml文件以"---"作为文档的开始,"..."作为文档的结束

# 表示注释,从这个字符一直到行尾,都会被解析器忽略。

YAML 支持的数据结构有三种。

• 对象:键值对的集合,又称为映射(mapping)/ 哈希(hashes) / 字典(dictionary)
• 数组:一组按次序排列的值,又称为序列(sequence) / 列表(list)
• 纯量(scalars):单个的、不可再分的值

对象


对象的一组键值对,使用冒号结构表示。

job: Developer

列表

---
fruits:
- Apple
- Orange
- Strawberry
- Mango

  转换为python格式

{'fruits': ['Apple', 'Orange', 'Strawberry', 'Mango']}

  可以使用行内表示法

---
fruits: ['Apple', 'Orange', 'Strawberry', 'Mango']

  

字典

---
martin:
name: Martin D'vloper
job: Developer
skill: Elite

转换为python格式

{'martin': {'job': 'Developer', 'name': "Martin D'vloper", 'skill': 'Elite'}}

可以使用行业内表示法

---
martin: {name: Martin D'vloper, job: Developer, skill: Elite}

复合结构

转换为python格式

[{'martin': {'job': 'Developer','name': "Martin D'vloper",'skills': ['python', 'perl', 'pascal']}},{'tabitha': {'job': 'Developer', 'name': 'Tabitha Bitumen','skills': ['lisp', 'fortran', 'erlang']}}]

  

纯量

数值  

number: 12
float:12.30

转换为python格式

{'float': 12.300000000000001, 'number': 12}

布尔值

表示true的值
true, True, TRUE, yes, Yes, YES, on, On, ON, y, Y

表示false的值
false, False, FALSE, no, No, NO, off, Off, OFF, n, N

转换数据类型

e: !!str 123
f: !!str true

转换为python格式

{'e': '123', 'f': 'true'}

字符串

# 字符串默认不使用引号表示。
str: 这是一行字符串
# 转换为python格式
{'str': '这是一行字符串'} # 单引号和双引号都可以使用,双引号不会对特殊字符转义。
# 如果字符串之中包含空格或特殊字符,需要放在引号之中。
str: '内容: 字符串'
# 转换为python格式
{'str': '内容: 字符串'} s1: '内容\n字符串'
s2: "内容\n字符串"
# 转换为python格式
{'s1': '内容\\n字符串','s2': '内容\n字符串'} # 单引号之中如果还有单引号,必须连续使用两个单引号转义。
str: 'labor''s day'
# 转换为python格式
{'str': "labor's day"} # 字符串可以写成多行,从第二行开始,必须有一个单空格缩进。换行符会被转为空格。
str: 这是一段
多行
字符串
# 转换为python格式
{'str': '这是一段 多行 字符串'} # 多行字符串可以使用|保留换行符,也可以使用>折叠换行。
this: |
Foo
Bar
that: >
Foo
Bar
# 转换为python格式
{'that': 'Foo Bar', 'this': 'Foo\nBar\n'} # +表示保留文字块末尾的换行,-表示删除字符串末尾的换行。
s1: |
Foo s2: |+
Foo s3: |-
Foo
# 转换为python格式
{'s1': 'Foo\n', 's2': 'Foo\n\n\n', 's3': 'Foo'} # 字符串之中可以插入 HTML 标记。
message: | <p style="color: red">
段落
</p>
# 转换为python格式
{'message': '\n<p style="color: red">\n 段落\n</p>'}

  

引用

# 锚点&和别名*,可以用来引用。
# &用来建立锚点(defaults),<<表示合并到当前数据,*用来引用锚点。
defaults: &defaults
adapter: postgres
host: localhost
development:
database: myapp_development
<<: *defaults
test:
database: myapp_test
<<: *defaults # 等同于下面的代码。
defaults:
adapter: postgres
host: localhost
development:
database: myapp_development
adapter: postgres
host: localhost
test:
database: myapp_
test adapter: postgres
host: localhost
# 转换为python格式
{'defaults': {'adapter': 'postgres', 'host': 'localhost'}, 'development': {'adapter': 'postgres', 'database': 'myapp_development', 'host': 'localhost'}, 'test': {'adapter': 'postgres', 'database': 'myapp_test', 'host': 'localhost'}} # 下面是另一个例子。
- &showell Steve
- Clark
- Brian
- Oren
- *showell
# 转换为python格式
['Steve', 'Clark', 'Brian', 'Oren', 'Steve']

  

yaml中引用变量

foo: "{{ variable }}"

高级YAML语法

!unsafe使用

# 变量值中保存的数据应被视为不安全的,防止不安全的字符子集和信息披露。
---
hosts: all
vars:
my_unsafe_variable: !unsafe 'unsafe value'
tasks:
...

 

Ansible 小手册系列 八(Yaml 语法格式)的更多相关文章

  1. Ansible 小手册系列 十八(Lookup 插件)

    file:获取文件内容 --- - hosts: all vars: contents: "{{ lookup('file', '/etc/foo.txt') }}" tasks: ...

  2. Ansible 小手册系列 三(命令介绍)

    仅仅只是介绍,可以选择跳过 ansible ansible是指令核心部分,其主要用于执行ad-hoc命令,即单条命令.默认后面需要跟主机和选项部分,默认不指定模块时,使用的是command模块. Us ...

  3. Ansible 小手册系列 十三(Jinja2)

    用于playbook中的jinja 2过滤器 更改数据格式,其结果是字符串 {{ some_variable | to_json }} {{ some_variable | to_yaml }} 对于 ...

  4. Ansible 小手册系列 十一(变量)

    变量名约束 变量名称应为字母,数字和下划线. 变量应始终以字母开头. 变量名不应与python属性和方法名冲突. 变量使用 通过命令行传递变量(extra vars) ansible-playbook ...

  5. Ansible 小手册系列 十四(条件判断和循环)

    条件判断 When 语句 在when 后面使用Jinja2 表达式,结果为True则执行任务. tasks: - name: "shut down Debian flavored syste ...

  6. Ansible 小手册系列 二十(经常遇到的问题)

    (1). 怎么为任务设置环境变量? - name: set environment shell: echo $PATH $SOME >> /tmp/a.txt environment: P ...

  7. Ansible 小手册系列 十二(Facts)

    Facts 是用来采集目标系统信息的,具体是用setup模块来采集得. 使用setup模块来获取目标系统信息 ansible hostname -m setup 仅显示与ansible相关的内存信息 ...

  8. Ansible 小手册系列 十(包含和角色)

    一.包含 (include) 使用include模块来包含foo文件 tasks: - include: foo.yml --- foo.yml - name: test foo command: e ...

  9. Ansible 小手册系列 九(Playbook)

    playbook是由一个或多个"play"组成的列表.play的主要功能在于将事先归并为一组的主机装扮成事先通过ansible中的task定义好的角色.从根本上来讲所谓task无非 ...

随机推荐

  1. 关联规则之Apriori

    1.关联规则原理 1.关联规则概述 关联规则(Association Rules)是反映一个事物与其他事物之间的相互依存性和关联性,如果两个或多个事物之间存在一定的关联关系,那么,其中一个事物就能通过 ...

  2. .net:Code First 创建或更新数据库

    控制台输入命令: 切换到项目的project.json 文件所在文件 dotnet ef migrations add XXX dotnet ef database update Visual Stu ...

  3. ruby中的self

    self,自己,在ruby中表示当前对象或默认对象.程序执行的任一时刻,有且仅有一个self. 1.谁成为self,在什么位置成为self? 要知道哪个对象是self,就必须知道当前的上下文.上下文主 ...

  4. ECMAScript与JavaScript

    ECMAScript发展史: 1997 1998.6 1999.12 2008.7 2009.12 2015.61996年11月 javaScript创造者Netscape公司将javaScript提 ...

  5. fiddler操作改到本地

    urlreplace test5.api.bookapi.cn:8889 localhost:8080

  6. ubuntu下python+tornado+supervisor+nginx部署

    由于项目需要,老师让我写一个小web系统,之前都是用java写web,想到自己最近学机器学习要用python,所以用python来写一下,此外,因为想用点新东西,也介于程序比较小,所以考虑用mongo ...

  7. springCloud--1

    电影微服务是服务消费者,用户微服务是服务提供者. Springcloud对eureka的支持很好,eureka本身是一个基于REST的服务, Eureka里面有一个注册表,Application Cl ...

  8. docker issue-Cannot connect to the Docker daemon. Is 'docker -d' running on this host?

    Here is my docker version when i run docker version : Client: Version: 1.8.1 API version: 1.20 Go ve ...

  9. windows库

    1.windows库的存在方式 1.1.静态库:不能被加载的程序,可以理解为目标程序的归档:*.lib. 1.2.动态库:是可以被加载的程序:*.dll. 2.静态库 2.1.静态库的特点    目标 ...

  10. Activiti工作流引擎数据库表结构

    Activiti工作流引擎数据库表结构 一.数据库表的命名 Acitiviti数据库中表的命名都是以ACT_开头的.第二部分是一个两个字符用例表的标识.此用例大体与服务API是匹配的. ACT_RE_ ...