如何告诉 jq 打印 aws ec2 cli 返回的每个实例的两个键的内容

如何告诉 jq 打印 aws ec2 cli 返回的每个实例的两个键的内容

运行 aws ec2 describe-instances 将返回类似以下内容的 json 文本:

{
    "Reservations": [
        {
            "Instances": [
                  "PublicDnsName": "ec2..."
                    "VpcId": "vpc-...",
                        ...
            "Instances": [

我知道对于每个“实例”,我可以使用 jq 提取单个字段的内容,例如 PublicDnsName,如下所示: jq '.Reservations[].Instances[].PublicDnsName'这将列出我的实例的 DNS 名称,但如何提取两个或多个字段并用空格或逗号等分隔它们?我希望每个实例的 PublicDnsName 和 VpcId 并排列出。

具体来说,我正在寻找的是 VpcId 为空、未定义或不存在的实例列表。换句话说,我想要一份我的 Classic 实例列表,我需要通过 API 获得它,以便处理结果。

答案1

以下是使用一些示例代码和数据的方法我对类似问题的回答在 Stack Overflow 上。

要选择多个字段,您可以使用对象构造。例如,此过滤器会创建一个仅包含PublicDnsName每个VpcId实例的对象:

  .Reservations[]
| .Instances[]
| {PublicDnsName, VpcId}

如果此过滤器在filter.jq并且来自其他答案的样本数据在,data.json则运行

$ jq -M -f filter.jq data.json

生产

{
  "PublicDnsName": "xxxxxxxx",
  "VpcId": "vpc-eb09eb8e"
}

一旦你有了包含所需内容的对象,将数据转换为另一种格式(例如 csv)就很容易了。使用此过滤器

  .Reservations[]
| .Instances[]
| {PublicDnsName, VpcId}
| [.[]]
| @csv

以及-r选项

$ jq -M -r -f filter.jq data.json

jq生产

"xxxxxxxx","vpc-eb09eb8e"

要添加过滤条件,例如 VpcId 不为空,请添加选择

  .Reservations[]
| .Instances[]
| {PublicDnsName, VpcId}
| select(.VpcId != null)
| [.[]]
| @csv

相关内容