`

yaml

 
阅读更多

转自:http://www.ruanyifeng.com/blog/2016/07/yaml.html

 

一、简介

YAML 语言(发音 /ˈjæməl/ )的设计目标,就是方便人类读写。它实质上是一种通用的数据串行化格式。

它的基本语法规则如下。

  • 大小写敏感
  • 使用缩进表示层级关系
  • 缩进时不允许使用Tab键,只允许使用空格。
  • 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可

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

YAML 支持的数据结构有三种。

  • 对象:键值对的集合,又称为映射(mapping)/ 哈希(hashes) / 字典(dictionary)
  • 数组:一组按次序排列的值,又称为序列(sequence) / 列表(list)
  • 纯量(scalars):单个的、不可再分的值

以下分别介绍这三种数据结构。

二、对象

对象的一组键值对,使用冒号结构表示,冒号后面需要有一个空格

 

animal: pets
  转为 JavaScript 如下。
  { animal: 'pets' }

 

 

Yaml 也允许另一种写法,将所有键值对写成一个行内对象。

 

hash: { name: Steve, foo: bar } 
  转为 JavaScript 如下。
  { hash: { name: 'Steve', foo: 'bar' } }

 

三、数组

一组连词线开头的行,构成一个数组。

 

- Cat
- Dog
- Goldfish
  转为 JavaScript 如下。
  [ 'Cat', 'Dog', 'Goldfish' ]

 

 

数据结构的子成员是一个数组,则可以在该项下面缩进一个空格。

 

-
 - Cat
 - Dog
 - Goldfish
  转为 JavaScript 如下。
  [ [ 'Cat', 'Dog', 'Goldfish' ] ]

 

 

数组也可以采用行内表示法。

 

animal: [Cat, Dog]
  转为 JavaScript 如下。
  { animal: [ 'Cat', 'Dog' ] }

 

 

四、复合结构

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

 

languages:
 - Ruby
 - Perl
 - Python 
websites:
 YAML: yaml.org 
 Ruby: ruby-lang.org 
 Python: python.org 
 Perl: use.perl.org 

 

转为 JavaScript 如下。

 

{ languages: [ 'Ruby', 'Perl', 'Python' ],
  websites: 
   { YAML: 'yaml.org',
     Ruby: 'ruby-lang.org',
     Python: 'python.org',
     Perl: 'use.perl.org' } }

 

 

五、纯量

纯量是最基本的、不可再分的值。以下数据类型都属于 JavaScript 的纯量。

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

数值直接以字面量的形式表示。

 

number: 12.30
  转为 JavaScript 如下。
  { number: 12.30 }

 

布尔值用truefalse表示。

 

isSet: true
  转为 JavaScript 如下。
  { isSet: true }

 

null~表示。

 

parent: ~ 
  转为 JavaScript 如下。
  { parent: null }

 

时间采用 ISO8601 格式。

 

iso8601: 2001-12-14t21:59:43.10-05:00 
  转为 JavaScript 如下。
  { iso8601: new Date('2001-12-14t21:59:43.10-05:00') }

 

日期采用复合 iso8601 格式的年、月、日表示。

 

date: 1976-07-31
  转为 JavaScript 如下。
  { date: new Date('1976-07-31') }

 

YAML 允许使用两个感叹号,强制转换数据类型。

 

e: !!str 123
f: !!str true
  转为 JavaScript 如下。
  { e: '123', f: 'true' }

 

 

六、字符串

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

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

 

str: 这是一行字符串
  转为 JavaScript 如下。
  { str: '这是一行字符串' }

 

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

 

str: '内容: 字符串'
  转为 JavaScript 如下。
  { str: '内容: 字符串' }

 

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

 

s1: '内容\n字符串'
s2: "内容\n字符串"
  转为 JavaScript 如下。
  { s1: '内容\\n字符串', s2: '内容\n字符串' }

 

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

 

str: 'labor''s day' 
  转为 JavaScript 如下。
  { str: 'labor\'s day' }

 

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

 

str: 这是一段
  多行
  字符串

 

转为 JavaScript 如下。

 

{ str: '这是一段 多行 字符串' }

 

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

 

this: |
  Foo
  Bar
that: >
  Foo
  Bar

 

转为 JavaScript 代码如下。

 

{ this: 'Foo\nBar\n', that: 'Foo Bar\n' }

 

 

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

 

s1: |
  Foo

s2: |+
  Foo


s3: |-
  Foo

 

转为 JavaScript 代码如下。

 

{ s1: 'Foo\n', s2: 'Foo\n\n\n', s3: 'Foo' }

 

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

 

message: |

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

 

转为 JavaScript 如下。

 

{ message: '\n<p style="color: red">\n  段落\n</p>\n' }

 

 

七、引用

锚点&和别名*,可以用来引用。

 

defaults: &defaults
  adapter:  postgres
  host:     localhost

development:
  database: myapp_development
  <<: *defaults

test:
  database: myapp_test
  <<: *defaults

 

 

等同于下面的代码。

 

defaults:
  adapter:  postgres
  host:     localhost

development:
  database: myapp_development
  adapter:  postgres
  host:     localhost

test:
  database: myapp_test
  adapter:  postgres
  host:     localhost

 

 

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

下面是另一个例子。

 

- &showell Steve 
- Clark 
- Brian 
- Oren 
- *showell 

 

转为 JavaScript 代码如下。

[ 'Steve', 'Clark', 'Brian', 'Oren', 'Steve' ]

 

八、函数和正则表达式的转换

这是 JS-YAML 库特有的功能,可以把函数和正则表达式转为字符串。

# example.yml
fn: function () { return 1 }
reg: /test/ 

解析上面的 yml 文件的代码如下。

var yaml = require('js-yaml');
var fs   = require('fs');

try {
  var doc = yaml.load(
    fs.readFileSync('./example.yml', 'utf8')
  );
  console.log(doc);
} catch (e) {
  console.log(e);
}

从 JavaScript 对象还原到 yaml 文件的代码如下。

var yaml = require('js-yaml');
var fs   = require('fs');

var obj = {
  fn: function () { return 1 },
  reg: /test/
};

try {
  fs.writeFileSync(
    './example.yml',
    yaml.dump(obj),
    'utf8'
  );
} catch (e) {
  console.log(e);
}

 

分享到:
评论

相关推荐

    yaml配置文件解析-yaml

    **YAML配置文件解析-YAML** YAML (YAML Ain't Markup Language) 是一种轻量级的数据序列化语言,被广泛应用于配置文件和数据交换。它具有简洁易读的特性,支持多种编程语言,如Python、Java、Ruby等。YAML的语法...

    c++版yaml库yaml-cpp

    **C++版YAML库yaml-cpp** yaml-cpp是一个用C++编写的开源库,专为解析、生成YAML格式的数据而设计。YAML(YAML Ain't Markup Language)是一种人类可读的数据序列化语言,常用于配置文件、数据交换和存储等领域。...

    yaml-cpp-yaml-cpp-0.6.2.zip

    《深入理解YAML-CPP库:解析YAML文件的CPP实现》 YAML,全称“YAML Ain't Markup Language”(发音同“camel”,意为“不是标记语言”),是一种简洁、直观的数据序列化语言。它常用于配置文件、数据交换格式等领域...

    yaml-cpp.tar.gz

    《yaml-cpp库详解与应用》 yaml-cpp是一个开源的C++库,专门用于解析和生成YAML(Yet Another Markup Language)格式的数据。YAML是一种简洁、直观的人类可读的数据序列化语言,常被用于配置文件、数据交换以及存储...

    Python使用pyyaml模块处理yaml数据

    pyyaml模块在python中用于处理yaml格式数据,主要使用yaml.safe_dump()、yaml.safe_load()函数将python值和yaml格式数据相互转换。当然也存在yaml.dump()、yaml.load()函数,同样能实现数据转换功能,只是官方不太...

    ingress的yaml文件

    YAML(YAML Ain't Markup Language)是一种数据序列化格式,常用于Kubernetes资源对象的配置文件,包括Ingress。下面我们将深入探讨Ingress的YAML文件及其相关知识点。 1. **Ingress资源对象**: - Ingress是...

    yaml-cpp-yaml-cpp-0.6.0.tar.gz

    《yaml-cpp库详解及其在运维中的应用》 yaml-cpp是C++语言的一个开源库,主要用于解析和生成YAML(YAML Ain't Markup Language)格式的数据。YAML是一种轻量级的数据序列化语言,广泛应用于配置文件、数据交换、...

    yaml-cpp库的编译&安装

    **yaml-cpp库的编译与安装指南** yaml-cpp是一个用C++编写的YAML解析器和生成器库,广泛应用于配置文件处理和数据序列化。为了在项目中使用yaml-cpp,我们需要先下载、解压源代码,然后进行编译和安装。以下是一...

    python读取yaml文件后修改写入本地实例

    Python中的YAML(YAML Ain't Markup Language)是一种数据序列化格式,常用于配置文件或数据交换。在本文中,我们将探讨如何使用Python的`ruamel.yaml`库来读取、修改并写入YAML文件。 首先,我们需要安装`ruamel....

    yaml-cpp-yaml-cpp-0.5.3.tar.gz_yaml-cpp_yaml-cpp0.5

    在yaml-cpp-0.5.3版本中,除了这两个主要组件外,还有一些辅助类和函数,如`Yaml::Parser`用于解析YAML输入,`Yaml::Exception`处理解析或序列化过程中的错误,以及`Yaml::parse`和`Yaml::dump`两个方便的全局函数,...

    yaml文件解析(java)

    在IT行业中,YAML(Yet Another Markup Language)是一种流行的、易于阅读的数据序列化格式,常用于配置文件和数据交换。Java作为一种广泛使用的编程语言,提供了多种库来处理YAML文件,如SnakeYAML和Jackson YAML。...

    nacos-k8s-yaml.zip

    在Kubernetes(简称k8s)环境中,Nacos可以通过YAML文件进行部署,实现服务在容器集群中的高可用和动态管理。本文将深入探讨如何使用YAML文件在k8s上部署Nacos集群,以及如何结合NFS(Network File System)实现数据...

    MatLab的YAML库文件

    在MATLAB中,YAML(YAML Ain't Markup Language)是一种流行的数据序列化格式,它被广泛用于存储配置文件、数据传输以及版本控制系统中的元数据。YAML库为MATLAB提供了一个接口,允许用户轻松地读取和写入YAML格式的...

    在Qt中使用yaml-cpp库对yml文件进行读写

    在Qt框架中,开发人员有时需要处理配置文件或者序列化数据,YAML(YAML Ain't Markup Language)是一种流行的数据序列化格式,因为其简洁、易读性而被广泛使用。yaml-cpp库是一个用于C++的YAML解析器和生成器,它...

    props2yaml-idea-plugin.zip

    props2yaml-idea-plugin是一款专为Java开发人员设计的IntelliJ IDEA插件,它能够方便地将传统的Properties配置文件转换成现代的YAML格式。这个插件的目的是提高代码的可读性和维护性,因为YAML(YAML Ain't Markup ...

    JAVA基于SnakeYAML实现解析与序列化YAML

    JAVA基于SnakeYAML实现解析与序列化YAML JAVA基于SnakeYAML实现解析与序列化YAML是JAVA开发中的一种常见需求,本文主要介绍了如何使用SnakeYAML库将YAML文档转换为Java对象,以及Java对象如何序列化为YAML文档。...

    k8s yaml 批量生成工具

    1. 资源内容:实际游戏项目中使用的简化版 k8s yaml 生成工具,由 Go 语言编写 2. 应用场景: a. 部署时需要现写/维护已有的 yaml,例如更改 deployment、service、hpa、ingress、configmap 等 b. 需要批量部署一...

    jackson-dataformat-yaml-2.10.0-API文档-中文版.zip

    赠送jar包:jackson-dataformat-yaml-2.10.0.jar; 赠送原API文档:jackson-dataformat-yaml-2.10.0-javadoc.jar; 赠送源代码:jackson-dataformat-yaml-2.10.0-sources.jar; 赠送Maven依赖信息文件:jackson-data...

    jackson-dataformat-yaml-2.11.4-API文档-中文版.zip

    赠送jar包:jackson-dataformat-yaml-2.11.4.jar; 赠送原API文档:jackson-dataformat-yaml-2.11.4-javadoc.jar; 赠送源代码:jackson-dataformat-yaml-2.11.4-sources.jar; 赠送Maven依赖信息文件:jackson-data...

    k8s 创建mysql的 全套yaml文件

    在Kubernetes(k8s)集群中创建MySQL数据库服务,通常涉及到多个YAML文件的配置,这些文件共同定义了MySQL的部署、服务、持久卷和持久卷声明等组件。以下是对这一过程的详细阐述: 首先,`mysql-deployment.yaml`是...

Global site tag (gtag.js) - Google Analytics