YAML语言教程与使用案例,如何编与读懂写YAML文件。

YAML概要

YAML 是 “YAML Ain’t a Markup Language”(YAML 不是一种标记语言)的递归缩写。在开发的这种语言时,YAML 的意思其实是:”Yet Another Markup Language”(仍是一种标记语言)。

YAML是一个类似 XML、JSON 的标记性语言。YAML 强调以数据为中心,并不是以标识语言为重点。因而 YAML 本身的定义比较简单,号称“一种人性化的数据格式语言”。

基本语法

1、大小写敏感

2、使用缩进表示层级关系

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

4、缩进的空格数不重要,只要相同层级的元素左侧对齐即可。【实际使用中建议两个空格作为一个层级的缩进】

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

6、冒号,以冒号结尾除外,其他所有冒号后面必须有空格

7、短横线,表示列表项,使用一个短横线加一个空格;多个项使用同样的缩进级别作为同一列表

支持的数据结构

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

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

3、字面量/纯量(数字、字符串、布尔值)(scalars):单个的、不可再分的值

YAML 组织结构

YAML 文件可以由一或多个文档组成(即相对独立的组织结构组成),文档间使用“---”(三个横线)在每文档开始作为分隔符(可选)。同时,文档也可以使用“...”(三个点号)作为结束符(可选)。如下图所示:

备注:如果只是单个文档,分隔符“---”可省略。

每个文档并不需要使用结束符“...”来表示结束,但是对于网络传输或者流来说,有明确结束的符号,有利于软件处理。(例如不需要知道流关闭就能知道文档结束)

Python中yaml模块的使用

Python pip 安装

如果未安装pip,则可以使用以下方法来安装:

 # curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py   # 下载安装脚本
# python get-pip.py # 运行安装脚本 或则:python3 get-pip.py 根据使用的Python决定
# pip --version # 版本查看

用哪个版本的 Python 运行安装脚本,pip 就被关联到哪个版本。

pip安装yaml与导入

安装pyyaml

# pip install pyyaml  # 或者pip3 install pyyaml

检查是否安装成功:

1、命令行输入:python

2、再输入:import yaml

安装成功后,在脚本里导入的语句,都是 import yaml

YAML-对象数据类型

备注:之所以对yaml文件使用Python进行解析,是因为我们要测验yaml文件格式是否书写正确。

对象数据:是一组键值对,使用冒号结构表示。

单个对象文档文件

yaml文件

 [root@docker02 yaml]# cat demo_01_obj.yml
---
name: zhang
age:

Python解析

 [root@docker02 yaml]# cat demo_01_obj.py
#!/usr/bin/env python
# -*- coding: utf- -*-
# Author: zhang import yaml file_path = "./demo_01_obj.yml"
file = open(file_path, 'r')
ys = yaml.load(file.read(), Loader=yaml.Loader)
print ys

输出结果

 [root@docker02 yaml]# python demo_01_obj.py
{'age': , 'name': 'zhang'}

多个对象文档文件

yaml文件,仔细对比下加了”---“和”...“ 的区别

 [root@docker02 yaml]# cat demo_02_obj.yml
---
name: zhang
age:
...
---
name: Jane
age:
key:
child-key: value
child-key2: value2
...
---
obj: {obj_key1: value1, obj_key2: value2}
...

Python解析

 [root@docker02 yaml]# cat demo_02_obj.py
#!/usr/bin/env python
# -*- coding: utf- -*-
# Author: zhang import yaml
import json file_path = "demo_02_obj.yml"
file = open(file_path, 'r') ys = yaml.load_all(file.read(), Loader=yaml.Loader)
for y in ys:
# 两种打印方式都尝试下
#print y
print json.dumps(y, indent=)

输出结果

 [root@docker02 yaml]# python demo_02_obj.py
{'age': , 'name': 'zhang'}
{'age': , 'name': 'Jane', 'key': {'child-key2': 'value2', 'child-key': 'value'}}
{'obj': {'obj_key1': 'value1', 'obj_key2': 'value2'}}
# 或者如下
[root@docker02 yaml]# python demo_02_obj.py
{
"age": ,
"name": "zhang"
}
{
"age": ,
"name": "Jane",
"key": {
"child-key2": "value2",
"child-key": "value"
}
}
{
"obj": {
"obj_key1": "value1",
"obj_key2": "value2"
}
}

