当前位置:   article > 正文

Yaml语法详细介绍_yaml ${}

yaml ${}

Part1什么是YAML

YAML是"YAML Ain’t a Markup Language"(YAML不是一种标记语言)的递归缩写。YAML的意思其实是:“Yet Another Markup Language”(仍是一种标记语言)。主要强度这种语音是以数据为中心,而不是以标记语音为重心,例如像xml语言就会使用大量的标记。

YAML是一个可读性高,易于理解,用来表达数据序列化的格式。它的语法和其他高级语言类似,并且可以简单表达清单(数组)、散列表,标量等数据形态。它使用空白符号缩进和大量依赖外观的特色,特别适合用来表达或编辑数据结构、各种配置文件等。

YAML的配置文件后缀为 .yml,例如Springboot项目中使用到的配置文件 application.yml 。

Part2基本语法

  • YAML使用可打印的Unicode字符,可使用UTF-8或UTF-16。

  • 数据结构采用键值对的形式,即 键名称: 值,注意冒号后面要有空格。

  • 每个清单(数组)成员以单行表示,并用短杠+空白(- )起始。或使用方括号([]),并用逗号+空白(, )分开成员。

  • 每个散列表的成员用冒号+空白(: )分开键值和内容。或使用大括号({ }),并用逗号+空白(, )分开。

  • 字符串值一般不使用引号,必要时可使用,使用双引号表示字符串时,会转义字符串中的特殊字符(例如\n)。使用单引号时不会转义字符串中的特殊字符。

  • 大小写敏感

  • 使用缩进表示层级关系,缩进不允许使用tab,只允许空格,因为有可能在不同系统下tab长度不一样

  • 缩进的空格数可以任意,只要相同层级的元素左对齐即可

  • 在单一文件中,可用连续三个连字号(—)区分多个文件。还有选择性的连续三个点号(…)用来表示文件结尾。

  • '#'表示注释,可以出现在一行中的任何位置,单行注释

  • 在使用逗号及冒号时,后面都必须接一个空白字符,所以可以在字符串或数值中自由加入分隔符号(例如:5,280或http://www.wikipedia.org)而不需要使用引号。

Part3数据类型

  • 纯量(scalars):单个的、不可再分的值

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

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

标量

标量是最基础的数据类型,不可再分的值,他们一般用于表示单个的变量,有以下七种:

  1. 字符串

  2. 布尔值

  3. 整数

  4. 浮点数

  5. Null

  6. 时间

  7. 日期

  1. # 字符串
  2. string.value: Hello!我是陈皮!
  3. # 布尔值,truefalse
  4. boolean.valuetrue
  5. boolean.value1false
  6. # 整数
  7. int.value10
  8. int.value10b1010_0111_0100_1010_1110 # 二进制
  9. # 浮点数
  10. float.value3.14159
  11. float.value1314159e-5 # 科学计数法
  12. Null,~代表null
  13. null.value: ~
  14. # 时间,时间使用ISO 8601格式,时间和日期之间使用T连接,最后使用+代表时区
  15. datetime.value: !!timestamp 2021-04-13T10:31:00+08:00
  16. # 日期,日期必须使用ISO 8601格式,即yyyy-MM-dd
  17. date.value: !!timestamp 2021-04-13

这样,我们就可以在程序中引入了,如下:

  1. @RestController
  2. @RequestMapping("demo")
  3. public class PropConfig {
  4.     @Value("${string.value}")
  5.     private String stringValue;
  6.     @Value("${boolean.value}")
  7.     private boolean booleanValue;
  8.     @Value("${boolean.value1}")
  9.     private boolean booleanValue1;
  10.     @Value("${int.value}")
  11.     private int intValue;
  12.     @Value("${int.value1}")
  13.     private int intValue1;
  14.     @Value("${float.value}")
  15.     private float floatValue;
  16.     @Value("${float.value1}")
  17.     private float floatValue1;
  18.     @Value("${null.value}")
  19.     private String nullValue;
  20.     @Value("${datetime.value}")
  21.     private Date datetimeValue;
  22.     @Value("${date.value}")
  23.     private Date datevalue;
  24. }

对象

我们知道单个变量可以用键值对,使用冒号结构表示 key: value,注意冒号后面要加一个空格。可以使用缩进层级的键值对表示一个对象,如下所示:

  1. person:
  2.   name: 陈皮
  3.   age: 18
  4.   man: true

然后在程序对这几个属性进行赋值到Person对象中,注意Person类要加get/set方法,不然属性会无法正确取到配置文件的值。使用@ConfigurationProperties注入对象,@value不能很好的解析复杂对象。

  1. package com.nobody;
  2. import lombok.Getter;
  3. import lombok.Setter;
  4. import org.springframework.boot.context.properties.ConfigurationProperties;
  5. import org.springframework.context.annotation.Configuration;
  6. /**
  7.  * @Description
  8.  * @Author Mr.nobody
  9.  * @Date 2021/4/13
  10.  * @Version 1.0.0
  11.  */
  12. @Configuration
  13. @ConfigurationProperties(prefix = "my.person")
  14. @Getter
  15. @Setter
  16. public class Person {
  17.     private String name;
  18.     private int age;
  19.     private boolean man;
  20. }

当然也可以使用 key:{key1: value1, key2: value2, ...}的形式,如下:

person: {name: 陈皮, age: 18, man: true}

数组

可以用短横杆加空格 -开头的行组成数组的每一个元素,如下的address字段:

  1. person:
  2.   name: 陈皮
  3.   age: 18
  4.   man: true
  5.   address:
  6.     - 深圳
  7.     - 北京
  8.     - 广州

也可以使用中括号进行行内显示形式,如下:

  1. person:
  2.   name: 陈皮
  3.   age: 18
  4.   man: true
  5.   address: [深圳, 北京, 广州]

在代码中引入方式如下:

  1. package com.nobody;
  2. import lombok.Getter;
  3. import lombok.Setter;
  4. import lombok.ToString;
  5. import org.springframework.boot.context.properties.ConfigurationProperties;
  6. import org.springframework.context.annotation.Configuration;
  7. import java.util.List;
  8. /**
  9.  * @Description
  10.  * @Author Mr.nobody
  11.  * @Date 2021/4/13
  12.  * @Version 1.0.0
  13.  */
  14. @Configuration
  15. @ConfigurationProperties(prefix = "person")
  16. @Getter
  17. @Setter
  18. @ToString
  19. public class Person {
  20.     private String name;
  21.     private int age;
  22.     private boolean man;
  23.     private List<String> address;
  24. }

如果数组字段的成员也是一个数组,可以使用嵌套的形式,如下:

  1. person:
  2.   name: 陈皮
  3.   age: 18
  4.   man: true
  5.   address: [深圳, 北京, 广州]
  6.   twoArr:
  7.     -
  8.       - 2
  9.       - 3
  10.       - 1
  11.     -
  12.       - 10
  13.       - 12
  14.       - 30
  1. package com.nobody;
  2. import lombok.Getter;
  3. import lombok.Setter;
  4. import lombok.ToString;
  5. import org.springframework.boot.context.properties.ConfigurationProperties;
  6. import org.springframework.context.annotation.Configuration;
  7. import java.util.List;
  8. @Configuration
  9. @ConfigurationProperties(prefix = "person")
  10. @Getter
  11. @Setter
  12. @ToString
  13. public class Person {
  14.     private String name;
  15.     private int age;
  16.     private boolean man;
  17.     private List<String> address;
  18.     private List<List<Integer>> twoArr;
  19. }

如果数组成员是一个对象,则用如下两种形式形式:

  1. childs:
  2.   -
  3.     name: 小红
  4.     age: 10
  5.   -
  6.     name: 小王
  7.     age: 15
childs: [{name: 小红, age: 10}, {name: 小王, age: 15}]

文本块

如果你想引入多行的文本块,可以使用|符号,注意在冒号:和 |符号之间要有空格。

  1. person:
  2.   name: |
  3.     Hello Java!!
  4.     I am fine!
  5.     Thanks! GoodBye!

它和加双引号的效果一样,双引号能转义特殊字符:

  1. person:
  2.   name: "Hello Java!!\nI am fine!\nThanks! GoodBye!"

显示指定类型

有时我们需要显示指定某些值的类型,可以使用 !(感叹号)显式指定类型。!单叹号通常是自定义类型,!!双叹号是内置类型,例如:

  1. # 指定为字符串
  2. string.value: !!str HelloWorld!
  3. # !!timestamp指定为日期时间类型
  4. datetime.value: !!timestamp 2021-04-13T02:31:00+08:00

内置的类型如下:

  • !!int:整数类型

  • !!float:浮点类型

  • !!bool:布尔类型

  • !!str:字符串类型

  • !!binary:二进制类型

  • !!timestamp:日期时间类型

  • !!null:空值

  • !!set:集合类型

  • !!omap,!!pairs:键值列表或对象列表

  • !!seq:序列

  • !!map:散列表类型

引用

引用会用到 &锚点符合和 *星号符号,&用来建立锚点,<< 表示合并到当前数据,* 用来引用锚点。

  1. xiaohong: &xiaohong
  2.   name: 小红
  3.   age: 20
  4. dept:
  5.   id: D15D8E4F6D68A4E88E
  6.   <<*xiaohong

上面最终相当于如下:

  1. xiaohong:
  2.   name: 小红
  3.   age: 20
  4. dept:
  5.   id: D15D8E4F6D68A4E88E
  6.   name: 小红
  7.   age: 20

还有一种文件内引用,引用已经定义好的变量,如下:

  1. base.host: https://chenpi.com
  2. add.person.url: ${base.host}/person/add

Part4单文件多配置

可以在同一个文件中,实现多文档分区,即多配置。在一个yml文件中,通过 — 分隔多个不同配置,根据spring.profiles.active 的值来决定启用哪个配置

  1. #公共配置
  2. spring:
  3.   profiles:
  4.     active: pro # 指定使用哪个文档块
  5. ---
  6. #开发环境配置
  7. spring:
  8.   profiles: dev # profiles属性代表配置的名称
  9. server:
  10.   port: 8080
  11. ---
  12. #生产环境配置
  13. spring:
  14.   profiles: pro
  15. server:
  16.   port: 8081
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/613996
推荐阅读
相关标签
  

闽ICP备14008679号