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

yq 工具

文章目录

  • yq命令
    • 快速
  • Recipes
    • 查找数组中的项目
    • 查找并更新数组中的项目
    • 深度修剪一棵树
    • 对数组中的项目进行多次或复杂的更新
    • 按字段对数组进行排序
  • Operators
    • Omit
      • Omit keys from map
      • Omit indices from array
    • Delete
      • Delete entry in map
      • Delete nested entry in map
      • Delete entry in array
      • Delete nested entry in array
      • Delete no matches
      • Delete matching entries
      • Recursively delete matching keys

yq命令

用法:yq [标志]yq [命令]示例:# 如果未指定命令,yq 默认为 'eval' 命令。更多示例请参阅 "yq eval --help"
yq '.stuff' < myfile.yml    # 从 "myfile.yml" 中输出位于 "stuff" 节点的数据yq -i '.stuff = "foo"' myfile.yml    # 就地更新 myfile.yml可用命令:completion       生成指定shell的自动补全脚本eval             (默认)按顺序对每个 YAML 文件中的每份文档应用表达式eval-all         加载所有 YAML 文件的所有 YAML 文档,然后运行一次表达式help             任何命令的帮助标志:-C, --colors                        强制使用颜色打印-e, --exit-status                   如果没有匹配项或返回 nullfalse,则设置退出状态-f, --front-matter string           (extract|process) 第一个输入作为 YAML 元数据。Extract 将提取 YAML 内容,process 将针对 YAML 内容运行表达式,保留其余数据不变--header-preprocess             吸收头部注释和分隔符,然后处理表达式。默认为真。-h, --help                          yq 帮助-I, --indent int                    设置输出缩进级别(默认为2-i, --inplace                       更新第一个给定文件的位置。-p, --input-format string           [yaml|y|xml|x] 输入解析格式。请注意,JSON 是 YAML 的子集。(默认为“yaml”)-M, --no-colors                     强制不带颜色打印-N, --no-doc                        不打印文档分隔符 (---)-n, --null-input                    不读取输入,只需评估给定的表达式。这对于从头创建文档很有用。-o, --output-format string          [yaml|y|json|j|props|p|xml|x] 输出类型。 (默认为“yaml”)-P, --prettyPrint                   美观打印,是 "... style ="" 的简写-s, --split-exp string              对每个结果(或文档)打印到名为(exp)的文件中。[exp] 参数必须返回字符串。您可以在表达式中使用 $index 作为结果计数器。--unwrapScalar                  解包标量,无引号、颜色或注释打印值(默认为真)-v, --verbose                       显示详细信息模式-V, --version                       打印版本信息并退出--xml-attribute-prefix string   XML 属性的前缀 (默认为"+")--xml-content-name string       当没有属性名称时,XML 内容的名称。 (默认为"+content")使用 "yq [命令] --help" 了解有关命令的更多信息。

快速

