AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 807046
Accepted
Michael Martinez
Michael Martinez
Asked: 2016-10-05 10:11:20 +0800 CST2016-10-05 10:11:20 +0800 CST 2016-10-05 10:11:20 +0800 CST

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

  • 772

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

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

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

具体来说,我要查找的是 VpcId 为空、未定义或不存在的实例列表。换句话说,我想要一个我的经典实例的列表,我需要通过 api 来处理结果。

amazon-ec2 json
  • 1 1 个回答
  • 10821 Views

1 个回答

  • Voted
  1. Best Answer
    jq170727
    2017-09-06T21:53:51+08:002017-09-06T21:53:51+08:00

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

    要选择多个字段,您可以使用Object Construction。例如,此过滤器生成一个仅包含每个实例的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 不为空,请添加select。

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

相关问题

  • 权限被拒绝(公钥)。从本地 Ubuntu 到 Amazon EC2 服务器的 SSH

  • 管理员如何管理他们的 EC2 EBS 和快照?

  • 云有多大?[关闭]

  • EC2 映像启动

  • 如何将安全组添加到正在运行的 EC2 实例?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve