yq 配置文件格式转换工具

2024-06-22 21:36

本文主要是介绍yq 配置文件格式转换工具,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在现代开发和运维的世界中,处理和转换不同格式的数据文件如 YAML、JSON、XML、CSV 等是日常任务。文件格式的多样性和复杂性常常给开发者带来不小的挑战。在这种情况下,强大的命令行工具能够极大地简化工作流程,本文主要介绍一款基于Go实现处理 YAML、JSON、XML、CSV、TOML 的命令行工具yq。

1 安装 go yq

1)安装 go 编译器

yq 依赖的 go 版本是 1.21,需要安装 1.21 版本以上的 go 版本。

$ go version
go version go1.21.11 darwin/amd64

2)安装 go yq

$ go install github.com/mikefarah/yq/v4@latest
go install github.com/mikefarah/yq/v4@latest
go: downloading github.com/mikefarah/yq/v4 v4.44.2
go: downloading github.com/mikefarah/yq v2.4.0+incompatible
go: downloading github.com/spf13/cobra v1.8.0
go: downloading gopkg.in/op/go-logging.v1 v1.0.0-20160211212156-b2cb9fa56473
go: downloading github.com/a8m/envsubst v1.4.2
go: downloading github.com/dimchansky/utfbom v1.1.1
go: downloading github.com/elliotchance/orderedmap v1.6.0
go: downloading github.com/alecthomas/participle/v2 v2.1.1
go: downloading github.com/goccy/go-json v0.10.3
go: downloading github.com/goccy/go-yaml v1.11.3
go: downloading github.com/jinzhu/copier v0.4.0
go: downloading github.com/yuin/gopher-lua v1.1.1
go: downloading golang.org/x/net v0.26.0
go: downloading github.com/magiconair/properties v1.8.7
go: downloading golang.org/x/text v0.16.0
go: downloading golang.org/x/xerrors v0.0.0-20220907171357-04be3eba64a2
go: downloading golang.org/x/sys v0.21.0

安装完成后,可以通过以下命令验证:

yq --version

应该会看到类似以下的输出:

yq (https://github.com/mikefarah/yq/) version v4.44.2
2 基本用法

go yq 可以处理多种文件格式,以下是一些常见的用法示例:

读取 YAML 文件

假设有一个名为 example.yaml 的 YAML 文件,内容如下:

name: John Doe
age: 30
address:city: ExampleCityzip: 12345

可以使用 yq 读取这个文件的内容:

yq e . example.yaml

输出将是:

name: John Doe
age: 30
address:city: ExampleCityzip: 12345

 

读取 JSON 文件

假设有一个名为 example.json 的 JSON 文件,内容如下:

{"name": "John Doe","age": 30,"address": {"city": "ExampleCity","zip": 12345}
}

可以使用 yq 读取这个文件的内容:

yq e -o=json . example.json

输出将是:

{"name": "John Doe","age": 30,"address": {"city": "ExampleCity","zip": 12345}
}
转换格式

go yq 强大的一点在于它可以在多种格式之间转换。比如,你可以将 YAML 文件转换为 JSON 文件:

yq e -o=json . example.yaml

类似地,可以将 JSON 文件转换为 YAML 文件:

yq e -o=yaml . example.json
编辑文件

可以使用 yq 编辑文件内容。以下演示如何修改 example.yaml 文件中的值:

yq e '.age = 31' -i example.yaml

修改后的 example.yaml 文件内容将是:

name: John Doe
age: 31
address:city: ExampleCityzip: 12345
 查询数据

有时我们只需要获取文件中的某一部分数据,yq 提供了一种简单的查询方式。比如,可以查询 example.yaml 文件中的 address 字段:

yq e '.address' example.yaml

输出将是:

city: ExampleCity
zip: 12345
多文件处理

yq 还支持同时处理多个文件,比如合并两个 YAML 文件:

假设有两个文件 file1.yaml 和 file2.yaml,内容如下:

file1.yaml:

name: John Doe
age: 30

file2.yaml:

address:city: ExampleCityzip: 12345

可以使用以下命令将这两个文件合并:

yq eval-all 'select(fileIndex == 0) * select(fileIndex == 1)' file1.yaml file2.yaml

输出将是:

name: John Doe
age: 30
address:city: ExampleCityzip: 12345
使用嵌套命令

有时我们需要进行一些更复杂的操作,比如修改嵌套的值。假设我们需要修改 example.yaml 文件中 address.city 的值,可以使用嵌套命令:

yq e '.address.city = "NewCity"' -i example.yaml

修改后的文件内容将是:

name: John Doe
age: 30
address:city: NewCityzip: 12345
使用管道传输与其他命令组合

go yq 还可以与其他命令组合使用,充分利用管道传输数据。比如,可以结合 jq 命令处理 JSON 文件:

cat example.json | yq e -o=json '.' | jq '.name'

输出将是:

"John Doe"
进阶用法和扩展
自定义函数

go yq 支持自定义函数,我们可以在处理文件时执行自定义逻辑。以下是一个简单的例子,创建一个自定义函数将所有字符串转换为大写:

yq e 'def uppercase: map_values(if type == "!!str" then (. | upcase) else . end); . ' example.yaml
使用正则表达式

go yq 支持使用正则表达式进行复杂的过滤和替换操作。假设我们需要替换所有以 J 开头的名字,可以使用以下命令:

yq e '(.name | select(. == "John Doe") | sub("John", "Jane"))' example.yaml
 结合自动化工具

将 go yq 结合到自动化工具如 Makefile 或 CI/CD 管道中,可以极大地提升自动化程度和效率。例如,可以在 Makefile 中定义一个任务处理 YAML 文件:

process_yaml:yq e '.version += 1' -i example.yaml

在 CI/CD 管道中,可以使用如下步骤:

jobs:process_yaml:runs-on: ubuntu-lateststeps:- name: Checkout codeuses: actions/checkout@v2- name: Install yqrun: go install github.com/mikefarah/yq/v4@latest- name: Process YAMLrun: yq e '.version += 1' -i example.yaml
总结

go yq 是一个强大而灵活的命令行工具,适用于处理多种文件格式如 YAML、JSON、XML、CSV、TOML 和属性文件。

 

这篇关于yq 配置文件格式转换工具的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1085472

相关文章

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

sqlite3 命令行工具使用指南

《sqlite3命令行工具使用指南》本文系统介绍sqlite3CLI的启动、数据库操作、元数据查询、数据导入导出及输出格式化命令,涵盖文件管理、备份恢复、性能统计等实用功能,并说明命令分类、SQL语... 目录一、启动与退出二、数据库与文件操作三、元数据查询四、数据操作与导入导出五、查询输出格式化六、实用功

Linux如何快速检查服务器的硬件配置和性能指标

《Linux如何快速检查服务器的硬件配置和性能指标》在运维和开发工作中,我们经常需要快速检查Linux服务器的硬件配置和性能指标,本文将以CentOS为例,介绍如何通过命令行快速获取这些关键信息,... 目录引言一、查询CPU核心数编程(几C?)1. 使用 nproc(最简单)2. 使用 lscpu(详细信

利用Python脚本实现批量将图片转换为WebP格式

《利用Python脚本实现批量将图片转换为WebP格式》Python语言的简洁语法和库支持使其成为图像处理的理想选择,本文将介绍如何利用Python实现批量将图片转换为WebP格式的脚本,WebP作为... 目录简介1. python在图像处理中的应用2. WebP格式的原理和优势2.1 WebP格式与传统

Nginx 重写与重定向配置方法

《Nginx重写与重定向配置方法》Nginx重写与重定向区别:重写修改路径(客户端无感知),重定向跳转新URL(客户端感知),try_files检查文件/目录存在性,return301直接返回永久重... 目录一.try_files指令二.return指令三.rewrite指令区分重写与重定向重写: 请求