YAML-数组数据类型

备注:之所以对yaml文件使用Python进行解析,是因为我们要测验yaml文件格式是否书写正确。

数组类型:一组连词线开头的行,构成一个数组

yaml文件

 [root@docker02 yaml]# cat demo_03_list.yml
# 书写方式1
color:
- red
- blue
- green
- orange
- white
# 书写方式2:行内表示法
fruits: [orange, apple, banana]

Python解析

 [root@docker02 yaml]# cat demo_03_list.py
#!/usr/bin/env python
# -*- coding: utf- -*-
# Author: zhang import yaml
import json file_path = "demo_03_list.yml"
file = open(file_path, 'r') ys = yaml.load_all(file.read(), Loader=yaml.Loader)
for y in ys:
# 两种打印方式都尝试下
#print y
print json.dumps(y, indent=)

输出结果

 [root@docker02 yaml]# python demo_03_list.py
{'color': ['red', 'blue', 'green', 'orange', 'white'], 'fruits': ['orange', 'apple', 'banana']}
# 或者结果如下
[root@docker02 yaml]# python demo_03_list.py
{
"color": [
"red",
"blue",
"green",
"orange",
"white"
],
"fruits": [
"orange",
"apple",
"banana"
]
}

YAML-复合结构

备注:之所以对yaml文件使用Python进行解析,是因为我们要测验yaml文件格式是否书写正确。

复合结构:对象和数组可以结合使用,形成复合结构

yaml文件,注意其书序格式,并细细对比输出结果

 [root@docker02 yaml]# cat demo_04_compose.yml
shop: GoodShopping
address: BJ
goods:
Food:
- sell_time: "AM 08:30"
food01: rice
food02: pork
Fruits:
- sell_time: "AM 09:00"
- fruit01: orange
price: 3.50
- fruit02: banana
price: 3.00
clothes:
- sell_time: "AM 09:30"
- clothe01
- clothe02

Python解析

 [root@docker02 yaml]# cat demo_04_compose.py
#!/usr/bin/env python
# -*- coding: utf- -*-
# Author: zhang import yaml
import json file_path = "demo_04_compose.yml"
file = open(file_path, 'r') ys = yaml.load_all(file.read(), Loader=yaml.Loader)
for y in ys:
# 两种打印方式都尝试下
print y
#print json.dumps(y, indent=)

输出结果,仔细对比下

 [root@docker02 yaml]# python demo_04_compose.py
{'shop': 'GoodShopping', 'goods': {'Food': [{'food02': 'pork', 'sell_time': 'AM 08:30', 'food01': 'rice'}], 'Fruits': [{'sell_time': 'AM 09:00'}, {'fruit01': 'orange', 'price': 3.5}, {'price': 3.0, 'fruit02': 'banana'}], 'clothes': [{'sell_time': 'AM 09:30'}, 'clothe01', 'clothe02']}, 'address': 'BJ'}
# 或者结果如下
[root@docker02 yaml]# python demo_04_compose.py
{
"shop": "GoodShopping",
"goods": {
"Food": [
{
"food02": "pork",
"sell_time": "AM 08:30",
"food01": "rice"
}
],
"Fruits": [
{
"sell_time": "AM 09:00"
},
{
"fruit01": "orange",
"price": 3.5
},
{
"price": 3.0,
"fruit02": "banana"
}
],
"clothes": [
{
"sell_time": "AM 09:30"
},
"clothe01",
"clothe02"
]
},
"address": "BJ"
}

YAML-纯量数据类型

备注:之所以对yaml文件使用Python进行解析,是因为我们要测验yaml文件格式是否书写正确。

纯量是最基本的,不可再分的值,包括:

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

常用数据类型的表示格式进行了约定

 [root@docker02 yaml]# cat demo_05_scalars.yml
boolean:
- TRUE # true,True都可以
- FALSE # false,False都可以
float:
- 3.14
- 6.8523015e+5 #可以使用科学计数法
int:
-
null:
nodeName: 'node'
parent: ~ # 使用~表示null
string:
- 哈哈
- 'Hello world' # 可以使用双引号或者单引号包裹特殊字符
- newline
newline2 # 字符串可以拆成多行,非尾行的每一行换行符都转为空格
date:
- -- # 日期必须使用ISO 8601格式,即yyyy-MM-dd
datetime:
- --17T15::+: #时间使用ISO 8601格式,时间和日期之间使用T连接,最后使用+代表时区

