首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Yaml 速成查询表

Yaml 速成查询表

作者头像
CRPER
发布2020-07-17 11:48:24
1.2K0
发布2020-07-17 11:48:24
举报
文章被收录于专栏:CRPER折腾记CRPER折腾记

前言

若是接触过编程数据结构的,对这个上手贼快. 写过json这些的...主要关注下缩进这些,理解下概念即可! 这里只列出非常高频且通用性高的使用姿势,个别骚姿势自行去提案了解!

写法及注释

值得一提的是:

  • 文件首行%YAML version ,可以指定使用yaml的版本
  • 键值对的冒号必须跟随空格才是标准的写法,不然会被当初一个字符串!
  • 大小写敏感
  • 声明的key必须为字符串
  • 使用空格缩进(不允许tab)
  • #行开头到行尾为注释区域
  • 值允许的类型有
    • str : 字符串
    • int | float: 整形及浮点型
    • list(array) : 可以理解为数组
    • map(dict) : 不同语言叫法不一样, 字典算是比较通用的解释
    • null(~) : 空值
    • date : iso-8601标准的日期格式
%YAML 1.2
---
# 这是一条注释,跟bash一样,#号开头

# 最常见的字符串声明,默认会自带单引号(会转义)
text: 我是测试文本
text1: '我是测试文本1'
text2: '我会被转义\n,因为单引号会对需要转义的进行转义'
text3: "双引号则忽略需要转义的,\n\t"
text4: "这是多行文本
 换行的需要空格缩进,
 你可以试试"

# |后面可以追加+(保留换行符,默认),-移除每行字符串末尾换行符
text5: |
 这种多行文本可读性比较强
 类似数组,整齐排列
 
 # 也支持+-,同样是控制换行符
text6: >
 这是折叠换行的姿势
 会在最后一行末尾保留换行符
 试试不就知道了
 
# 空值,日期声明
isEmpty: ~
isEmpty2: null
date: 2020-07-15
 


#一维数组的写法(也能理解为列表)
# 写法一
language: ['c','c++']
# 写法二
hight_language:
- 'python'
- 'java'

# 二维数组
# 写法一
testNestedArr1:
- [1,2,3]
- [4,5,6]
# 写法二, 依托缩进
testNestedArr2:
-
 - Cat
 - Dog
 - Goldfish


# map的写法,js中也可以理解为对象,也能理解为一些语言的字典
# 写法一
asiaHuman: {eye: 'black',skin: 'yellow'}
# 写法二
europeHuman:
- eye: 'blue'
- skin: 'white'

# 数组对象写法
arrayMap: 
- key: 1
- {test: 'fsadfas'}
 
 
 # 声明锚点,这个可以用来给其他复用,有点类似继承
 # 采用&来声明锚点
human: &base
 foot: true
 hand: true
 head: true
 body: true
 
 
 # 锚点复用,用<<来声明导入(合并到当前),*+锚点来确定引用范围
asiaMan: &asiaM
 skin: 'yellow'
 <<: *base

otherDesc:
 - &inline {strong: True}

skill:
 <<: *asiaM
 <<: *inline
 it: very good
 
 
 

# 类型强制转换
# !!int # 整数类型 
# !!float # 浮点类型 
# !!bool # 布尔类型 
# !!str # 字符串类型 
# !!binary # 也是字符串类型 
# !!timestamp # 日期时间类型 
# !!null # 空值 
# !!set # 集合 
# !!omap,!!pairs # 键值列表或对象列表
# !!seq # 序列,也是列表 
# !!map # 键值表
needStr: !!str '0.01'
needBoolean: !!bool 'false'
needBoolean2: !!bool 'True' 
needSeq: !!seq [1,2,2,3]
needFloat: !!float '666.6'


# 关联数组键,我在折腾k8s的过程看过这个写法
# 特意去了解了下,他可以组合多个key为更复杂的key
? - key1
  - key2
: - value1
  - {value2: '3'}

...



---
# 在线编译器是数据流编译,不能多个文档在线,这部分不能放进去(可以独立测试)
# 切割yaml文档,该姿势在k8s的配置文件比较常见
# 以---(三横线)开头
# 以...结束为一个yaml文档
testNestedArr2:
- 
 - Cat
 - Dog
 - Goldfish
...
 
  

编译效果

{ text: '我是测试文本',
  text1: '我是测试文本1',
  text2: '我会被转义\\n,因为单引号会对需要转义的进行转义',
  text3: '双引号则忽略需要转义的,\n\t',
  text4: '这是多行文本 换行的需要空格缩进, 你可以试试',
  text5: '这种多行文本可读性比较强\n类似数组,整齐排列\n\n# 也支持+-,同样是控制换行符\n',
  text6: '这是折叠换行的姿势 会在最后一行末尾保留换行符 试试不就知道了\n',
  isEmpty: null,
  isEmpty2: null,
  date: Wed Jul 15 2020 08:00:00 GMT+0800 (中国标准时间),
  language: [ 'c', 'c++' ],
  hight_language: [ 'python', 'java' ],
  testNestedArr1: [ [ 1, 2, 3 ], [ 4, 5, 6 ] ],
  testNestedArr2: [ [ 'Cat', 'Dog', 'Goldfish' ] ],
  asiaHuman: { eye: 'black', skin: 'yellow' },
  europeHuman: [ { eye: 'blue' }, { skin: 'white' } ],
  arrayMap: [ { key: 1 }, { test: 'fsadfas' } ],
  human: { foot: true, hand: true, head: true, body: true },
  asiaMan: { skin: 'yellow', foot: true, hand: true, head: true, body: true },
  otherDesc: [ { strong: true } ],
  skill: 
   { skin: 'yellow',
     foot: true,
     hand: true,
     head: true,
     body: true,
     strong: true,
     it: 'very good' },
  needStr: '0.01',
  needBoolean: false,
  needBoolean2: true,
  needSeq: [ 1, 2, 2, 3 ],
  needFloat: 666.6,
  'key1,key2': [ 'value1', { value2: '3' } ] }

在线测试地址

基于JS-YARML : nodeca.github.io/js-yaml/

官方提案

yaml一直在更新,包括更复杂的姿势 具体骚的程度看不同语言实现的支持程度! 有兴趣的点击下面的传送门: yaml.org/

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020年07月15日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 写法及注释
  • 编译效果
  • 在线测试地址
  • 官方提案
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档