具体来说(https://github.com/mikefarah/yq)4.35+我有一个以逗号分隔的术语字符串,并且如果字段值是其中一个术语,我想过滤列表。例如)给定以下输入:-
具体来说 https://github.com/mikefarah/yq https://github.com/mikefarah/yq)4.35+
我有一个以逗号分隔的术语字符串,如果字段值是这些术语之一,我想过滤列表。
例如)给定以下输入:
- name: bob
age: 12
- name: jen
age: 22
- name: mork
age: 4003
字段值作为子字符串存在的 name
元素 "jen,mork"
使得输出为:
- name: jen
age: 22
- name: mork
age: 4003
我还可以将这些术语表示为字符串数组,即 ["jen", "mork"]
因此相当于:
yq 'filter("jen,mork" | contains(.name))' array.yaml
# Though I'm not sure how `contains` gets the original array context
# or
yq 'filter(.name in ["jen", "mork"])' array.yaml
我意识到这可以通过构建一个集合来完成 or
,如下所示:
yq 'filter(.name == "jen" or .name == "mork"])' array.yaml
但我希望得到一些更优雅的东西。
我不太确定该尝试什么,因为这似乎与操作员想要的工作方式背道而驰。
只需构建一个流,比较就会自动迭代其项目:
yq 'filter(.name == ("jen", "mork"))' array.yaml
要导入列表,请使用环境变量并 env
访问它:
list='["jen", "mork"]' yq 'filter(.name == (env(list) | .[]))' array.yaml
使用 yq v4.44.2,您可以缩短为 .name == env(list)[]
.
输出:
- name: jen
age: 22
- name: mork
age: 4003