# 4.18.1之前
cat file.yaml | yq e '.cool' -# 4.18+
cat file.yaml | yq '.cool'
# 读取一个值:
yq '.a.b[0].c' file.yaml# 来自 STDIN 的管道:
cat file.yaml | yq '.a.b[0].c'# 就地更新 yaml 文件
yq -i '.a.b[0].c = "cool"' file.yaml# 使用环境变量更新
NAME=mike yq -i '.a.b[0].c = strenv(NAME)' file.yaml# 合并多个文件
yq ea '. as $item ireduce ({}; . * $item )' path/to/*.yml# 对 yaml 文件进行多次更新
yq -i '.a.b[0].c = "cool" |.x.y.z = "foobar" |.person.name = strenv(NAME)
' file.yaml

在这里插入图片描述
在这里插入图片描述

Recipes

查找数组中的项目

- name: FoonumBuckets: 0
- name: BarnumBuckets: 0yq '.[] | select(.name == "Foo")' sample.ymlname: Foo
numBuckets: 0.[]展开数组,并将所有项目放入上下文中。
然后将这些项目通过管道 ( |)输入select(.name == "Foo"),将选择 name 属性设置为“Foo”的所有节点。

查找并更新数组中的项目

- name: FoonumBuckets: 0
- name: BarnumBuckets: 0yq '(.[] | select(.name == "Foo") | .numBuckets) |= . + 1' sample.yml- name: FoonumBuckets: 1
- name: BarnumBuckets: 0从上面的示例开始,.[]splats 数组,选择过滤项目。然后我们将|其通过管道 () 传送到.numBuckets,这将从所有匹配项中选择该字段Splat、select 和字段都在括号中,整个表达式|=作为左侧表达式传递给运算符,作为. + 1右侧表达式传递给运算符。|=是相对于其自身值更新字段的运算符,以点 ( ) 引用.。该表达式. + 1会递增 numBuckets 计数器。

深度修剪一棵树

假设我们只对 child1 和 child2 感兴趣,并且想过滤掉其他所有内容。

parentA:- bob
parentB:child1: i am child1child3: hiya
parentC:childX: coolchild2: me child2yq '(.. |                                     # recurse through all the nodesselect(has("child1") or has("child2")) | # match parents that have either child1 or child2(.child1, .child2) |                     # select those childrenselect(.)                                # filter out nulls
) as $i ireduce({};                        # using that set of nodes, create a new result mapsetpath($i | path; $i)                   # and put in each node, using its original path
)' sample.ymlparentB:child1: i am child1
parentC:child2: me child2查找所有匹配的child1和child2节点使用 ireduce,仅使用这些节点创建一个新映射使用其原始路径将每个节点设置到新地图中

对数组中的项目进行多次或复杂的更新

myArray:- name: Footype: cat- name: Bartype: dogyq 'with(.myArray[]; .name = .name + " - " + .type)' sample.ymlmyArray:- name: Foo - cattype: cat- name: Bar - dogtype: dogwith 运算符将有效地循环第一个给定表达式中的每个给定项目,并对其运行第二个表达式。.myArray[]将数组展开到myArray.因此with将针对该数组中的每个项目运行.name = .name + " - " + .type该表达式针对每个项目运行,将名称更新为原始名称和类型的串联。

按字段对数组进行排序

myArray:- name: FoonumBuckets: 1- name: BarnumBuckets: 0yq '.myArray |= sort_by(.numBuckets)' sample.ymlmyArray:- name: BarnumBuckets: 0- name: FoonumBuckets: 1我们想去排序.myArray。sort_by其工作原理是通过管道将一个数组输入其中,然后通过管道输出一个已排序的数组。所以,我们使用|=更新.myArray。这与做相同.myArray = (.myArray | sort_by(.numBuckets))

Operators

Omit

Works likepick, but instead you specify the keys/indices that youdon’twant included.

Omit keys from map

myMap:cat: meowdog: barkthing: hamsterhamster: squeakyq '.myMap |= omit(["hamster", "cat", "goat"])' sample.ymlmyMap:dog: barkthing: hamster

Omit indices from array

Note that non existent indices are skipped.

- cat
- leopard
- lionyq 'omit([2, 0, 734, -5])' sample.yml- leopard

Delete

Delete entry in map

# Given a sample.yml file of:
a: cat
b: dog# then
yq 'del(.b)' sample.yml# will output
a: cat

Delete nested entry in map

a:a1: freda2: froodyq 'del(.a.a1)' sample.ymla:a2: frood

Delete entry in array

- 1
- 2
- 3yq 'del(.[1])' sample.yml- 1
- 3

Delete nested entry in array

- a: catb: dogyq 'del(.[0].a)' sample.yml- b: dog

Delete no matches

a: cat
b: dogyq 'del(.c)' sample.ymla: cat
b: dog

Delete matching entries

a: cat
b: dog
c: batyq 'del( .[] | select(. == "*at") )' sample.ymlb: dog

Recursively delete matching keys

a:name: frogb:name: blogage: 12yq 'del(.. | select(has("name")).name)' sample.ymla:b:age: 12

http://www.mrgr.cn/news/47467.html

相关文章:

  • DSP+Simulink——点亮LED灯(TMSDSP28379D)超详细
  • Linux第一课:c语言 学习记录day06
  • QEMU通过OVS实现联网
  • 细说STM32F407单片机以轮询方式读写外部SRAM的方法
  • Linux第一个系统程序---进度条
  • [java基础-集合篇]优先队列PriorityQueue结构与源码解析
  • 前端笔记(一):父传子,子传父,获取DOM对象或组件,别名路径联想设置,elemntPlus
  • Hadoop再探讨
  • BERT模型学习笔记
  • 关于贝叶斯分类器的一份介绍
  • CANoe_调用C#控件的方法_DEMO方法演示
  • Python类基本知识
  • 联软安全助手卸载 UniAccess Agent,最简单的方法,两步解决!!!
  • C语言从头学67——学习头文件stddef.h和stdbool.h
  • 挑战高薪职位--全面掌握Oracle数据库:从入门到实战高薪技能(11g至19c)
  • 10.10今日错题解析(软考)
  • 爸妈总说着学门技术,学机器视觉技术确实是一条踏实的生活道路,这条路你走得下去走得通吗?
  • ubuntu 18.04虚拟机以太网网段与地平线J6板端连接配置
  • 排序算法——归并排序
  • Lumerical——光源(Sources)
  • 40亿个QQ号,限制1G内存,如何去重?
  • Python内置函数
  • 机器学习:序列模式算法的原理、应用场景及优缺点介绍
  • opencv的相机标定与姿态解算
  • uniapp 省、市、区、乡镇 数据层级选择插件 Ba-DataPicker
  • 【工具使用】使用Docsify搭建个人文档网站