给定这个数组:
[{"Key":"base_ami","Value":"ami-46d003ac"},
{"Key":"app","Value":"amibuild"},
{"Key":"sbu","Value":"IT"},
{"Key":"base_ami_image_location","Value":"123456789012/amazon-linux"},
{"Key":"app_env","Value":"dev"},
{"Key":"Name","Value":"amazon-linux"},
{"Key":"jenkins_build_id","Value":"24"},
{"Key":"os_type","Value":"linux"},
{"Key":"version","Value":"1.0.24"}]我要这个输出:
[{"Key":"app","Value":"amibuild"},{"Key":"sbu","Value":"IT"},{"Key":"app_env","Value":"dev"}]我已经把它写到这里了:
.[] | select(.Key == "app"), select(.Key == "app_env"), select(.Key == "sbu")但结果是:
{"Key":"app","Value":"amibuild"}
{"Key":"sbu","Value":"IT"}
{"Key":"app_env","Value":"dev"}我需要这些单独的对象作为数组的元素返回。
发布于 2018-08-22 22:09:46
只需将结果包装在[...]中即可。
[.[] | select(.Key == "app"), select(.Key == "app_env"), select(.Key == "sbu")]您还可以稍微缩短这个过滤器:
[.[] | select(.Key == "app" or .Key == "app_env" or .Key == "sbu")]或者使用map函数:
map(select(.Key == "app" or .Key == "app_env" or .Key == "sbu"))https://stackoverflow.com/questions/51970546
复制相似问题