YAML语法总结

参考文档

官方文档:https://yaml.org/spec/1.2.2/
文档1:https://www.runoob.com/w3cnote/yaml-intro.html
文档2:https://www.jianshu.com/p/36f6acedf378

一、YAML概念

  • YAML语法全称 “Yet Another Markup Language(另一种标记语言)" ,设计目标是为了方便所有人都能很快看懂读写的语法,常用于配置文件。
  • YAML的配置文件都以.yml为后缀
  • 凡是以.yml为后缀的都是用的YAML语法,常见的比如ansible的playbook、docker的compose等
  • YAML 规范通常被视为过于复杂,因为它看起来很简单。尽管 YAML 经常用于软件配置,但它一直是并将继续是一种完整的数据序列化语言。未来的 YAML 计划专注于使语言和生态系统更加强大和可靠,同时简化实施者的开发过程。

二、YAML核心

YAML以数据为中心,使用空白,缩进,分行组织数据。三种数据类型为:对象、数组、纯量

三、常用语法规则

  1. 大小写敏感
  2. 使用缩进表示层级关系
  3. 禁止使用tab缩进,只能使用空格键
  4. 缩进的空格数不重要,只要相同层级的元素左对齐即可
  5. 使用#表示注释
  6. 字符串可以不用引号标注

四、YAML数据类型

YAML 支持以下几种数据类型:

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

五、数据类型的详解

1. YAML 对象

  • 对象键值使用冒号结构表示 key: value 冒号后面要加一个空格
  • 也可以使用对象键值组合 key:{key1: value1, key2: value2, …}
  • 还可以使用缩进表示层级关系。
- key: 
    child-key: value
    child-key2: value2

较为复杂的对象格式,可以使用问号加一个空格代表一个复杂的 key,配合一个冒号加一个空格代表一个 value:

?  
    - complexkey1
    - complexkey2
:
    - complexvalue1
    - complexvalue2

# 一句话理解就是?后接空格表示一个key的数组,而:后接空格表示一个value的数组

2、YAML数组

  1. -开头表示数组
- id
- name
- route
  1. 行内表示多维数组
key: [value1, value2, , , ,]
  1. 使用同级缩进构成父子关系
 -
  - A
  - B
  - C
 
#这里回顾一下语法规则:同级使用空格缩进,没有空格数量一说,只要对其的就是同级,类似于树状图层次分级
  1. 手动写一个举例
 user:
  -
   -id: 1
   -name: root
   -pass: ABC123
  -
   -id: 2
   -name: admin
   -pass: ABC456
   

解释
在这里插入图片描述

3.数组和对象

languages: 
  - Ruby 
  - Perl
  - Python 
websites:
  YAML: yaml.org  
  Ruby: ruby-lang.org 
  Python: python.org 
  Perl: use.perl.org

-开头的为数组
kay: value的为对象

4.纯量

纯量是最基本的,不可再分的值,包括:

  • 字符串
  • 布尔值
  • 整数
  • 浮点数
  • Null
  • 时间
  • 日期

使用一个例子来快速了解纯量的基本使用:

boolean: 
    - TRUE  #true,True都可以
    - FALSE  #false,False都可以
float:
    - 3.14
    - 6.8523015e+5  #可以使用科学计数法
int:
    - 123
    - 0b1010_0111_0100_1010_1110    #二进制表示
null:
    nodeName: 'node'
    parent: ~  #使用~表示null
string:
    - 哈哈
    - 'Hello world'  #可以使用双引号或者单引号包裹特殊字符
    - newline
      newline2    #字符串可以拆成多行,每一行会被转化成一个空格
date:
    - 2018-02-17    #日期必须使用ISO 8601格式,即yyyy-MM-dd
datetime: 
    -  2018-02-17T15:02:31+08:00    #时间使用ISO 8601格式,时间和日期之间使用T连接,最后使用+代表时区

引用& 锚点和 * 别名,可以用来引用:

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

& 用来建立锚点(defaults),<< 表示合并到当前数据,* 用来引用锚点。

下面是另一个例子:

- &showell Steve 
- Clark 
- Brian 
- Oren 
- *showell 
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

为互联网铺一条公路

你的支持,我的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值