双叹号强制转换类型

yaml文件

 [root@docker02 yaml]# cat demo_06_switch.yml
# 原信息
ori01: 3.14
ori02: ""
# 强制转换
int_str: !!str 3.14 # value 整数强制转换为字符串
str_int: !!int "" # value 字符串强制转换为整数

Python解析

 [root@docker02 yaml]# cat demo_06_switch.py
#!/usr/bin/env python
# -*- coding: utf- -*-
# Author: zhang import yaml
import json file_path = "demo_06_switch.yml"
file = open(file_path, 'r') ys = yaml.load_all(file.read(), Loader=yaml.Loader)
for y in ys:
# 两种打印方式都尝试下
print y
#print json.dumps(y, indent=)

输出结果,仔细对比下

 [root@docker02 yaml]# python demo_06_switch.py
{'ori01': 3.14, 'int_str': '3.14', 'ori02': '', 'str_int': }
# 或者输出如下
[root@docker02 yaml]# python demo_06_switch.py
{
"ori01": 3.14,
"int_str": "3.14",
"ori02": "",
"str_int":
}

YAML-引用

备注:之所以对yaml文件使用Python进行解析,是因为我们要测验yaml文件格式是否书写正确。

& 用来建立锚点(defaults),<< 表示合并到当前数据,* 用来引用锚点。

yaml文件

 [root@docker02 yaml]# cat demo_07_anchor.yml
---
hr:
- Mark McGwire
# Following node labeled SS
- &SS Sammy Sosa # 定义要复制的数据
rbi:
- *SS # Subsequent occurrence 这里是数据复制目标
- Ken Griffey
...
---
defaults: &defaults
adapter: postgres
host: localhost development:
database: myapp_development
<<: *defaults test:
database: myapp_test
info: *defaults
...

Python解析

 [root@docker02 yaml]# cat demo_07_anchor.py
#!/usr/bin/env python
# -*- coding: utf- -*-
# Author: zhang import yaml
import json file_path = "demo_07_anchor.yml"
file = open(file_path, 'r') ys = yaml.load_all(file.read(), Loader=yaml.Loader)
for y in ys:
# 两种打印方式都尝试下
print y
#print json.dumps(y, indent=)

输出结果,仔细对比下

 [root@docker02 yaml]# python demo_07_anchor.py
{'hr': ['Mark McGwire', 'Sammy Sosa'], 'rbi': ['Sammy Sosa', 'Ken Griffey']}
{'development': {'adapter': 'postgres', 'host': 'localhost', 'database': 'myapp_development'}, 'test': {'info': {'adapter': 'postgres', 'host': 'localhost'}, 'database': 'myapp_test'}, 'defaults': {'adapter': 'postgres', 'host': 'localhost'}}
# 或者结果如下
[root@docker02 yaml]# python demo_07_anchor.py
{
"hr": [
"Mark McGwire",
"Sammy Sosa"
],
"rbi": [
"Sammy Sosa",
"Ken Griffey"
]
}
{
"development": {
"adapter": "postgres",
"host": "localhost",
"database": "myapp_development"
},
"test": {
"info": {
"adapter": "postgres",
"host": "localhost"
},
"database": "myapp_test"
},
"defaults": {
"adapter": "postgres",
"host": "localhost"
}
}

YAML-字符串

备注:之所以对yaml文件使用Python进行解析,是因为我们要测验yaml文件格式是否书写正确。

字符串是最常见,也是最复杂的一种数据类型。

字符串默认不使用引号表示。

str: 这是一行字符串

如果字符串之中包含空格或特殊字符,需要放在引号之中。

str: '内容: 字符串'

单引号和双引号都可以使用,双引号不会对特殊字符转义。

s1: '内容\n字符串'
s2: "内容\n字符串"

单引号之中如果还有单引号,必须连续使用两个单引号转义。

str: 'labor''s day'

字符串可以写成多行,从第二行开始,必须有空格缩进。换行符会被转为空格。

str: 这是一段
多行
字符串

多行字符串可以使用 | 保留换行符,也可以使用 > 折叠换行。

 this: |
