其他 - YAML 入门
2024-09-03 14:36:57
概述
- 简单介绍 YAML 语言
背景
- 很多地方, 都在使用 YAML
- k8s
- spring
- 其他
- 很多地方, 都在使用 YAML
准备
验证工具
- YAML、YML在线格式化校验工具
一个 YAML 转换 JSON 的工具
- 通常来说, YAML 是可以转化为 JSON 的
- 有一个能告诉你对错的验证工具, 对学习很有帮助
这里如果使用 广告屏蔽插件的化, 背景会变得不太好看
- 处理办法, 是把 body 元素里的 style 属性去掉即可
- YAML、YML在线格式化校验工具
JSON 的基础
- 起码知道 map, list 的表示
1. YAML
概述
- 简述 YAML 相关
什么是 YAML
- YAML ain't markup language
- YAML 不是标记语言
- 这个玩法, 和 gnu 有点类似...
- YAML ain't markup language
目的
- 一门 可读性好 的语言
- 一门可以作为 数据序列化标准 的语言
- 一门 跨平台 的语言
和 JSON 的关系
- JSON 更加注重 跨平台, YAML 更重视可读
- YAML 可以视为 JSON 的超集
- JSON 的格式, 在 YAML 中合法
后缀名到底是 .YAML 还是 .yml
- 都行
- 推荐使用 .YAML
2. 语法
- 概述
- 简单介绍 YAML 语法
1. 普通文本
概述
- 尝试输入普通文本
例子
# 输入
1
2
3 4
# 转换
'1 2 3\n4'
我的想法
- 虽然转换成功, 但是不建议使用
- 为啥非要用 YAML 来存放普通文本呢
- 虽然转换成功, 但是不建议使用
2. 注释
概述
- YAML 的注释
注释格式
开始
- 以 # 开头
位置
- 行首
- 整行都被视为注释
- 行中
- 符号 # 右侧的字符, 被视为注释
- 行首
格式
- 符号 # 和注释内容之间, 需要 空格 隔开
约定
- 我在后面整理中, 不会在 YAML 里添加任何注释
- 下文中的 # 只是用来分隔的 解释说明文字
3. 简单 map
- 概述
- 简单 map
例子1: kv 分隔符
示例
# 输入
1:1
# 输出
61
结果
- 卧槽怎么是这个东西?
原因
: 格式有问题
可用的格式, 有这两种
# 官网推荐这一种, : 紧跟key, 但是在 value 前面, 有一个空格
1: 1
2 : 2
后面一定注意, YAML 其实 很吃 格式
- 格式很重要
修正
# 输入
1: 1
# 输出, 这就对了嘛
{ '1': 1 }
例子2: 简单的 map
示例
# 输入
1: 10
abandon: 狂热
# 输出
{ '1': 10, abandon: '狂热' }
结果
- 数字 和 字母都能作为 key
- 而且比起 JSON, YAML 的格式好像更为简单
- 起码 '' 的使用, 没有那么复杂
- 而且比起 JSON, YAML 的格式好像更为简单
- 数字 和 字母都能作为 key
其他注意的问题
概述
- 一些其他的注意事项
- 本来想 举例子 来说, 但还是太懒了
字符集
- YAML 支持 unicode 的所有可见字符集
特殊字符
- 如果需要 #, :, 则可以用 '' 或者 "" 引用, 保证使用正常
- 那个转化器, 无法识别 "", 这个暂时没法验证
- 如果需要 #, :, 则可以用 '' 或者 "" 引用, 保证使用正常
key 不能重复
- 重复的 key, 会导致 解析失败
key 不能为空
- 否则会导致 解析失败
- 单纯的 空格 和 tab 也不行
- 空字符串, 倒是没问题
- 否则会导致 解析失败
value 可以为空
- 转换出来的 JSON, 会识别为 null
- 如果是文字 null, 则加上 ''
数字值域
使用 11111111111111111111 做 键 时
- 转化后的 键 为 11111111111111110000
- 不知道是因为解析器使用 js 的原因, 还是其他原因
在使用数字的时候, 要有意识的去注意 值域
bool
- YAML 支持 bool 类型
- true, True
- false, False
- YAML 支持 bool 类型
4. 简单 list
- 概述
- 简单 list
例子1: 简单 list
示例
# 输入
-
- ' '
- ' '
- 1
- abandon
# 输出
[ null, ' ', '\t', 1, 'abandon' ]
结果
- 值可以为空
- 空格 和 tab 必须用 '' 或者 ""
- 否则视为 null
- 和 值 之间, 必须要有 空格
- 友情提示: 注意对齐, 后面的缩进, 会有大麻烦
5. 嵌套
- 概述
- 尝试一些相对复杂的嵌套
例子1: map 嵌套
示例
# 输入
key1:
key11: value11
key12: value12
key2:
key11: value11
key12: value12
# 输出
{ key1: { key11: 'value11', key12: 'value12' },
key2: { key21: 'value21', key22: 'value22' } }
结果
- map 可以作为 value
注意
缩进
- YAML 中, 层次是靠 缩进 体现的
- 缩进使用的, 是 两个空格
- 一定不能用 tab 去缩进
- 缩进不正确, 会导致报错
当然, 可以多层嵌套
- 但具体能嵌套多少层, 我也是不清楚
例子2: list 嵌套
示例
# 输入
- super1
-
- sub1
- sub2
- super3
# 输出
[ 'super1', [ 'sub1', 'sub2' ], 'super3' ]
结果
- list 可以作为 list 元素存在
- 那个空行 - 需要注意
- list 可以作为 list 元素存在
注意
- 还是缩进
- 层数
- 可以多层嵌套
- 但是能套多少层, 我还是不清楚
例子3: list 做 map 的 key
示例
# 输入
?
- var1
- var2
:
key
# 输出
{ 'var1,var2': 'key' }
结果
- list 作为 map 的 key, 成功转化
注意
- 注意格式
- ?
- :
- map 不能作为 map 的 key
- 注意格式
例子4: list 作为 map 的 value
示例
# 输入
key:
- value1
- value2
# 输出
{ key: [ 'value1', 'value2' ] }
结果
- 成功
例子5: map 作为 list 的元素
示例
# 输入
- key10: value10
key11: value11
- key20: value20
key21: value21
# 输出
[ { key10: 'value10', key11: 'value11' },
{ key20: 'value20', key21: 'value21' } ]
结果
- 成功嵌套
6. 其他
感觉了解了这些, 基本就够用了吧
- 感觉日常使用, 基本是 够了
当然有一些疑问
- 层数上限
- 容量上限
- int 和 float 的上限
- 特殊转义
- " 和 ' 的区别
这些问题, 如果在使用中遇到, 再去处理吧
感觉 YAML 其实是一种 写起来更简单的 JSON
- 如果有想法的话, 其实是可以写一个东西, 来将 YAML 转化为 JSON 的
ps
最新文章
- NavigationBar隐藏后,返回时表现不完美
- Xcode 文档注释方法
- Java中List、Collections实现梭哈游戏
- PEM文件格式详细解析
- 关于Raw,Assets的使用
- iOS 证书调试的理解(Personal)
- PRMonitor,学习SSDT HOOK的好例子,学习的内核HOOK的好例子(注意右边有一堆类似的例子)
- xcode6制作IOS .a静态库小记
- ubuntu 设置vpn
- 一个基于Behave框架的http接口测试实例
- Linux指令--telnet
- 为微软samples-for-ai贡献代码是种怎么样的体验?
- You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'group t1,customer t2
- tp3.2 上传文件及下载文件
- [转] 简述js中 for in 与 for of 区别
- zabbix3.4安转
- Codeforces828 D. High Load
- Linux下DB2命令学习及整理
- CentOS 6.7下创建桌面快捷方式
- NIOS II SOPC系统自定义IP常见知识点总结