当前位置: 首页 > news >正文

YAML基础语言深度解析

引言

     YAML(YAML Ain't Markup Language,即YAML不是一种标记语言)是一种直观、易于阅读的数据序列化格式,常用于配置文件、数据交换和程序间的通信。其设计目标是易于人类阅读和编写,同时也便于机器解析和生成。在本文中,我们将深入探索YAML的基本语法规则,从使用缩进表示层级关系、空格与Tab的严格区分、列表与字典的区分等几个方面进行详细讲解,力求条理清晰、结构分明。

一、YAML基础概览

1.1 YAML的起源与特点

YAML起源于2001年,由Clarke Ingram在O'Reilly Media的一次研讨会上首次提出。它的设计理念是简洁、直观且易于人类理解,同时保持机器解析的高效性。YAML的主要特点包括:

  • 可读性高:通过简单的语法规则,使得数据内容易于人类阅读和编写。
  • 扩展性强:支持多种数据类型,如字符串、整数、浮点数、布尔值、列表、字典等。
  • 灵活性好:可以轻松地与多种编程语言集成,进行数据交换和序列化。
  • 简洁性:去除不必要的标记和复杂结构,使得文件内容更加简洁明了。
1.2 YAML的应用场景

YAML因其独特的优势,在多个领域得到了广泛应用,包括但不限于:

  • 配置文件:作为软件或应用的配置文件,提供灵活的配置选项。
  • 数据交换:在不同系统或程序间交换数据,确保数据的准确性和一致性。
  • 自动化脚本:编写自动化脚本时,使用YAML作为输入或输出格式,简化脚本的编写和维护。

二、YAML的语法规则

2.1 使用缩进表示层级关系

YAML通过缩进来表示数据的层级关系,这是其语法规则的核心之一。在YAML文件中,左侧对齐的数据表示它们处于同一层级,而缩进则用于表示数据的子层级。

示例

person:  name: John Doe  age: 30  address:  street: 123 Main St  city: Anytown  zip: 12345

 在上述示例中,person 是一个字典(或称为映射),它包含了三个键值对:nameage 和 address。其中,address 又是一个字典,包含了三个子键值对:streetcity 和 zip。通过缩进,我们可以清晰地看出这些数

2.2 缩进必须使用空格,不可使用Tab

YAML对缩进有着严格的要求,即必须使用空格来进行缩进,而不能使用Tab键。这是因为不同的文本编辑器和查看器可能对Tab的解析不一致,从而导致YAML文件的解析错误。

错误示例(使用Tab进行缩进):

# 假设这里使用了Tab进行缩进  
person:  name: John Doe  age: 30  address:  street: 123 Main St  city: Anytown  zip: 12345

上述示例中的缩进使用了Tab键,这可能会导致YAML解析器无法正确解析文件,从而引发错误。

正确做法(使用空格进行缩进):

person:  name: John Doe  age: 30  address:  street: 123 Main St  city: Anytown  zip: 12345
2.3 列表与字典的区分

在YAML中,列表和字典是两种基本的数据结构,它们通过不同的语法规则进行区分。

  • 列表:以“-”开头,表示一系列有序的元素。列表中的元素可以是任何类型的数据,包括字符串、整数、浮点数、布尔值、其他列表或字典等。

示例

fruits:  - apple  - banana  - cherry

在上述示例中,fruits 是一个列表,包含了三个字符串元素:applebanana 和 cherry

  • 字典:不以“-”开头,由键值对组成,键和值之间用冒号(:)分隔,且冒号后面需要有一个空格。字典中的键通常是字符串,而值可以是任何类型的数据。
    person:  name: John Doe  age: 30

在上述示例中,person 是一个字典,包含了两个键值对:name 和 age。 

三、YAML的高级特性

3.1 锚点(Anchors)与别名(Aliases)

YAML中的锚点(Anchors)和别名(Aliases)允许你在文件中重用相同的数据结构,这对于减少重复和提高文件可维护性非常有帮助。

  • 锚点:通过在数据前添加&后跟一个锚名来定义。
  • 别名:通过*后跟一个已定义的锚名来引用之前定义的数据。

示例

defaults: &defaults  adapter: postgres  encoding: utf8  pool: 5  development:  <<: *defaults  database: myapp_development  test:  <<: *defaults  database: myapp_test

在这个示例中,我们定义了一个名为defaults的锚点,它包含了一些数据库连接的基本配置。然后,在developmenttest配置中,我们通过<<: *defaults引用了这个锚点,从而避免了重复书写相同的配置信息。

3.2 字符串表示

YAML提供了多种表示字符串的方式,包括单引号、双引号、未引用和块引用。

  • 未引用字符串:如果字符串不包含特殊字符(如:#%@!|>'"[]{},?-*/\ \t\n\r"\""#),则可以直接书写,不需要引号。
  • 单引号字符串:用单引号括起来的字符串会保留字符串中的所有特殊字符,包括换行符,但不会对特殊字符进行转义。
  • 双引号字符串:用双引号括起来的字符串可以包含特殊字符,并允许使用转义序列(如\n表示换行)。
  • 块引用字符串:用于表示多行文本,可以通过|>来标识。|保留换行符,而>则将所有换行符转换为空格。

示例

unquoted: Hello World  
single_quoted: 'Hello\nWorld'  # 输出包含换行符  
double_quoted: "Hello\nWorld"  # 输出Hello World(换行符被转义)  
block_literal: |  This is a block literal string.  It retains newlines and leading spaces.  block_folded: >  This is a block folded string.  It folds newlines and leading spaces into a single space.
3.3 复杂数据类型

YAML支持多种复杂数据类型,如集合(sets)、映射(maps)、序列(sequences)等,使得它非常适合表示复杂的数据结构。

  • 映射:在YAML中,字典(或称为映射)是一种键值对的集合,键是唯一的,而值可以是任何类型的数据。
  • 序列:列表(或称为序列)是一种有序的元素集合,元素可以是任何类型的数据。
  • 集合:YAML本身没有直接支持集合(即不包含重复元素的列表)的语法,但可以通过一些技巧(如使用字典的键来模拟集合)来实现类似的功能。
3.4 注释

YAML中的注释以#开头,直到行尾。注释对于提高文件的可读性非常有帮助,但需要注意的是,注释不会被解析器处理,因此它们不会出现在解析后的数据结构中。

示例

# 这是一个注释  
person:  name: John Doe # 这是对name的注释  age: 30

四、YAML的最佳实践

4.1 保持文件整洁
  • 使用合理的缩进和空格,确保文件结构清晰。
  • 避免不必要的复杂嵌套,尽量保持数据结构简洁明了。
  • 使用注释来解释复杂的配置或逻辑,提高文件的可读性。
4.2 遵循一致性
  • 在整个文件中保持一致的缩进级别和空格使用。
  • 对于字符串表示,选择一种方式并在整个文件中保持一致。
  • 使用相同的命名规则和格式来命名键和值。
4.3 验证YAML文件的正确性
  • 使用YAML解析器或在线工具来验证YAML文件的语法正确性。
  • 在将YAML文件用于生产环境之前,进行充分的测试以确保配置的正确性

五、总结

       YAML以其简洁的语法、直观的结构和强大的功能,在配置文件、数据交换和程序间通信等领域得到了广泛应用。通过本文的详细讲解,我们深入了解了YAML的基本语法规则,包括使用缩进表示层级关系、空格与Tab的严格区分、列表与字典的区分等。同时,我们也探讨了YAML的高级特性,如锚点与别名、字符串的多种表示方式、复杂数据类型的支持以及注释的使用。

六、YAML的局限性与未来展望

       尽管YAML具有许多优点,但它也存在一些局限性。例如,YAML的语法规则相对严格,对缩进和空格的使用有严格要求,这可能导致一些新手在使用时遇到困惑。此外,YAML的解析器在不同编程语言中的实现可能存在细微差异,这可能会影响到YAML文件的跨平台兼容性。

然而,随着YAML的不断发展和完善,这些问题正在逐步得到解决。未来,我们可以期待YAML在以下几个方面取得更大的进步:

  1. 标准化与兼容性:随着YAML标准的不断推广和普及,不同编程语言中的YAML解析器将更加统一和兼容,从而减少因解析差异导致的问题。

  2. 性能优化:随着技术的不断进步,YAML解析器的性能将得到进一步提升,从而加快YAML文件的解析速度,提高程序的整体性能。

  3. 扩展性与灵活性:YAML将继续保持其扩展性和灵活性,支持更多类型的数据和更复杂的结构,以满足不同领域和场景的需求。

  4. 易用性提升:针对新手用户,可以开发更多易于上手的工具和文档,帮助他们快速掌握YAML的语法和用法,降低学习成本。

七、结语

       YAML作为一种优秀的数据序列化格式,以其简洁、直观和强大的特点赢得了众多开发者的青睐。通过本文的讲解,我们希望能够帮助读者更好地理解和使用YAML,提高开发效率和代码质量。同时,我们也期待YAML在未来能够不断发展和完善,为更多领域和场景提供更加便捷和高效的数据交换和配置管理解决方案。

       最后,我们鼓励读者在实际项目中积极尝试使用YAML,并分享自己的使用经验和心得。通过不断的实践和交流,我们可以共同推动YAML的发展和应用,为软件开发和数据管理领域带来更多的创新和进步。

 

相关文章:

YAML基础语言深度解析

引言 YAML&#xff08;YAML Aint Markup Language&#xff0c;即YAML不是一种标记语言&#xff09;是一种直观、易于阅读的数据序列化格式&#xff0c;常用于配置文件、数据交换和程序间的通信。其设计目标是易于人类阅读和编写&#xff0c;同时也便于机器解析和生成。在本文中…...

xcode使用

1. 界面 1.1. Build Settings,Build Phases和Build Rules三个设置项 Build Settings(编译设置): 每个选项由标题(Title)和定义(Definition)组成。这里主要定义了Xcode在编译项目时的一些具体配置 Build Phases(编译资源):用于指定编译过程中项目所链接的原文件,依赖对象,库…...

OV2640引脚的定义(OV2640 FPC模组规格书(接口线序))

OV2640是一款由Omni Vision公司生产的1/4寸CMOS UXGA&#xff08;1632x1222&#xff09;图像传感器。这款传感器以其小巧的体积、低工作电压和强大的功能而著称&#xff0c;它集成了单片UXGA摄像头和影像处理器&#xff0c;能够通过SCCB总线控制输出各种分辨率的8/10位影像数据…...

CTFSHOW 萌新 web10 解题思路和方法(passthru执行命令)

点击题目链接&#xff0c;分析页面代码。发现代码中过滤了system、exec 函数&#xff0c;这意味着我们不能通过system(cmd命令)、exec&#xff08;cmd命令&#xff09;的方式运行命令。 在命令执行中&#xff0c;常用的命令执行函数有&#xff1a; system(cmd_code);exec(cmd_…...

深入Java数据库连接和JDBC

引言 Java数据库连接(JDBC)是Java语言中用于执行SQL语句的标准API。通过JDBC,开发者可以方便地与关系型数据库进行交互。然而,直接使用JDBC API面临着数据库连接管理复杂、性能瓶颈等问题。数据库连接池作为一种解决方案,可以有效地管理数据库连接,提高应用程序的性能。…...

灰狼优化算法(GWO)与长短期记忆网络(LSTM)结合的预测模型(GWO-LSTM)及其Python和MATLAB实现

#### 一、背景 在现代数据科学和人工智能领域&#xff0c;预测模型的准确性和效率是研究者和工程师不断追求的目标&#xff0c;尤其是在时间序列预测、金融市场分析、气象预测等领域。长短期记忆&#xff08;LSTM&#xff09;网络是一种解决传统递归神经网络&#xff08;RNN&a…...

电路板热仿真覆铜率,功率,结温,热阻率信息计算获取方法总结

🏡《电子元器件学习目录》 目录 1,概述2,覆铜率3,功率4,器件尺寸5,结温6,热阻1,概述 电路板热仿真操作是一个复杂且细致的过程,旨在评估和优化电路板内部的热分布及温度变化,以确保电子元件的可靠性和性能。本文简述在进行电路板的热仿真时,元器件热信息的计算方法…...

C#中多线程编程中的同步、异步、串行、并行及并发及死锁

在C#中&#xff0c;多线程编程是一个强大的功能&#xff0c;它允许程序同时执行多个任务。然而&#xff0c;这也带来了复杂性&#xff0c;特别是在处理同步、异步、串行、并行、并发以及死锁等问题时。下面我将详细解释这些概念&#xff0c;并给出一些C#中的示例和注意事项。 …...

【Lampiao靶场渗透】

文章目录 一、IP地址获取 二、信息收集 三、破解SSH密码 四、漏洞利用 五、提权 一、IP地址获取 netdiscover -i eth0 Arp-scan -l Nmap -sP 192.168.78.0/24 靶机地址&#xff1a;192.168.78.177 Kali地址&#xff1a;192.168.78.128 二、信息收集 nmap -sV -p- 192.…...

使用WebSocket实现log日志流的实时展示-从轮询到通知

场景介绍 最近开发一个系统&#xff0c;其中一个模块需要展示实时的执行过程&#xff0c;过程日志可能比较多。以前的方案都是前端定时轮询&#xff0c;比如每秒查一次后端接口&#xff0c;将拉取回来的日志重新展示。轮询方案简单容易实现&#xff0c;但是比较消耗资源&#…...

UE5 从零开始制作跟随的大鹅

文章目录 二、绑定骨骼三、创建 ControlRig四、创建动画五、创建动画蓝图六、自动寻路七、生成 goose八、碰撞 和 Physics Asset缺点 # 一、下载模型 首先我们需要下载一个静态网格体&#xff0c;这里我们可以从 Sketchfab 中下载&#xff1a;Goose Low Poly - Download Free …...

O’Reilly

--江上往来人&#xff0c;但爱鲈鱼美。 --君看一叶舟&#xff0c;出没风波里。 OReilly OReilly出版社出版的技术类图书 俗称动物系列 应该是每个技术人员的必备手册。 OReilly动物系列&#xff08;中译本&#xff09; 简介" 动物系列作为 OReilly 书籍的典型代表被普遍…...

优盘驱动器未格式化:数据拯救行动指南

优盘困境&#xff1a;驱动器未格式化的挑战 在日常的数据存储与传输中&#xff0c;优盘以其便携性和高容量成为了我们不可或缺的伙伴。然而&#xff0c;当您尝试访问优盘时&#xff0c;突然弹出的“驱动器未被格式化”提示却如同晴天霹雳&#xff0c;让人措手不及。这一状况不…...

4.Handler mappings

处理程序映射 简介 在早期版本的 Spring 中&#xff0c;用户需要在 Web 应用程序上下文中定义一个或多个 HandlerMapping bean 以将传入的 Web 请求映射到适当的处理程序。随着注解控制器的引入&#xff0c;通常不再需要这样做&#xff0c;因为 RequestMappingHandlerMapping…...

《学会 SpringMVC 系列 · 消息转换器 MessageConverters》

&#x1f4e2; 大家好&#xff0c;我是 【战神刘玉栋】&#xff0c;有10多年的研发经验&#xff0c;致力于前后端技术栈的知识沉淀和传播。 &#x1f497; &#x1f33b; CSDN入驻不久&#xff0c;希望大家多多支持&#xff0c;后续会继续提升文章质量&#xff0c;绝不滥竽充数…...

深度学习项目 -7-使用 Python 的手写数字识别

一、前言 该文章仅作为个人学习使用 二、正文 项目源代码&#xff1a;深度学习项目 - 使用 Python 进行手写数字识别 - DataFlair (data-flair.training) 数据集&#xff1a;​​​​​​​https://drive.google.com/open?id1hJiOlxctFH3uL2yTqXU_1f6c0zLr8V_K Python 深…...

MySQL —— 库,数据类型 与 表

库与基础操作 1.1 查看数据库 使用 show databases; 可以查看当前 MySQL 目前有多少个数据库 5 rows 表示有 5 行&#xff0c;这里是表示的是有效的数据&#xff0c;不包括 第一行的指引 set 表示结果集合 0.01 sec 表示这个 sql 语句一共运行了0.01 秒&#xff0c;一般情况…...

Java重修笔记 第二十七天 匿名内部类

匿名内部类 1. 定义&#xff1a;无类名&#xff08;底层自动分配类名“外部类名$1”&#xff09;&#xff0c;既是类也是对象&#xff0c;定义在外部类的局部位置&#xff0c;例如方法体和代码块中&#xff0c;通过new类或接口并在大括号里重写方法来实现。 2. 使用场景&…...

Nero Lens 智图 - 适用于 iOS 和 iPadOS 的专业图片处理 App

首先是手机端的无损放大 App&#xff1a;Nero Lens 智图&#xff0c;适用于 iOS 和 iPadOS&#xff0c;不仅可以放大&#xff0c;还有多种 AI 图片增强功能。 使用这款 App 可以通过 AI 模型智能放大可达 400%&#xff0c;还有老照片去划痕、上色&#xff0c;抠图移除背景、照…...

Nginx代理路径被吃

Nginx代理路径被吃的情况 日常工作中经常使用nginx反向代理一些资源&#xff0c;有时正常代理&#xff0c;发现代理不过去。 验证被吃调location情况 通过浏览器访问&#xff1a; https://zhao138969.com/LinuxPackage/Python/SelectDocker location /LinuxPackage { proxy…...

KubeSphere 容器平台高可用:环境搭建与可视化操作指南

Linux_k8s篇 欢迎来到Linux的世界&#xff0c;看笔记好好学多敲多打&#xff0c;每个人都是大神&#xff01; 题目&#xff1a;KubeSphere 容器平台高可用&#xff1a;环境搭建与可视化操作指南 版本号: 1.0,0 作者: 老王要学习 日期: 2025.06.05 适用环境: Ubuntu22 文档说…...

【Python】 -- 趣味代码 - 小恐龙游戏

文章目录 文章目录 00 小恐龙游戏程序设计框架代码结构和功能游戏流程总结01 小恐龙游戏程序设计02 百度网盘地址00 小恐龙游戏程序设计框架 这段代码是一个基于 Pygame 的简易跑酷游戏的完整实现,玩家控制一个角色(龙)躲避障碍物(仙人掌和乌鸦)。以下是代码的详细介绍:…...

C++实现分布式网络通信框架RPC(3)--rpc调用端

目录 一、前言 二、UserServiceRpc_Stub 三、 CallMethod方法的重写 头文件 实现 四、rpc调用端的调用 实现 五、 google::protobuf::RpcController *controller 头文件 实现 六、总结 一、前言 在前边的文章中&#xff0c;我们已经大致实现了rpc服务端的各项功能代…...

MySQL 隔离级别:脏读、幻读及不可重复读的原理与示例

一、MySQL 隔离级别 MySQL 提供了四种隔离级别,用于控制事务之间的并发访问以及数据的可见性,不同隔离级别对脏读、幻读、不可重复读这几种并发数据问题有着不同的处理方式,具体如下: 隔离级别脏读不可重复读幻读性能特点及锁机制读未提交(READ UNCOMMITTED)允许出现允许…...

在rocky linux 9.5上在线安装 docker

前面是指南&#xff0c;后面是日志 sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sudo dnf install docker-ce docker-ce-cli containerd.io -y docker version sudo systemctl start docker sudo systemctl status docker …...

【CSS position 属性】static、relative、fixed、absolute 、sticky详细介绍,多层嵌套定位示例

文章目录 ★ position 的五种类型及基本用法 ★ 一、position 属性概述 二、position 的五种类型详解(初学者版) 1. static(默认值) 2. relative(相对定位) 3. absolute(绝对定位) 4. fixed(固定定位) 5. sticky(粘性定位) 三、定位元素的层级关系(z-i…...

将对透视变换后的图像使用Otsu进行阈值化,来分离黑色和白色像素。这句话中的Otsu是什么意思?

Otsu 是一种自动阈值化方法&#xff0c;用于将图像分割为前景和背景。它通过最小化图像的类内方差或等价地最大化类间方差来选择最佳阈值。这种方法特别适用于图像的二值化处理&#xff0c;能够自动确定一个阈值&#xff0c;将图像中的像素分为黑色和白色两类。 Otsu 方法的原…...

《通信之道——从微积分到 5G》读书总结

第1章 绪 论 1.1 这是一本什么样的书 通信技术&#xff0c;说到底就是数学。 那些最基础、最本质的部分。 1.2 什么是通信 通信 发送方 接收方 承载信息的信号 解调出其中承载的信息 信息在发送方那里被加工成信号&#xff08;调制&#xff09; 把信息从信号中抽取出来&am…...

Cinnamon修改面板小工具图标

Cinnamon开始菜单-CSDN博客 设置模块都是做好的&#xff0c;比GNOME简单得多&#xff01; 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...

docker 部署发现spring.profiles.active 问题

报错&#xff1a; org.springframework.boot.context.config.InvalidConfigDataPropertyException: Property spring.profiles.active imported from location class path resource [application-test.yml] is invalid in a profile specific resource [origin: class path re…...