其他 - YAML 入门
Posted xy14
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了其他 - YAML 入门相关的知识,希望对你有一定的参考价值。
- 概述
- 简单介绍 YAML 语言
- 背景
- 很多地方, 都在使用 YAML
- k8s
- spring
- 其他
- 很多地方, 都在使用 YAML
- 准备
- 验证工具
- YAML、YML在线格式化校验工具
- 一个 YAML 转换 JSON 的工具
- 通常来说, YAML 是可以转化为 JSON 的
- 有一个能告诉你对错的验证工具, 对学习很有帮助
- 这里如果使用 广告屏蔽插件的化, 背景会变得不太好看
- 处理办法, 是把 body 元素里的 style 属性去掉即可
- 一个 YAML 转换 JSON 的工具
- 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 4'
- 我的想法
- 虽然转换成功, 但是不建议使用
- 为啥非要用 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 的原因, 还是其他原因
- 在使用数字的时候, 要有意识的去注意 值域
- 使用 11111111111111111111 做 键 时
- bool
- YAML 支持 bool 类型
- true, True
- false, False
- YAML 支持 bool 类型
4. 简单 list
- 概述
- 简单 list
例子1: 简单 list
示例
# 输入 - - ' ' - ' ' - 1 - abandon # 输出 [ null, ' ', ' ', 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
以上是关于其他 - YAML 入门的主要内容,如果未能解决你的问题,请参考以下文章