Как объединить объекты TargetGroupARNs и TargetGroupArn, уникальные в оболочке bash?

#json #linux #bash #shell

#json #linux #bash #оболочка

Вопрос:

У меня есть два файла json.

Я хочу объединить объекты в targetgroup.json и autoscaling.json с уникальным значением TargetGroupARNs и TargetGroupArn в оболочке bash.

Я использую jq версии 1.4 и не могу обновиться до последней версии по какой-либо причине.

 #cat autoscaling.json
      {
        "AutoScalingGroups": [
            {
                "AutoScalingGroupARN": "arn:aws:autoscaling:ap-northeast-1:050073205187:autoScalingGroup:29f22791-b9cf-49c2-9ba6-b9ac2759d767:autoScalingGroupName/asg-dev-srv-01-20190327_133322",
                "ServiceLinkedRoleARN": "arn:aws:iam::050073205187:role/aws-service-role/autoscaling.amazonaws.com/AWSServiceRoleForAutoScaling",
                "TargetGroupARNs": [
                    "arn:aws:elasticloadbalancing:ap-northeast-1:050073205187:targetgroup/dev-trial-tg/ef79ad5c9df9014e"
                ]

            },
            {
                "AutoScalingGroupARN": "arn:aws:autoscaling:ap-northeast-1:050073205187:autoScalingGroup:cf662dc3-4e27-4022-a165-ebba8ca9488b:autoScalingGroupName/asg_group",
                "ServiceLinkedRoleARN": "arn:aws:iam::050073205187:role/aws-service-role/autoscaling.amazonaws.com/AWSServiceRoleForAutoScaling",
                "TargetGroupARNs": [
                    "arn:aws:elasticloadbalancing:ap-northeast-1:050073205187:targetgroup/dev-trial1-tg/580ab71538a59063"
                ]
            }
        ]
    }


 #cat targetgroup.json
[
  {
    "TargetGroupArn": "arn:aws:elasticloadbalancing:ap-northeast-1:050073205187:targetgroup/dev-trial-tg/ef79ad5c9df9014e",
    "TargetGroupName": "dev-trial-tg"
  },
  {
    "TargetGroupArn": "arn:aws:elasticloadbalancing:ap-northeast-1:050073205187:targetgroup/dev-trial1-tg/580ab71538a59063",
    "TargetGroupName": "dev-trial1-tg"
  }
]
  

Мое желаемое:

 [
    {
        "AutoScalingGroups": [
            {
                "AutoScalingGroupARN": "arn:aws:autoscaling:ap-northeast-1:050073205187:autoScalingGroup:29f22791-b9cf-49c2-9ba6-b9ac2759d767:autoScalingGroupName/asg-dev-srv-01-20190327_133322",
                "ServiceLinkedRoleARN": "arn:aws:iam::050073205187:role/aws-service-role/autoscaling.amazonaws.com/AWSServiceRoleForAutoScaling",
                "TargetGroupARNs": [
                    "TargetGroupArn": "arn:aws:elasticloadbalancing:ap-northeast-1:050073205187:targetgroup/dev-trial-tg/ef79ad5c9df9014e",
                    "TargetGroupName": "dev-trial-tg"
                ],
            },
            {
                "AutoScalingGroupARN": "arn:aws:autoscaling:ap-northeast-1:050073205187:autoScalingGroup:cf662dc3-4e27-4022-a165-ebba8ca9488b:autoScalingGroupName/asg_group",
                "ServiceLinkedRoleARN": "arn:aws:iam::050073205187:role/aws-service-role/autoscaling.amazonaws.com/AWSServiceRoleForAutoScaling",
                "TargetGroupARNs": [
                    "TargetGroupArn": "arn:aws:elasticloadbalancing:ap-northeast-1:050073205187:targetgroup/dev-trial1-tg/580ab71538a59063",
                    "TargetGroupName": "dev-trial1-tg"
                ]
            }
        ]
    }
]
  

Я пытался, но это было слишком сложно для меня. Я надеюсь, вы сможете мне помочь.

Комментарии:

1. Ваш желаемый результат не является допустимым JSON

2. @oguzismail вы можете мне помочь? 🙁

3. Это то, чего вы хотите? jq -n 'input | reduce (input|to_entries)[] as $p (.; .AutoScalingGroups[$p.key].TargetGroupARNs = $p.value)' autoscaling.json targetgroup.json

4. @oguzismail. Это работает. Большое спасибо, брат

5. @oguzismail о. большое вам спасибо

Ответ №1:

Это решение от @oguzismail

 jq -n 'input | reduce (input|to_entries)[] as $p (.; .AutoScalingGroups[$p.key].TargetGroupARNs = $p.value)' autoscaling.json targetgroup.json