三分薄地,认真耕耘

导航

 

1、YAML基本概念

1.1 简介

设计目标:方便读写

用处:专门用来写配置文件的语言,一种通用的数据串行化格式

1.2 基本语法

大小写敏感

使用缩进表示层级关系

缩进时不允许使用Tab键,只允许使用空格。

缩进的空格数目不重要,只要相同层级的元素左侧对齐即可

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

1.3 支持的数据结构:

字典:键值对的集合,又称为映射(mapping)/ 哈希(hashes) / 对象

数组:一组按次序排列的值,又称为序列(sequence) / 列表(list)

纯量(scalars):单个的、不可再分的值,即基本数据类型

1.4 注意点

重复定义时,后定义的会覆盖前面定义的值

如果值为 int, float, bool等类型,解析后会转换为对应的类型

2、数据结构

2.1 字典

键值对,使用冒号结构表示。


# {k1: v1}
hash:
  k1: v1
  k2: true
  k3: 1
  k4: 1.0001

# or
# { k1:v1, k2:v2 }, k: v 间的空格不能省略
hash: { k1: v1, k2: true, k3: 1, k4: 1.0001 } 

2.2 数组

一组连词线开头的行,构成一个数组。


# ['Cat', 'Dog', 'Goldfish']
listname
  - Cat
  - Dog
  - Goldfish

如果数据结构的子成员是一个数组,则可以在该项下面缩进一个空格。


# [# ['Cat', 'Dog', 'Goldfish'], ]
listname
  -
    - Cat
    - Dog
    - Goldfish

行内表示法


# { animal: [ 'Cat', 'Dog' ] }
animal: [Cat, Dog]

2.3 纯量

纯量是最基本的、不可再分的值。

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

表现形式:

数值类,直接以字面量的形式表示


# num: 12.30
num: 12.30

布尔,true 和 false 表示


# {flag: true}
flag: true

null 用~表示


# {parent: null}
parent: ~

时间,采用ISO8601格式


# { iso8601: new Date('2001-12-14t21:59:43.10-05:00') }
iso8601: 2001-12-14t21:59:43.10-05:00 

日期


# { date: new Date('1976-07-31') }
date: 1976-07-31

2.4 强制类型转换,双!


# { e: '123', f: 'true' }
e: !!str 123
f: !!str true

2.5 字符串


# { str: '这是一行字符串' }
str: 这是一行字符串

# 字符串之中包含空格或特殊字符,需要放在引号之中
# { str: '内容: 字符串' }
str: '内容: 字符串'

# 单引号和双引号都可以使用,双引号不会对特殊字符转义
# { s1: '内容\\n字符串', s2: '内容\n字符串' }
s1: '内容\n字符串'
s2: "内容\n字符串"

# 单引号之中如果还有单引号,必须连续使用两个单引号转义
# { str: 'labor\'s day' }
str: 'labor''s day'

# 字符串可以写成多行,从第二行开始,必须有一个单空格缩进。换行符会被转为空格
# { str: '这是一段 多行 字符串' }
str: 这是一段
  多行
  字符串

# 多行字符串可以使用|保留换行符,也可以使用>折叠换行
# { this: 'Foo\nBar\n', that: 'Foo Bar\n' }
this: |
  Foo
  Bar
that: >
  Foo
  Bar

# +表示保留文字块末尾的换行,-表示删除字符串末尾的换行。
# { s1: 'Foo\n', s2: 'Foo\n\n\n', s3: 'Foo' }
s1: |
  Foo
s2: |+
  Foo
s3: |-
  Foo 
  

3、引用

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

  • &用来建立锚点,类似于声明变量
  • *用来引用锚点,类似于引用变量
  • <<表示合并到当前数据(如果变量名重复也会覆盖)

# example, 文件名为test2.yml
var: &var 111

tag1: &tag1
  - *var
  - m2
# 等价于
#tag1: &tag1
#  - 111
#  - m2

tag2:
  - *tag1
  - *var
  - m3
  - m4
# 等价于  
#tag2:
#  - [111, m2]
#  - 111
#  - m3
#  - m4

redis: &redis
  r_host: redis_host
  r_port: redis_port

mysql: &mysql
  m_host: mysql_host
  m_port: mysql_port

dev1:
  <<: *redis
  <<: *mysql
# 等价于
#dev1:
#  r_host: redis_host
#  r_port: redis_port
#  m_host: mysql_host
#  m_port: mysql_port

dev2:
  redis: *redis
  mysql: *mysql
# 等价于
#dev2:
#  redis: { r_host: redis_host, r_port: redis_port }
#  mysql: { m_host: mysql_host, m_port: mysql_port } 

4、学习链接

阮一峰YAML 语言教程
YAML 在线damo
YAML、YML在线编辑器(格式化校验)

posted on 2019-11-06 10:16  平复心态  阅读(317)  评论(0编辑  收藏  举报