Foo
Bar
that: >
Foo
Bar

+ 表示保留字符串行末尾的换行,- 表示删除字符串末尾的换行。

 s1: |
Foo s2: |+
Foo s3: |-
Foo

字符串之中可以插入 HTML 标记。

 message: |

   <p style="color: red">
段落
</p>

字符串测验案例

yaml文件

 [root@docker02 yaml]# cat demo_08_str.yml
str01: zhangsan
str02: 'Q: What are you doing?' str03: 'zhangsan\nlisi\nwangwu'
str04: "zhangsan\nlisi\nwangwu" str05: 'What''s your name?'
str06: "What's your name?" str07:
'Ken: Hello,
My name is Ken.
What''s your name?' str08:
"Ken: Hello,
My name is Ken.
What's your name?" str11: | str12: >
aaa xxx
bbb yyy
ccc zzz # 之后有2行空行
str16: |
zhangsan
lisi
wangwu # 之后有2行空行
str17: |+
zhangsan
lisi
wangwu # 之后有2行空行
str18: |-
zhangsan
lisi
wangwu message: | <p style="color: red">
one line str
</p>

Python解析

 [root@docker02 yaml]# cat demo_08_str.py
#!/usr/bin/env python
# -*- coding: utf- -*-
# Author: zhang import yaml
import json file_path = "demo_08_str.yml"
file = open(file_path, 'r') ys = yaml.load_all(file.read(), Loader=yaml.Loader)
for y in ys:
# 两种打印方式都尝试下
print y
#print json.dumps(y, indent=)

输出结果,仔细对比下

 [root@docker02 yaml]# python demo_08_str.py
{'str02': 'Q: What are you doing?', 'str01': 'zhangsan', 'str05': "What's your name?", 'str08': "Ken: Hello, My name is Ken. What's your name?", 'str06': "What's your name?", 'str18': 'zhangsan\nlisi\nwangwu', 'str17': 'zhangsan\nlisi\nwangwu\n\n\n', 'str16': 'zhangsan\nlisi\nwangwu\n', 'message': u'\n<p style="color: red">\n one line str\n</p>\n', 'str03': 'zhangsan\\nlisi\\nwangwu', 'str04': 'zhangsan\nlisi\nwangwu', 'str12': 'aaa xxx bbb yyy ccc zzz\n', 'str11': '111\n222\n333\n', 'str07': "Ken: Hello, My name is Ken. What's your name?"}
# 或者输出如下
[root@docker02 yaml]# python demo_08_str.py
{
"str02": "Q: What are you doing?",
"str01": "zhangsan",
"str05": "What's your name?",
"str08": "Ken: Hello, My name is Ken. What's your name?",
"str06": "What's your name?",
"str18": "zhangsan\nlisi\nwangwu",
"str17": "zhangsan\nlisi\nwangwu\n\n\n",
"str16": "zhangsan\nlisi\nwangwu\n",
"message": "\n<p style=\"color: red\">\n one line str\n</p>\n",
"str03": "zhangsan\\nlisi\\nwangwu",
"str04": "zhangsan\nlisi\nwangwu",
"str12": "aaa xxx bbb yyy ccc zzz\n",
"str11": "111\n222\n333\n",
"str07": "Ken: Hello, My name is Ken. What's your name?"
}

完毕!


———END———
如果觉得不错就关注下呗 (-^O^-) !

YAML 语言教程与使用案例的更多相关文章

  1. 转: YAML 语言教程 from(阮一峰)

    YAML 语言教程 from: http://www.ruanyifeng.com/blog/2016/07/yaml.html

  2. 转:spring boot log4j2配置(使用log4j2.yml文件)---YAML 语言教程

    转:spring boot log4j2配置(使用log4j2.yml文件) - CSDN博客http://blog.csdn.net/ClementAD/article/details/514988 ...

  3. YAML 语言教程(转载)

    用YAML语言读取配置是最快的,之前的suricata中用yaml读取了配置,并且在代码运行期间,对配置进行了维护,所以抽点时间,来了解一下YAML语言编程,下文虽然对YAML语言和JAVAScrip ...

  4. 学习笔记:yaml语言教程

    目录 1.YAML基本概念 1.1 简介 1.2 基本语法 1.3 支持的数据结构: 1.4 注意点 2.数据结构 2.1 字典 2.2 数组 2.3 纯量 2.4 强制类型转换,双! 2.5 字符串 ...

  5. YAML 语言教程

    编程免不了要写配置文件,怎么写配置也是一门学问. YAML 是专门用来写配置文件的语言,非常简洁和强大,远比 JSON 格式方便. 本文介绍 YAML 的语法,以 JS-YAML 的实现为例.你可以去 ...

  6. yaml语言教程

    大家直接去看阮一峰的教程. http://www.ruanyifeng.com/blog/2016/07/yaml.html?f=tt 简介 基本语法规则: 大小写敏感 使用缩进表示层级关系 缩进时不 ...

  7. YAML语言简明教程

    编程免不了要写配置文件,如果你还在用xml/ini/json,就有点过时了,怎么写配置也是一门学问. YAML 是专门用来写配置文件的语言,非常简洁和强大,远比 JSON 格式方便. 本文介绍 YAM ...

  8. SpringBoot图文教程「概念+案例 思维导图」「基础篇上」

    有天上飞的概念,就要有落地的实现 概念+代码实现是本文的特点,教程将涵盖完整的图文教程,代码案例 每个知识点配套自测面试题,学完技术自我测试 本文初学向,所以希望文中所有的代码案例都能敲一遍 大哥大姐 ...

  9. Swift3.0语言教程字符串与URL的数据转换与自由转换

    Swift3.0语言教程字符串与URL的数据转换与自由转换 Swift3.0语言教程字符串与URL的数据转换 Swift3.0语言教程字符串与URL的数据转换与自由转换,字符串中的字符永久保存除了可以 ...

随机推荐

  1. mysql8.0 Mac下的安装

    一.下载及安装 首先去官网下载mac对应版本的Mysql,尾缀为.dmg的程序包 下载地址:https://dev.mysql.com/downloads/mysql/ 二.启动 在 Setting ...

  2. JAVA 代码查错

    1.abstract class Name { private String name; public abstract boolean isStupidName(String name){}} 大侠 ...

  3. php实现登录失败次数限制

    需求:同一个账号在同一个IP地址连续密码输错一定次数后,这个账号是会被锁定30分钟的. 实现思路: 需要一个表(user_login_info)负责记录用户登录的信息,不管登录成功还是失败都记录.并且 ...

  4. Yii2.0ActiveRecord嵌套子查询(AR子查询)

    yii2.0的ActiveRecord是可以嵌套子查询的. 比如从一个子查询里面筛选数据. 首先实例化出来一个Query对象,代表子查询. $subQuery = new \yii\db\Query( ...

  5. @hdu - 6426@ Problem A.Alkane

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 求包含 n 个碳的烷烃与烷基的同分异构体个数 mod 99824 ...

  6. Excel只想显示一部分日期,怎样把其余部分隐藏起来?

      问题:只想显示一部分日期,怎样把其余部分隐藏起来? 方法:分列 Step1:选中需要修改的单元格——数据——分列. Step2:固定宽度——点击下一步. Step3:在建立分列处单击鼠标(若想取消 ...

  7. 这一次搞懂Spring Web零xml配置原理以及父子容器关系

    前言 在使用Spring和SpringMVC的老版本进行开发时,我们需要配置很多的xml文件,非常的繁琐,总是让用户自行选择配置也是非常不好的.基于约定大于配置的规定,Spring提供了很多注解帮助我 ...

  8. Beta冲刺--项目测试

    这个作业属于哪个课程 软件工程 (福州大学至诚学院 - 计算机工程系) 这个作业要求在哪里 Beta 冲刺 这个作业的目标 Beta冲刺--项目测试 作业正文 如下 其他参考文献 ... Beta冲刺 ...

  9. 算法题解:最小的K个数(海量数据Top K问题)

    [本文版权归微信公众号"代码艺术"(ID:onblog)所有,若是转载请务必保留本段原创声明,违者必究.若是文章有不足之处,欢迎关注微信公众号私信与我进行交流!] 题目 输入 n ...

  10. 第十章:RDB持久化

    RDB 保存命令 save 命令,阻塞 Redis 服务器进程,直到保存动作完成: bgsave 命令,派生出一个子进程来完成保存动作: 载入命令 Redis 没有载入 RDB 文件的命令,载入动作在 ...