[
    {
        "tags": [
            "json",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 20,
                "is_accepted": true,
                "score": 20,
                "last_activity_date": 1632448514,
                "last_edit_date": 1632448514,
                "creation_date": 1520622524,
                "answer_id": 49200556,
                "question_id": 49200066,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**`jq`**&#39;s `sort_by()` function accepts an array as input.\r\n\r\n    curl &#39;http://...&#39; |\r\n        jq -r &#39;\r\n            map(select(.parent_id != null)) \r\n            | sort_by(.parent_id)[]\r\n            | [.name, .parent_id]\r\n            | @tsv\r\n        &#39;\r\n\r\nSample output:\r\n\r\n    asdfg\t7\r\n    another-test\t9",
                "title": "jq select() and sort_by()"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 15,
        "last_activity_date": 1632448514,
        "creation_date": 1520620331,
        "question_id": 49200066,
        "body_markdown": "I am parsing a curl output from gitlab api, and I need to add a sort_by to my query, then select only certain values.\r\n\r\nsample input:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 10,\r\n        &quot;name&quot;: &quot;another-test&quot;,\r\n        &quot;path&quot;: &quot;another-test&quot;,\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;visibility&quot;: &quot;private&quot;,\r\n        &quot;lfs_enabled&quot;: true,\r\n        &quot;avatar_url&quot;: null,\r\n        &quot;web_url&quot;: &quot;https://mygitlab/groups/another-test&quot;,\r\n        &quot;request_access_enabled&quot;: false,\r\n        &quot;full_name&quot;: &quot;another-test&quot;,\r\n        &quot;full_path&quot;: &quot;another-test&quot;,\r\n        &quot;parent_id&quot;: 9\r\n      },\r\n      {\r\n        &quot;id&quot;: 11,\r\n        &quot;name&quot;: &quot;asdfg&quot;,\r\n        &quot;path&quot;: &quot;asdfg&quot;,\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;visibility&quot;: &quot;private&quot;,\r\n        &quot;lfs_enabled&quot;: true,\r\n        &quot;avatar_url&quot;: null,\r\n        &quot;web_url&quot;: &quot;https://mygitlab/groups/asdfg&quot;,\r\n        &quot;request_access_enabled&quot;: false,\r\n        &quot;full_name&quot;: &quot;asdfg&quot;,\r\n        &quot;full_path&quot;: &quot;asdfg&quot;,\r\n        &quot;parent_id&quot;: 7\r\n      }\r\n\r\nI parse the JSON with jq as follows:\r\n\r\n    curl http://..... | jq -r &#39;.[] | select(.parent_id!=null) | .name, .parent_id&#39; \r\n\r\nThis works exactly as expected, but when I try to sort the results by parent_id, I get an error:\r\n\r\n    curl http://..... | jq -r &#39;.[] | select(.parent_id!=null) | .name, .parent_id | sort_by(.parent_id)&#39;\r\n    jq: error (at &lt;stdin&gt;:0): Cannot index number with string &quot;parent_id&quot;\r\n\r\nI can use sort_by(), by putting a single dot instead than .[]:\r\n\r\n    curl http://..... | jq &#39;. | sort_by(.parent_id) &#39;\r\n\r\nBut I cannot combine the 2 functions.\r\n\r\nClarification: I need to extract name and parent_id, sorted by parent_id, when it is not null.\r\n\r\nThanks in advance",
        "link": "https://stackoverflow.com/questions/49200066/jq-select-and-sort-by",
        "title": "jq select() and sort_by()"
    },
    {
        "tags": [
            "json",
            "csv",
            "kafka-consumer-api",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1520637655,
                "last_edit_date": 1520637655,
                "creation_date": 1520637305,
                "answer_id": 49203564,
                "question_id": 49202920,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq -r &#39;[.isBusiness, .countryCode, .phone] | @csv&#39;\r\n\r\nproduces CSV:\r\n\r\n    false,&quot; MX&quot;,&quot;52/4446789864&quot;\r\n    false,&quot; GB&quot;,&quot;44/0187567846&quot;\r\n\r\nThe filter:\r\n\r\n    &quot;\\(.isBusiness), \\(.countryCode), \\(.phone)&quot;\r\n\r\nproduces\r\n\r\n    false,  MX, 52/4446789864\r\n    false,  GB, 44/0187567846\r\n\r\nYou might want to &quot;trim&quot; the string values, e.g. using:\r\n\r\n    def trim: sub(&quot;^ +&quot;;&quot;&quot;) | sub(&quot; +$&quot;;&quot;&quot;);\r\n",
                "title": "Consuming json values from a kafka topic and writing them and formatting them in a csv file using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1520652232,
        "creation_date": 1520633323,
        "last_edit_date": 1520652232,
        "question_id": 49202920,
        "body_markdown": "I am trying to write into a csv file keys and values that are in a kafka topic. I have been able to select the keys and values that I want, but I am not able to get them separated by rows (three values per row values in rows separated by commas).\r\n\r\nThis is an example of two json records that I consumed from my kafka topic without doing any filtering. The command that I used is:\r\n\r\n`./kafka-run-class.sh kafka.tools.ConsoleConsumer --bootstrap-server kafka1.example.net:9092 --topic prod.example.v1 --max-messages 2 | jq -r &#39;. &#39;` \r\n\r\n`{\r\n  &quot;count&quot;: &quot;0&quot;,\r\n  &quot;source&quot;: 3,\r\n  &quot;lastModified&quot;: &quot;2018-03-09T21:03:54.039Z&quot;,\r\n  &quot;isBusiness&quot;: false,\r\n  &quot;countryCode&quot;: &quot; MX&quot;,\r\n  &quot;phone&quot;: &quot;52/4446789864&quot;\r\n}\r\n{\r\n  &quot;count&quot;: &quot;0&quot;,\r\n  &quot;source&quot;: 3,\r\n  &quot;lastModified&quot;: &quot;2018-03-09T21:03:54.039Z&quot;,\r\n  &quot;isBusiness&quot;: false,\r\n  &quot;countryCode&quot;: &quot; GB&quot;,\r\n  &quot;phone&quot;: &quot;44/0187567846&quot;\r\n}`\r\n\r\nI tried using this command, but each value is being put into its own row:\r\n\r\n`./kafka-run-class.sh kafka.tools.ConsoleConsumer --bootstrap-server kafka1.example.net:9092 --topic prod.example.v1 --max-messages 3 | jq -r &#39; .isBusiness, .countryCode, .phone &#39; &gt; file.csv`\r\n\r\nIdeal output would be:\r\n\r\n    false, MX, 52/4446789864\r\n    false, GB, 44/0187567846\r\n    true, BE, 32/8745687645",
        "link": "https://stackoverflow.com/questions/49202920/consuming-json-values-from-a-kafka-topic-and-writing-them-and-formatting-them-in",
        "title": "Consuming json values from a kafka topic and writing them and formatting them in a csv file using JQ"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520823477,
                "post_id": 49225840,
                "comment_id": 85458763,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 46983,
                    "reputation": 2952,
                    "user_id": 139040,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://i.sstatic.net/jZr6E.jpg?s=256",
                    "display_name": "Gaia",
                    "link": "https://stackoverflow.com/users/139040/gaia"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520870940,
                "post_id": 49225840,
                "comment_id": 85483021,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1520809298,
                "creation_date": 1520809298,
                "answer_id": 49226039,
                "question_id": 49225840,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The main non-obvious thing here is the post-fix &quot;not&quot;:\r\n\r\n    select( ( .subver | test(&quot;(^|:)0.22.5.7($|/)&quot;) | not) or\r\n            .synced_blocks &lt; 77982)",
                "title": "JQ: Filter result by does not contain string OR is less than value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1520811532,
        "creation_date": 1520807757,
        "last_edit_date": 1520811532,
        "question_id": 49225840,
        "body_markdown": "On Ubuntu, I have\r\n\r\n    jq &#39;.[] | {addr: .addr, subver: .subver, inbound: .inbound, synced_blocks: .synced_blocks} | select(.synced_blocks &lt; 77982)&#39;\r\n\r\n    {\r\n      &quot;addr&quot;: &quot;299.247.7.254:8268&quot;,\r\n      &quot;subver&quot;: &quot;/String:0.22.5.7/&quot;,\r\n      &quot;inbound&quot;: false,\r\n      &quot;synced_blocks&quot;: 77979\r\n    }\r\n    {\r\n      &quot;addr&quot;: &quot;228.290.206.224:8268&quot;,\r\n      &quot;subver&quot;: &quot;/String:0.22.5.6/&quot;,\r\n      &quot;inbound&quot;: false,\r\n      &quot;synced_blocks&quot;: 77980\r\n    }\r\n    {\r\n      &quot;addr&quot;: &quot;208.62.262.244:55226&quot;,\r\n      &quot;subver&quot;: &quot;/String:0.22.5.7/&quot;,\r\n      &quot;inbound&quot;: true,\r\n      &quot;synced_blocks&quot;: 77978\r\n    }\r\n    {\r\n      &quot;addr&quot;: &quot;200.2.222.25:50452&quot;,\r\n      &quot;subver&quot;: &quot;/String:0.22.5.7/&quot;,\r\n      &quot;inbound&quot;: true,\r\n      &quot;synced_blocks&quot;: 77980\r\n    }\r\n    {\r\n      &quot;addr&quot;: &quot;220.92.79.44:50970&quot;,\r\n      &quot;subver&quot;: &quot;/String:0.22.4.2/&quot;,\r\n      &quot;inbound&quot;: true,\r\n      &quot;synced_blocks&quot;: -2\r\n    }\r\n    {\r\n      &quot;addr&quot;: &quot;45.22.228.69:57462&quot;,\r\n      &quot;subver&quot;: &quot;/String:0.22.5.7/&quot;,\r\n      &quot;inbound&quot;: true,\r\n      &quot;synced_blocks&quot;: 77980\r\n    }\r\n    {\r\n      &quot;addr&quot;: &quot;29.206.256.229:8268&quot;,\r\n      &quot;subver&quot;: &quot;/String:0.22.5.7/&quot;,\r\n      &quot;inbound&quot;: false,\r\n      &quot;synced_blocks&quot;: 77980\r\n    }\r\n\r\nAlso\r\n\r\n    select(.subver | contains(&quot;0.22.5.7&quot;) | not)\r\n\r\nworks to show results where subver does not contain  &quot;0.22.5.7&quot;. But I can&#39;t fit in an OR for both conditions.\r\n\r\n**How do I show only results where subver does not contain  &quot;0.22.5.7&quot; OR .synced_blocks &lt; 77982 ?**",
        "link": "https://stackoverflow.com/questions/49225840/jq-filter-result-by-does-not-contain-string-or-is-less-than-value",
        "title": "JQ: Filter result by does not contain string OR is less than value"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1520828775,
                "creation_date": 1520828775,
                "answer_id": 49228151,
                "question_id": 49228126,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Look at these links\r\n\r\nhttps://stackoverflow.com/questions/32960857/how-to-convert-arbirtrary-simple-json-to-csv-using-jq\r\n\r\nhttp://bigdatums.net/2017/09/30/convert-json-to-csv-with-jq/\r\n\r\n( jq -r &#39;.myarray | @csv&#39; )",
                "title": "How to convert json into csv file using jq?"
            },
            {
                "up_vote_count": 14,
                "is_accepted": true,
                "score": 14,
                "last_activity_date": 1559078132,
                "last_edit_date": 1559078132,
                "creation_date": 1520831011,
                "answer_id": 49228411,
                "question_id": 49228126,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you want all the key-values, \r\nthen assuming that the keys are presented in a consistent order in the input file, you can simply write: \r\n\r\n    jq -r &#39;[.[]] | @csv&#39; palanikumar.json\r\n\r\nWith the given input, this produces the following CSV:\r\n\r\n    &quot;ca&quot;,812,404,130756,&quot;hit&quot;\r\n    &quot;ua&quot;,206996,301,142,&quot;unknown&quot;\r\n    &quot;ua&quot;,206996,0,0,&quot;unknown&quot;\r\n\r\nAdding the headers and the trailing semicolons (if you really want them) is left as a (very easy) exercise.\r\n\r\n## Inconsistent ordering\r\nIf the ordering of the keys varies or might vary, then the following could be used to produce suitable CSV, assuming that the ordering of the keys in the first object in the input stream should be used:\r\n\r\n\r\n    input\r\n    | . as $first\r\n    | keys_unsorted as $keys\r\n    | $keys, [$first[]], (inputs | [.[$keys[]]]) | @csv\r\n\r\nThe appropriate invocation of jq would include both the -n and -r command-line options.\r\n\r\n",
                "title": "How to convert json into csv file using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 12,
        "last_activity_date": 1559078132,
        "creation_date": 1520828516,
        "last_edit_date": 1520861472,
        "question_id": 49228126,
        "body_markdown": "This is my json file:\r\n\r\n    {\r\n      &quot;ClientCountry&quot;: &quot;ca&quot;,\r\n      &quot;ClientASN&quot;: 812,\r\n      &quot;CacheResponseStatus&quot;: 404,\r\n      &quot;CacheResponseBytes&quot;: 130756,\r\n      &quot;CacheCacheStatus&quot;: &quot;hit&quot;\r\n    }\r\n    {\r\n      &quot;ClientCountry&quot;: &quot;ua&quot;,\r\n      &quot;ClientASN&quot;: 206996,\r\n      &quot;CacheResponseStatus&quot;: 301,\r\n      &quot;CacheResponseBytes&quot;: 142,\r\n      &quot;CacheCacheStatus&quot;: &quot;unknown&quot;\r\n    }\r\n    {\r\n      &quot;ClientCountry&quot;: &quot;ua&quot;,\r\n      &quot;ClientASN&quot;: 206996,\r\n      &quot;CacheResponseStatus&quot;: 0,\r\n      &quot;CacheResponseBytes&quot;: 0,\r\n      &quot;CacheCacheStatus&quot;: &quot;unknown&quot;\r\n    }\r\n\r\nI want to convert these json into csv like below.\r\n\r\n    &quot;ClientCountry&quot;, &quot;ClientASN&quot;,&quot;CacheResponseStatus&quot;, &quot;CacheResponseBytes&quot;, &quot;CacheCacheStatus&quot;\r\n    &quot;ca&quot;, 812, 404, 130756, &quot;hit&quot;;\r\n    &quot;ua&quot;, 206996, 301, 142,&quot;unknown&quot;;\r\n    &quot;ua&quot;, 206996, 0,0,&quot;unknown&quot;;\r\n\r\nPlease let me know how to achieve this using jq?\r\n\r\nI just tried below. But its not working.\r\n\r\n    jq &#39;to_entries[] | [.key, .value] | @csv&#39;\r\n\r\nRegards\r\nPalani",
        "link": "https://stackoverflow.com/questions/49228126/how-to-convert-json-into-csv-file-using-jq",
        "title": "How to convert json into csv file using jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1520872945,
                "last_edit_date": 1520872945,
                "creation_date": 1520868803,
                "answer_id": 49239004,
                "question_id": 49238602,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -r &#39;.RoleDetailList | map(select(.AttachedManagedPolicies | length &gt; 0))[] \r\n           | .RoleName as $r | .AttachedManagedPolicies[] \r\n           | [$r, .PolicyName] | @csv&#39; output.json\r\nSample output:\r\n\r\n    &quot;ADFS-amtest-ro&quot;,&quot;pol-amtest-ro&quot;\r\n    &quot;adfs-host-role&quot;,&quot;pol-amtest-ro&quot;\r\n    &quot;aws-elasticbeanstalk-ec2-role&quot;,&quot;AWSElasticBeanstalkWebTier&quot;\r\n    &quot;aws-elasticbeanstalk-ec2-role&quot;,&quot;AWSElasticBeanstalkMulticontainerDocker&quot;\r\n    &quot;aws-elasticbeanstalk-ec2-role&quot;,&quot;AWSElasticBeanstalkWorkerTier&quot;\r\n    &quot;aws-elasticbeanstalk-service-role&quot;,&quot;AWSElasticBeanstalkEnhancedHealth&quot;\r\n    &quot;aws-elasticbeanstalk-service-role&quot;,&quot;AWSElasticBeanstalkService&quot;\r\n    &quot;AWSAccCorpAdmin&quot;,&quot;AdministratorAccess&quot;\r\n    &quot;AWScompanyCorpAdmin&quot;,&quot;AdministratorAccess&quot;\r\n    &quot;AWScompanyCorpPowerUser&quot;,&quot;PowerUserAccess&quot;\r\n    &quot;AWSServiceRoleForAutoScaling&quot;,&quot;AutoScalingServiceRolePolicy&quot;\r\n    &quot;AWSServiceRoleForElasticBeanstalk&quot;,&quot;AWSElasticBeanstalkServiceRolePolicy&quot;\r\n    &quot;AWSServiceRoleForElasticLoadBalancing&quot;,&quot;AWSElasticLoadBalancingServiceRolePolicy&quot;\r\n    &quot;AWSServiceRoleForOrganizations&quot;,&quot;AWSOrganizationsServiceTrustPolicy&quot;\r\n    &quot;AWSServiceRoleForRDS&quot;,&quot;AmazonRDSServiceRolePolicy&quot;\r\n    &quot;Cloudyn&quot;,&quot;ReadOnlyAccess&quot;\r\n    &quot;DatadogAWSIntegrationRole&quot;,&quot;DatadogAWSIntegrationPolicy&quot;\r\n    &quot;datadog_alert_metrics_role&quot;,&quot;AWSLambdaBasicExecutionRole-66abe1f2-cee8-4a90-a026-061b24db1b02&quot;\r\n    &quot;dev-instance-role&quot;,&quot;dev-instance-role-policy&quot;\r\n    &quot;ecsInstanceRole&quot;,&quot;AmazonEC2ContainerServiceforEC2Role&quot;\r\n    &quot;ecsServiceRole&quot;,&quot;AmazonEC2ContainerServiceRole&quot;\r\n    &quot;companySAMLUser&quot;,&quot;AdministratorAccess&quot;\r\n    &quot;irole-matlabscheduler&quot;,&quot;pol-marketdata-rw&quot;\r\n    &quot;lambda-ec2-ami-role&quot;,&quot;lambda-ec2-ami-policy&quot;\r\n    &quot;lambda_api_gateway_twilio_processor&quot;,&quot;AWSLambdaBasicExecutionRole-f47a6b57-b716-4740-b2c6-a02fa6480153&quot;\r\n    &quot;lambda_api_gateway_twilio_processor&quot;,&quot;AWSLambdaSNSPublishPolicyExecutionRole-d31a9f16-80e7-47c9-868a-f162396cccf6&quot;\r\n    &quot;OneLoginAdmin&quot;,&quot;AdministratorAccess&quot;\r\n    &quot;OneLoginDev&quot;,&quot;PowerUserAccess&quot;\r\n    &quot;rds-monitoring-role&quot;,&quot;AmazonRDSEnhancedMonitoringRole&quot;\r\n    &quot;role-amtest-ro&quot;,&quot;pol-amtest-ro&quot;\r\n    ...\r\n\r\n",
                "title": "How to extract specific section from JSON and convert it to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1520872945,
        "creation_date": 1520867662,
        "last_edit_date": 1520871196,
        "question_id": 49238602,
        "body_markdown": "Part of output.json (file has multiple same sections-only role/policy name differs) full link:https://1drv.ms/u/s!AizscpxS0QM4hJl_VRQaWbm6D8T8_w\r\n\r\n    {\r\n      &quot;AssumeRolePolicyDocument&quot;: {\r\n        &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n        &quot;Statement&quot;: [\r\n          {\r\n            &quot;Action&quot;: &quot;sts:AssumeRoleWithSAML&quot;,\r\n            &quot;Effect&quot;: &quot;Allow&quot;,\r\n            &quot;Condition&quot;: {\r\n              &quot;StringEquals&quot;: {\r\n                &quot;SAML:aud&quot;: &quot;https://signin.aws.amazon.com/saml&quot;\r\n              }\r\n            },\r\n            &quot;Principal&quot;: {\r\n              &quot;Federated&quot;: &quot;arn:aws:iam::279052847476:saml-provider/LastPass&quot;\r\n            }\r\n          }\r\n        ]\r\n      },\r\n      &quot;RoleId&quot;: &quot;AROAI3SYPHW7ZSS4TSO6Y&quot;,\r\n      &quot;CreateDate&quot;: &quot;2017-05-23T22:29:53Z&quot;,\r\n      &quot;InstanceProfileList&quot;: [],\r\n      &quot;RoleName&quot;: &quot;AWSCorpAdmin&quot;,\r\n      &quot;Path&quot;: &quot;/&quot;,\r\n      &quot;AttachedManagedPolicies&quot;: [\r\n        {\r\n          &quot;PolicyName&quot;: &quot;AdministratorAccess&quot;,\r\n          &quot;PolicyArn&quot;: &quot;arn:aws:iam::aws:policy/AdministratorAccess&quot;\r\n        }\r\n      ],\r\n      &quot;RolePolicyList&quot;: [],\r\n      &quot;Arn&quot;: &quot;arn:aws:iam::279052847476:role/AWSCorpAdmin&quot;\r\n    }\r\n\r\nHow to get following output (map IAM role to policy) and convert it to csv file using jq  ?\r\n\r\n    jq -r &#39;.AssumeRolePolicyDocument[]| .fields.RoleName |  @csv&#39; output.json\r\n    jq: error (at output.json:11895): Cannot iterate over null (null)\r\n\r\n\r\n\r\nDesired output:\r\n\r\n    AWSCorpAdmin,AdministratorAccess \r\nI need to loop throuhg whole JSON file and to get policy for every role (above is just example)\r\n \r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49238602/how-to-extract-specific-section-from-json-and-convert-it-to-csv",
        "title": "How to extract specific section from JSON and convert it to CSV"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1520875367,
                "creation_date": 1520875367,
                "answer_id": 49241106,
                "question_id": 49240873,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -r &#39;.foo | to_entries[] | &quot;\\(.key),\\(.value.name),\\(.value.role)&quot;&#39; example.json\r\nThe output:\r\n\r\n    bar,bob,gopherthis\r\n    baz,tom,gopherthat\r\n\r\n",
                "title": "jq query CSV output with name of &#39;this&#39; thing"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1520875367,
        "creation_date": 1520874609,
        "question_id": 49240873,
        "body_markdown": "example.json\r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;bar&quot;: {\r\n          &quot;name&quot;: &quot;bob&quot;,\r\n          &quot;role&quot;: &quot;gopherthis&quot;\r\n        },\r\n        &quot;baz&quot;: {\r\n          &quot;name&quot;: &quot;tom&quot;,\r\n          &quot;role&quot;: &quot;gopherthat&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nexample query:\r\n\r\n    jq -r &#39;.foo[] | &quot; \\(.name),\\(.role) &quot; &#39; example.json\r\n     bob,gopherthis \r\n     tom,gopherthat \r\n\r\n\r\nMy question is how do I get bar and baz associated with their name and role?  Where the output would be:\r\n\r\n\r\n    bar,bob,gopherthis\r\n    baz,tom,gopherthat\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49240873/jq-query-csv-output-with-name-of-this-thing",
        "title": "jq query CSV output with name of &#39;this&#39; thing"
    },
    {
        "tags": [
            "json",
            "bash",
            "for-loop",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1520913796,
                "creation_date": 1520913796,
                "answer_id": 49248165,
                "question_id": 49247989,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; is there just a better solution ... ?\r\n\r\nYes!\r\n\r\n1. You evidently only need one call to curl and one to jq, but at the very\r\nleast, you should avoid calling curl more than once.\r\n\r\n2.  Avoid constructing the jq command &quot;on the fly&quot;.  Instead, you can pass in the shell (or environment) variables\r\non the command line, e.g. using --arg or --argjson\r\n\r\n3.  In this specific case, it looks like you can avoid calling jq more than once by simply using jq&#39;s &#39;,&#39; operator.\r\n\r\nIn brief, try something along the following lines:\r\n\r\n     curl -s &quot;$extension_url&quot; |\r\n       jq --arg extension &quot;$extension&quot; &#39;\r\n         .[$extension][&quot;header&quot;,&quot;developer&quot;,&quot;category&quot;,&quot;description&quot;]&#39;\r\n",
                "title": "Is there a better solution to cURL this JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1631796191,
        "creation_date": 1520912588,
        "last_edit_date": 1631796191,
        "question_id": 49247989,
        "body_markdown": "I have this function that iterates over the keys of a given JSON using `curl` and `jq` as the JSON processor, My code looks like this : (bash)\r\n\r\n    function getJSONContent {\r\n      option=&quot;&quot;\r\n\r\n      for option in &quot;header&quot; &quot;developer&quot; &quot;category&quot; &quot;description&quot;\r\n      do\r\n        content=$(curl -s $extension_url | jq &quot;.[\\&quot;$extension\\&quot;][\\&quot;$option\\&quot;]&quot;)\r\n        printf &quot;$content\\n&quot;\r\n      done\r\n    }\r\n\r\nBut the problem is that it curl&#39;s 4 time and I haven&#39;t found a better solution to this without getting an error. \r\n\r\n**Is doing this okay? Or is there just a better solution to do this in Bash / Shellscript?**",
        "link": "https://stackoverflow.com/questions/49247989/is-there-a-better-solution-to-curl-this-json",
        "title": "Is there a better solution to cURL this JSON?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1520940556,
                "creation_date": 1520940556,
                "answer_id": 49255020,
                "question_id": 49253032,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -r &#39;.RoleDetailList \r\n           | map(select((.AssumeRolePolicyDocument.Statement | length &gt; 0) \r\n                         and (.AssumeRolePolicyDocument.Statement[0].Principal.Federated) \r\n                         and (.RolePolicyList | length &gt; 0))\r\n             )[] \r\n           | [(.AssumeRolePolicyDocument.Statement[0] | .Action, .Principal.Federated),\r\n               .RoleName, .RolePolicyList[0].PolicyName] | @csv&#39; output.json\r\nThe output:\r\n\r\n    &quot;sts:AssumeRoleWithSAML&quot;,&quot;arn:aws:iam::279052847476:saml-provider/companyADFS&quot;,&quot;ADFS-Administrators&quot;,&quot;Administrator-Access&quot;",
                "title": "Parsing JSON file using JQ and export it to CSV-BASH"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1521015531,
        "creation_date": 1520934804,
        "last_edit_date": 1521015531,
        "question_id": 49253032,
        "body_markdown": "JSON file:https://1drv.ms/u/s!AizscpxS0QM4hJl_VRQaWbm6D8T8_w\r\n\r\n\r\nThis is one section:\r\n\r\n    &quot;RoleDetailList&quot;: [\r\n            {\r\n                &quot;AssumeRolePolicyDocument&quot;: {\r\n                    &quot;Version&quot;: &quot;2012-10-17&quot;, \r\n                    &quot;Statement&quot;: [\r\n                        {\r\n                            &quot;Action&quot;: &quot;sts:AssumeRoleWithSAML&quot;, \r\n                            &quot;Effect&quot;: &quot;Allow&quot;, \r\n                            &quot;Condition&quot;: {\r\n                                &quot;StringEquals&quot;: {\r\n                                    &quot;SAML:aud&quot;: &quot;https://signin.aws.amazon.com/saml&quot;\r\n                                }\r\n                            }, \r\n                            &quot;Principal&quot;: {\r\n                                &quot;Federated&quot;: &quot;arn:aws:iam::279052847476:saml-provider/CompanyADFS&quot;\r\n                            }\r\n                        }\r\n                    ]\r\n                }, \r\n                &quot;RoleId&quot;: &quot;AROAJANL3L2IZ6UISEGAU&quot;, \r\n                &quot;CreateDate&quot;: &quot;2016-08-20T13:51:07Z&quot;, \r\n                &quot;InstanceProfileList&quot;: [], \r\n                &quot;RoleName&quot;: &quot;ADFS-Administrators&quot;, \r\n                &quot;Path&quot;: &quot;/&quot;, \r\n                &quot;AttachedManagedPolicies&quot;: [], \r\n                &quot;RolePolicyList&quot;: [\r\n                    {\r\n                        &quot;PolicyName&quot;: &quot;Administrator-Access&quot;, \r\n                        &quot;PolicyDocument&quot;: {\r\n                            &quot;Version&quot;: &quot;2012-10-17&quot;, \r\n                            &quot;Statement&quot;: [\r\n                                {\r\n                                    &quot;Action&quot;: &quot;*&quot;, \r\n                                    &quot;Resource&quot;: &quot;*&quot;, \r\n                                    &quot;Effect&quot;: &quot;Allow&quot;, \r\n                                    &quot;Sid&quot;: &quot;Stmt1434192117145&quot;\r\n                                }\r\n                            ]\r\n                        }\r\n                    }\r\n                ], \r\n                &quot;Arn&quot;: &quot;arn:aws:iam::279052847476:role/ADFS-Administrators&quot;\r\n            },\r\n\r\n\r\nHow,for all these sections in JSON file to get following (this is example for this section only) to CSV format ?\r\n\r\n \r\n\r\n\r\n@Roman, your solution works, how to add another column, to get Policy Name from\r\n\r\n    &quot;AttachedManagedPolicies&quot;: [\r\n                    {\r\n                        &quot;PolicyName&quot;: &quot;pol-amtest-ro&quot;, \r\n                        &quot;PolicyArn&quot;: &quot;arn:aws:iam::279052847476:policy/pol-amtest-ro&quot;\r\n                    }\r\n                ], \r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49253032/parsing-json-file-using-jq-and-export-it-to-csv-bash",
        "title": "Parsing JSON file using JQ and export it to CSV-BASH"
    },
    {
        "tags": [
            "bash",
            "jq",
            "strptime"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520964379,
                "post_id": 49262889,
                "comment_id": 85529527,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520964475,
                "post_id": 49262889,
                "comment_id": 85529601,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3377022,
                    "reputation": 13682,
                    "user_id": 2834978,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ff9af10001f37bc0de566ca2caf2f558?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "LMC",
                    "link": "https://stackoverflow.com/users/2834978/lmc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520964528,
                "post_id": 49262889,
                "comment_id": 85529624,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 3377022,
                    "reputation": 13682,
                    "user_id": 2834978,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ff9af10001f37bc0de566ca2caf2f558?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "LMC",
                    "link": "https://stackoverflow.com/users/2834978/lmc"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1520964607,
                "post_id": 49262889,
                "comment_id": 85529666,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11954057,
                    "reputation": 900,
                    "user_id": 8746930,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://lh3.googleusercontent.com/-4vA616Iuc-I/AAAAAAAAAAI/AAAAAAAAAAc/5hrF-krxrXM/s256-rj/photo.jpg",
                    "display_name": "eagle",
                    "link": "https://stackoverflow.com/users/8746930/eagle"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520964699,
                "post_id": 49262889,
                "comment_id": 85529720,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520964758,
                "post_id": 49262889,
                "comment_id": 85529753,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11954057,
                    "reputation": 900,
                    "user_id": 8746930,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://lh3.googleusercontent.com/-4vA616Iuc-I/AAAAAAAAAAI/AAAAAAAAAAc/5hrF-krxrXM/s256-rj/photo.jpg",
                    "display_name": "eagle",
                    "link": "https://stackoverflow.com/users/8746930/eagle"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520964918,
                "post_id": 49262889,
                "comment_id": 85529838,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3377022,
                    "reputation": 13682,
                    "user_id": 2834978,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ff9af10001f37bc0de566ca2caf2f558?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "LMC",
                    "link": "https://stackoverflow.com/users/2834978/lmc"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520965118,
                "post_id": 49262889,
                "comment_id": 85529944,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11954057,
                    "reputation": 900,
                    "user_id": 8746930,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://lh3.googleusercontent.com/-4vA616Iuc-I/AAAAAAAAAAI/AAAAAAAAAAc/5hrF-krxrXM/s256-rj/photo.jpg",
                    "display_name": "eagle",
                    "link": "https://stackoverflow.com/users/8746930/eagle"
                },
                "reply_to_user": {
                    "account_id": 3377022,
                    "reputation": 13682,
                    "user_id": 2834978,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ff9af10001f37bc0de566ca2caf2f558?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "LMC",
                    "link": "https://stackoverflow.com/users/2834978/lmc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520965157,
                "post_id": 49262889,
                "comment_id": 85529963,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11954057,
                    "reputation": 900,
                    "user_id": 8746930,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://lh3.googleusercontent.com/-4vA616Iuc-I/AAAAAAAAAAI/AAAAAAAAAAc/5hrF-krxrXM/s256-rj/photo.jpg",
                    "display_name": "eagle",
                    "link": "https://stackoverflow.com/users/8746930/eagle"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520965290,
                "post_id": 49262889,
                "comment_id": 85530030,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1520965307,
                "post_id": 49262889,
                "comment_id": 85530045,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1520965957,
                "last_edit_date": 1520965957,
                "creation_date": 1520964523,
                "answer_id": 49263033,
                "question_id": 49262889,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The issue is not the timezone, but the nanoseconds field; `%f` is not available in standard `strptime` for C.\r\n\r\nIf you know your format won&#39;t change, there&#39;s no particular reason to use `strptime` or `strftime` at all:\r\n\r\n    jq -r &#39;.time_field | sub(&quot;^(?&lt;date&gt;[[:digit:]-]+)T(?&lt;time&gt;[[:digit:]:]+)[.].*&quot;;\r\n                             &quot;\\(.date) \\(.time)&quot;)&#39; \\\r\n      &lt;&lt;&lt;&#39;{&quot;time_field&quot;: &quot;2018-03-13T14:00:17.1614661Z&quot;}&#39;\r\n\r\n...properly emits:\r\n\r\n    2018-03-13 14:00:17",
                "title": "Strptime with timezones and jq"
            },
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1520993436,
                "last_edit_date": 1520993436,
                "creation_date": 1520965544,
                "answer_id": 49263320,
                "question_id": 49262889,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "So I found a workaround to get around the ZULU offset and the nano-seconds since I do not really care so much about the nano-seconds. Not sure if it is efficient\r\n\r\n    echo &#39;{&quot;time_field&quot;: &quot;2018-03-13T14:00:17.1234567Z&quot;}&#39; | jq -r &#39;\r\n    .time_field \r\n    | split(&quot;.&quot;)[0] \r\n    | strptime(&quot;%Y-%m-%dT%H:%M:%S&quot;) \r\n    | mktime \r\n    | strftime(&quot;%F %X&quot;)&#39;",
                "title": "Strptime with timezones and jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1520993436,
        "creation_date": 1520964057,
        "last_edit_date": 1520965660,
        "question_id": 49262889,
        "body_markdown": "Not sure what I am doing wrong here\r\n\r\n    getting_data | gunzip | jq -r &#39;.time_field | strptime(&quot;%Y-%m-%dT%H:%M:%S.%fZ&quot;)&#39;\r\n\r\nThe error comes back as such:\r\n\r\n    jq: error (at &lt;stdin&gt;:0): date &quot;2018-03-13T14:00:17.1614661Z&quot; does not \r\n    match format &quot;%Y-%m-%dT%H:%M:%S.%fZ&quot;\r\n\r\nThe desired output would be `2018-03-13 14:00:17`",
        "link": "https://stackoverflow.com/questions/49262889/strptime-with-timezones-and-jq",
        "title": "Strptime with timezones and jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1521032862,
                "last_edit_date": 1521032862,
                "creation_date": 1521031893,
                "answer_id": 49278253,
                "question_id": 49273348,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "needed to wrap it into array and to apply join\r\n\r\n \r\n\r\n    jq -rc &#39;.RoleDetailList\r\n    | map(select((.AssumeRolePolicyDocument.Statement | length &gt; 0) and \r\n        (.AssumeRolePolicyDocument.Statement[].Principal.Federated) or \r\n        (.AttachedManagedPolicies | length &gt;0) or \r\n        (.RolePolicyList | length &gt; 0)) )[]\r\n    | [.RoleName,\r\n       ([.RolePolicyList[].PolicyName,\r\n         ([.AttachedManagedPolicies[].PolicyName] | join(&quot;--&quot;))] \r\n        | join(&quot; &quot;)),\r\n       (.AssumeRolePolicyDocument.Statement[] | .Principal.Federated)] \r\n    | @csv&#39; output.json",
                "title": "Parsing JSON file using jq,convert it to CSV - combine 2 columns into one"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1521032862,
        "creation_date": 1521017841,
        "last_edit_date": 1521032177,
        "question_id": 49273348,
        "body_markdown": "JSON file:https://1drv.ms/u/s!AizscpxS0QM4hJl_VRQaWbm6D8T8_w\r\n\r\nPart of file:\r\n\r\n    &quot;RoleDetailList&quot;: [\r\n            {\r\n                &quot;AssumeRolePolicyDocument&quot;: {\r\n                    &quot;Version&quot;: &quot;2012-10-17&quot;, \r\n                    &quot;Statement&quot;: [\r\n                        {\r\n                            &quot;Action&quot;: &quot;sts:AssumeRoleWithSAML&quot;, \r\n                            &quot;Effect&quot;: &quot;Allow&quot;, \r\n                            &quot;Condition&quot;: {\r\n                                &quot;StringEquals&quot;: {\r\n                                    &quot;SAML:aud&quot;: &quot;https://signin.aws.amazon.com/saml&quot;\r\n                                }\r\n                            }, \r\n                            &quot;Principal&quot;: {\r\n                                &quot;Federated&quot;: &quot;arn:aws:iam::279052847476:saml-provider/CompanyADFS&quot;\r\n                            }\r\n                        }\r\n                    ]\r\n                }, \r\n                &quot;RoleId&quot;: &quot;AROAJANL3L2IZ6UISEGAU&quot;, \r\n                &quot;CreateDate&quot;: &quot;2016-08-20T13:51:07Z&quot;, \r\n                &quot;InstanceProfileList&quot;: [], \r\n                &quot;RoleName&quot;: &quot;ADFS-Administrators&quot;, \r\n                &quot;Path&quot;: &quot;/&quot;, \r\n                &quot;AttachedManagedPolicies&quot;: [], \r\n                &quot;RolePolicyList&quot;: [\r\n                    {\r\n                        &quot;PolicyName&quot;: &quot;Administrator-Access&quot;, \r\n                        &quot;PolicyDocument&quot;: {\r\n                            &quot;Version&quot;: &quot;2012-10-17&quot;, \r\n                            &quot;Statement&quot;: [\r\n                                {\r\n                                    &quot;Action&quot;: &quot;*&quot;, \r\n                                    &quot;Resource&quot;: &quot;*&quot;, \r\n                                    &quot;Effect&quot;: &quot;Allow&quot;, \r\n                                    &quot;Sid&quot;: &quot;Stmt1434192117145&quot;\r\n                                }\r\n                            ]\r\n                        }\r\n                    }\r\n                ], \r\n                &quot;Arn&quot;: &quot;arn:aws:iam::279052847476:role/ADFS-Administrators&quot;\r\n            },\r\n\r\n\r\nIn other sections `&quot;AttachedManagedPolicies&quot;: [],` is not empty it has following structure:\r\n\r\n    &quot;AttachedManagedPolicies&quot;: [\r\n                    {\r\n                        &quot;PolicyName&quot;: &quot;pol-amtest-ro&quot;, \r\n                        &quot;PolicyArn&quot;: &quot;arn:aws:iam::279052847476:policy/pol-amtest-ro&quot;\r\n                    }\r\n                ]\r\n\r\n\r\n\r\n I got all needed columns, just need to combine 2nd and 3rd into single one:\r\n  \r\n    jq -rc &#39;.RoleDetailList\r\n    | map(select((.AssumeRolePolicyDocument.Statement | length &gt; 0) and \r\n          (.AssumeRolePolicyDocument.Statement[].Principal.Federated) or \r\n          (.AttachedManagedPolicies | length &gt;0) or\r\n          (.RolePolicyList | length &gt; 0)) )[]  \r\n    | [.RoleName,\r\n       .RolePolicyList[].PolicyName,\r\n       ([.AttachedManagedPolicies[].PolicyName] | join(&quot;::&quot;)),\r\n       (.AssumeRolePolicyDocument.Statement[] | .Principal.Federated)]\r\n    | @csv&#39; output.json\r\n\r\nOutput:\r\n\r\n    &quot;ADFS-Administrators&quot;,&quot;Administrator-Access&quot;,&quot;&quot;,&quot;arn:aws:iam::279052847476:saml-provider/CompanyDFS&quot;\r\n\r\nHow to get rid of `&quot;&quot;,&quot;` (get it only in first line) ?\r\n\r\n\r\nTried `(.RolePolicyList[].PolicyName + &quot; &quot; + .AttachedManagedPolicies[].PolicyName)`\r\n\r\nbut then getting `&quot;ADFS-Administrators&quot;,&quot;arn:aws:iam::279052847476:saml-provider/CompanyADFS&quot;`\r\n\r\nLost values of 2 and 3rd column entirely\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/49273348/parsing-json-file-using-jq-convert-it-to-csv-combine-2-columns-into-one",
        "title": "Parsing JSON file using jq,convert it to CSV - combine 2 columns into one"
    },
    {
        "tags": [
            "json",
            "hashtable",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1521052701,
                "creation_date": 1521052701,
                "answer_id": 49285419,
                "question_id": 49284942,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Collect the objects in an array and reduce it with `add`:\r\n\r\n    $ jq &#39;[.[] | {(.name): .id}] | add&#39; tmp.json\r\n    {\r\n      &quot;object1name&quot;: 1,\r\n      &quot;object2name&quot;: 24\r\n    }\r\n\r\nYou can write the filter a little more tersely as `map({(.name): .id}) | add`.",
                "title": "jq: build lookup table"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1521063082,
                "last_edit_date": 1521063082,
                "creation_date": 1521052712,
                "answer_id": 49285420,
                "question_id": 49284942,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; Why doesn&#39;t my code [work] though?\r\n\r\nYou were close!  Although @chepner&#39;s answers are the most straightforward, an answer along the lines you seem to have been thinking is certainly possible:\r\n\r\n\r\n    [ {(.[] | .name): .id}] | add\r\n\r\n",
                "title": "jq: build lookup table"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1521063082,
        "creation_date": 1521051036,
        "question_id": 49284942,
        "body_markdown": "I&#39;m trying to build a lookup table in jq.\r\n\r\nInput:\r\n\r\n      {\r\n        &quot;Object1&quot;: {\r\n            &quot;id&quot;: 1,\r\n            &quot;name&quot;: &quot;object1name&quot;\r\n        },\r\n        &quot;Object2&quot;: {\r\n            &quot;id&quot;: 24,\r\n            &quot;name&quot;: &quot;object2name&quot;\r\n        }\r\n      }  \r\n\r\nExpected output:\r\n\r\n    {\r\n        &quot;object1name&quot;:1,\r\n        &quot;object2name&quot;:2 \r\n    }\r\n\r\nI tried the following jq code but it gives me an error:\r\n\r\n    {.[] | ((.name):.id)}\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/49284942/jq-build-lookup-table",
        "title": "jq: build lookup table"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "children"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1521075188,
                "creation_date": 1521075188,
                "answer_id": 49289914,
                "question_id": 49289408,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One way:\r\n\r\n    to_entries[] | [.] | from_entries\r\n\r\nMore prosaically:\r\n\r\n    keys_unsorted[] as $k | {($k): .[$k]}",
                "title": "Get child elements with their keys (jq)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1521094200,
        "creation_date": 1521071492,
        "last_edit_date": 1521094200,
        "question_id": 49289408,
        "body_markdown": "Using `jq`, I would like to get all the children of the root element and include their keys.\r\n\r\ne.g. from this document:\r\n\r\n    {&quot;foo&quot;: [1, 2, 3], &quot;bar&quot;: [4, 5, 6]}\r\n\r\nI would like to get:\r\n\r\n    {&quot;foo&quot;: [1, 2, 3]}\r\n    {&quot;bar&quot;: [4, 5, 6]}\r\n\r\nUsing variations on array indexing, I lose the keys:\r\n\r\n    echo &#39;{&quot;foo&quot;: [1, 2, 3], &quot;bar&quot;: [4, 5, 6]}&#39; | jq -c .[]\r\n    [1,2,3]\r\n    [4,5,6]\r\n\r\nHow can I get the desired result?",
        "link": "https://stackoverflow.com/questions/49289408/get-child-elements-with-their-keys-jq",
        "title": "Get child elements with their keys (jq)"
    },
    {
        "tags": [
            "json",
            "jq",
            "safe-browsing"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1521120331,
                "creation_date": 1521120331,
                "answer_id": 49300654,
                "question_id": 49299086,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; .matches.threatType\r\n\r\n`.matches` is an array, so you&#39;d have to use `[]` to expand it, e.g.:\r\n\r\n    .matches[].threatType\r\n\r\n&gt; .threatType\r\n\r\nThis attempt could be salvaged using `..`, e.g.\r\n\r\n    .. | .threatType? // empty\r\n\r\n&gt; .[] | .threatType\r\n\r\nNo comment :-)\r\n\r\n&gt; .[] | {type: .threatType}\r\n\r\nYou probably meant:\r\n\r\n    .matches[] | {type: .threatType}\r\n\r\n## p.s.\r\nYou might want to use `debug` to help debug/understand what&#39;s going on.\r\n\r\nAlso, in future, please don&#39;t forget to describe or show the expected output.",
                "title": "jq - can&#39;t extract key values from google safebrowsing json response"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1521120331,
        "creation_date": 1521115633,
        "question_id": 49299086,
        "body_markdown": "So I&#39;ve read the `jq` tutorial and played with the `github` `json` responses from  there and extracted some values of some other keys so &lt;b&gt;I think I understand how the syntax works&lt;/b&gt;. Unfortunately nothing works when attempting to use it on a Google `safe-browsing` `json` response. Here is the full response stored in a variable (did the same for the github examples from `jq` tutorial):\r\n\r\n\r\n    echo &quot;$safeb&quot;\r\n    {\r\n      &quot;matches&quot;: [\r\n    {\r\n      &quot;threatType&quot;: &quot;MALWARE&quot;,\r\n      &quot;platformType&quot;: &quot;ALL_PLATFORMS&quot;,\r\n      &quot;threat&quot;: {\r\n        &quot;url&quot;: &quot;http://www.wittyvideos.com&quot;\r\n      },\r\n      &quot;cacheDuration&quot;: &quot;300s&quot;,\r\n      &quot;threatEntryType&quot;: &quot;URL&quot;\r\n      }\r\n     ]\r\n    }\r\n\r\n... and this is what I tried:\r\n\r\n    echo &quot;$safeb&quot; | jq &#39;.matches.threatType&#39;\r\n    jq: error (at &lt;stdin&gt;:13): Cannot index array with string &quot;threatType&quot;\r\n&lt;space&gt;\r\n\r\n    echo &quot;$safeb&quot; | jq &#39;.threatType&#39;\r\n    null\r\n&lt;space&gt;\r\n\r\n    echo &quot;$safeb&quot; | jq &#39;.[] | .threatType&#39;\r\n    jq: error (at &lt;stdin&gt;:13): Cannot index array with string &quot;threatType&quot;\r\n&lt;space&gt;\r\n\r\n    echo &quot;$safeb&quot; | jq &#39;.[] | {type: .threatType}&#39;\r\n    jq: error (at &lt;stdin&gt;:13): Cannot index array with string &quot;threatType&quot;\r\n\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/49299086/jq-cant-extract-key-values-from-google-safebrowsing-json-response",
        "title": "jq - can&#39;t extract key values from google safebrowsing json response"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1521119758,
                "creation_date": 1521119758,
                "answer_id": 49300472,
                "question_id": 49300056,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": ".results is an array so you&#39;ll have to expand it too. This can be done either by:\r\n\r\n     .results[] | .indicators[] | [.indicator, .type] | @csv\r\n\r\nor more compactly:\r\n\r\n     .results[].indicators[] | [.indicator, .type] | @csv\r\n\r\nYou&#39;ll also have to direct the output to the designated file, e.g.: \r\n\r\n      jq -r -f program.jq &lt; AV.json &gt; AV.csv\r\n\r\n### Output\r\n\r\n    &quot;CVE-2018-0802&quot;,&quot;CVE&quot;\r\n    &quot;fb9c9cbf6925de8c7b6ce8e7a8d5290e628be0b82a58f3e968426c0f734f38f6&quot;,&quot;FileHash-SHA256&quot;",
                "title": "Use jq to Convert json File to csv"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1521119758,
        "creation_date": 1521118573,
        "question_id": 49300056,
        "body_markdown": "I am using curl to pull Alien Vault OTX pulses from their API, the initial output I receive is in json format and I need to convert this json into csv as so it can be read by some other software. I aim to use jq as many others have recommended it.\r\n\r\n    {   &quot;count&quot;: 1210,   &quot;next&quot;: &quot;https://otx.alienvault.com/api/v1/pulses/subscribed?page=2&quot;,   &quot;results&quot;: [\r\n        {\r\n          &quot;industries&quot;: [],\r\n          &quot;tlp&quot;: &quot;white&quot;,\r\n          &quot;description&quot;: &quot;Tropic Trooper (also known as KeyBoy) levels its campaigns against Taiwanese, Philippine, and Hong Kong targets, focusing on their government, healthcare, transportation, and high-tech industries. Its operators are believed to be very organized and develop their own cyberespionage tools that they fine-tuned in their recent campaigns. Many of the tools they use now feature new behaviors, including a change in the way they maintain a foothold in the targeted network.&quot;,\r\n          &quot;created&quot;: &quot;2018-03-14T17:24:48.014000&quot;,\r\n          &quot;tags&quot;: [\r\n            &quot;china&quot;,\r\n            &quot;keyboy&quot;,\r\n            &quot;tropic trooper&quot;\r\n          ],\r\n          &quot;modified&quot;: &quot;2018-03-14T17:24:48.014000&quot;,\r\n          &quot;author_name&quot;: &quot;AlienVault&quot;,\r\n          &quot;public&quot;: 1,\r\n          &quot;extract_source&quot;: [],\r\n          &quot;references&quot;: [\r\n            &quot;https://blog.trendmicro.com/trendlabs-security-intelligence/tropic-trooper-new-strategy/&quot;\r\n          ],\r\n          &quot;targeted_countries&quot;: [],\r\n          &quot;indicators&quot;: [\r\n            {\r\n              &quot;indicator&quot;: &quot;CVE-2018-0802&quot;,\r\n              &quot;description&quot;: &quot;&quot;,\r\n              &quot;created&quot;: &quot;2018-03-14T17:25:03&quot;,\r\n              &quot;title&quot;: &quot;&quot;,\r\n              &quot;content&quot;: &quot;&quot;,\r\n              &quot;type&quot;: &quot;CVE&quot;,\r\n              &quot;id&quot;: 406248965\r\n            },\r\n            {\r\n              &quot;indicator&quot;: &quot;fb9c9cbf6925de8c7b6ce8e7a8d5290e628be0b82a58f3e968426c0f734f38f6&quot;,\r\n              &quot;description&quot;: &quot;&quot;,\r\n              &quot;created&quot;: &quot;2018-03-14T17:25:03&quot;,\r\n              &quot;title&quot;: &quot;&quot;,\r\n              &quot;content&quot;: &quot;&quot;,\r\n              &quot;type&quot;: &quot;FileHash-SHA256&quot;,\r\n              &quot;id&quot;: 438581959\r\n            }\r\n          ],\r\n          &quot;more_indicators&quot;: false,\r\n          &quot;revision&quot;: 1,\r\n          &quot;adversary&quot;: &quot;Tropic Trooper&quot;,\r\n          &quot;id&quot;: &quot;5aa95ae02781860367e354e4&quot;,\r\n          &quot;name&quot;: &quot;Tropic Troopers New Strategy&quot;\r\n        }\r\n\r\nI am looking to use jq to extract certain fields and convert to csv. My expected output would look something like:\r\n\r\n    &quot;CVE-2018-0802&quot;,&quot;CVE&quot;\r\n    &quot;tibetnews.today&quot;,&quot;domain&quot;\r\n    &quot;02281e26e89b61d84e2df66a0eeb729c5babd94607b1422505cd388843dd5456&quot;,&quot;FileHash-SHA256&quot;\r\n\r\nSo far I have tried:\r\n\r\n    &lt;AV.json jq -r &#39;.results.indicators[] | [.indicator, .type] | @csv&#39; AV.csv\r\n\r\nAny help is greatly appreciated.\r\n\r\nCheers,\r\n\r\nGeorge\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49300056/use-jq-to-convert-json-file-to-csv",
        "title": "Use jq to Convert json File to csv"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521134193,
                "post_id": 49302617,
                "comment_id": 85613193,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 88,
                "is_accepted": false,
                "score": 88,
                "last_activity_date": 1521127342,
                "last_edit_date": 1521127342,
                "creation_date": 1521125768,
                "answer_id": 49302719,
                "question_id": 49302617,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Yes; wrap the filter in an array :)\r\n\r\n\r\n    $ jq &#39;[.[] | select(.id == &quot;second&quot;)]&#39; tmp.json\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;second&quot;,\r\n        &quot;val&quot;: 2\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;second&quot;,\r\n        &quot;val&quot;: 3\r\n      }\r\n    ]\r\n\r\nOr, use `map/1`, which is predefined as `[.[] | ...]`.\r\n\r\n    $ jq &#39;map(select(.id == &quot;second&quot;))&#39; tmp.json\r\n    [same result]\r\n\r\n---\r\n\r\nTo wrap the results in a `bash` array, use the `-c` option to output each result on a single line, and read the result with `readarray`.\r\n\r\n    $ readarray -t arr &lt; &lt;(jq -c &#39;.[] | select(.id == &quot;second&quot;)&#39; tmp.json)\r\n    $ for r in &quot;${arr[@]}&quot;; do echo &quot;Result: $r&quot;; done\r\n    Result: {&quot;id&quot;:&quot;second&quot;,&quot;val&quot;:2}\r\n    Result: {&quot;id&quot;:&quot;second&quot;,&quot;val&quot;:3}",
                "title": "Output the results of select operation in an array - jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 46,
        "last_activity_date": 1521127342,
        "creation_date": 1521125481,
        "question_id": 49302617,
        "body_markdown": "I have the following input: \r\n\r\n    [\r\n      {&quot;id&quot;: &quot;first&quot;, &quot;val&quot;: 1}, \r\n      {&quot;id&quot;: &quot;second&quot;, &quot;val&quot;: 2}, \r\n      {&quot;id&quot;: &quot;second&quot;, &quot;val&quot;: 3}\r\n    ]\r\n\r\nUsing the jq filter : .[] | select(.id == &quot;second&quot;)\r\n\r\nI get following as output :\r\n\r\n     {\r\n      &quot;id&quot;: &quot;second&quot;,\r\n      &quot;val&quot;: 2\r\n     }\r\n     {\r\n      &quot;id&quot;: &quot;second&quot;,\r\n      &quot;val&quot;: 3\r\n     }\r\n\r\n\r\nI want to get the result in the form of an array. Is it possible to get the multiple result values of select operation in an array?",
        "link": "https://stackoverflow.com/questions/49302617/output-the-results-of-select-operation-in-an-array-jq",
        "title": "Output the results of select operation in an array - jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1521169436,
                "creation_date": 1521169436,
                "answer_id": 49312521,
                "question_id": 49312431,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In order to loop through the items in the JSON array using bash, you could write:\r\n\r\n    echo &quot;${conf}&quot; | jq -cr &quot;.[]&quot; |\r\n    while read -r configy\r\n    do\r\n      echo configy=&quot;$configy&quot;\r\n    done\r\n\r\nThis yields:\r\n\r\n    configy={&quot;fraudThreshold&quot;:4,&quot;fraudTTLSec&quot;:60}\r\n    configy={&quot;fraudThreshold&quot;:44,&quot;fraudTTLSec&quot;:60}\r\n\r\nHowever there is almost surely a better way to achieve your ultimate goal.",
                "title": "Looping through json array not working - jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1521250626,
                "last_edit_date": 1521250626,
                "creation_date": 1521170250,
                "answer_id": 49312629,
                "question_id": 49312431,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    echo &quot;${conf}&quot; | jq -car &#39;.[] | &quot;configy=&quot; + tojson&#39;\r\n\r\nproduces:\r\n\r\n    configy={&quot;fraudThreshold&quot;:4,&quot;fraudTTLSec&quot;:60}\r\n    configy={&quot;fraudThreshold&quot;:44,&quot;fraudTTLSec&quot;:60}",
                "title": "Looping through json array not working - jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1521188448,
                "creation_date": 1521188448,
                "answer_id": 49315996,
                "question_id": 49312431,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt;     for configy in $(echo &quot;${conf}&quot; | jq -r &quot;.[]&quot;); do \r\nIt is splitting the string using spaces and giving the results one by one. Why is bash showing this weird behavior?\r\n\r\nThis behavior is not weird at all. See the [**Bash Reference Manual: Word Splitting**][1]:\r\n  [1]: https://www.gnu.org/software/bash/manual/html_node/Word-Splitting.html\r\n\r\n&gt; The shell scans the results of parameter expansion, command\r\n&gt; substitution, and arithmetic expansion that did not occur within\r\n&gt; double quotes for word splitting.\r\n\r\n---\r\n&gt; Is there any solution to this?\r\n\r\nM&#226;tt Fr&#235;&#235;man and peak presented working solutions; you can slightly optimize them by replacing `echo &quot;${conf}&quot; |` with `&lt;&lt;&lt;&quot;$conf&quot; `.",
                "title": "Looping through json array not working - jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1521250626,
        "creation_date": 1521168705,
        "last_edit_date": 1521169062,
        "question_id": 49312431,
        "body_markdown": "I have a JSON array &lt;i&gt;**conf=**&lt;/i&gt; \r\n\r\n     [ { &quot;fraudThreshold&quot;: 4, &quot;fraudTTLSec&quot;: 60 }, { &quot;fraudThreshold&quot;: 44, &quot;fraudTTLSec&quot;: 60 } ]\r\n\r\nI want to loop through its items. So I have done the following: \r\n\r\n    for configy in $(echo &quot;${conf}&quot; | jq -r &quot;.[]&quot;); do \r\n        echo configy=$configy \r\n    done\r\n\r\nThe results are:- \r\n\r\n    configy={\r\n    configy=&quot;fraudThreshold&quot;:\r\n    configy=4,\r\n    configy=&quot;fraudTTLSec&quot;:\r\n&lt;i&gt;and so on.&lt;/i&gt;\r\n\r\n\r\nIt is splitting the string using spaces and giving the results one by one.\r\nWhy is bash showing this weird behavior? Is there any solution to this?\r\n \r\nAlso, it is giving proper values when I do : \r\n\r\n    configy=$(echo $conf | jq .[-1])\r\n    echo configy=$configy \r\n\r\nResult:\r\n \r\n     configy={ &quot;fraudThreshold&quot;: 44, &quot;fraudTTLSec&quot;: 60 }\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49312431/looping-through-json-array-not-working-jq",
        "title": "Looping through json array not working - jq"
    },
    {
        "tags": [
            "bash",
            "jq",
            "nul"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2058249,
                    "reputation": 426,
                    "user_id": 2243682,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/FqmTf.png?s=256",
                    "display_name": "GGets",
                    "link": "https://stackoverflow.com/users/2243682/ggets"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521208204,
                "post_id": 49321015,
                "comment_id": 85645824,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521208286,
                "post_id": 49321015,
                "comment_id": 85645893,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521208410,
                "post_id": 49321015,
                "comment_id": 85645987,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1521232603,
                "last_edit_date": 1521232603,
                "creation_date": 1521208240,
                "answer_id": 49322365,
                "question_id": 49321015,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use `readarray`, which gained a `-d` analogous to the same option on `read` in `bash` 4.4:\r\n\r\n    $ readarray -d $&#39;\\0&#39; -t a &lt; &lt;(jq -ncj &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;][]+&quot;\\u0000&quot;&#39;)\r\n    $ declare -p a\r\n    declare -a a=([0]=&quot;a&quot; [1]=&quot;b&quot; [2]=&quot;c&quot;)\r\n\r\n`-d &#39;&#39;` works as well; since shell strings are null terminated, `&#39;&#39;` is, technically, the string containing the null character.\r\n\r\n---\r\n\r\nWithout `readarray -d` support, you can use a `while` loop with `read`, which should work in any version of `bash`:\r\n\r\n    \r\n    a=()\r\n    while read -d &#39;&#39; -r item; do\r\n        a+=(&quot;$item&quot;)\r\n    done &lt; &lt;( jq -ncj &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;][]+&quot;\\u0000&quot;&#39; )\r\n\r\nThis is the best you can do unless you know something about the array elements that would let you pick an alternate delimiter that isn&#39;t part of any of the elements.",
                "title": "Storing JQ NULL-delimited output in bash array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1521212044,
                "creation_date": 1521212044,
                "answer_id": 49323670,
                "question_id": 49321015,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since you are NOT using jq&#39;s `-r` option, the question arises as to whether the problem as posed in the title is perhaps an [&quot;XY&quot; problem][1].  If the goal is simply to assign JSON values to a bash array, consider:\r\n\r\n    $ readarray -t a &lt; &lt;(jq -nc &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;][]&#39;) ; printf &#39;%s\\n&#39; &quot;${a[@]}&quot;\r\n    &quot;a&quot;\r\n    &quot;b&quot;\r\n    &quot;c&quot;\r\n\r\nNotice that the bash array values are recognizably JSON values (in this case, JSON strings, complete with the double-quotation marks).\r\n\r\nEven more tellingly:\r\n\r\n    $ readarray -t a &lt; &lt;(jq -nc &#39;[&quot;a\\\\b&quot;,&quot;\\&quot;b\\&quot;&quot;,&quot;c&quot;][]&#39;) ; printf &#39;%s\\n&#39; &quot;${a[@]}&quot;\r\n    &quot;a\\\\b&quot;\r\n    &quot;\\&quot;b\\&quot;&quot;\r\n    &quot;c&quot;\r\n\r\nCompare the loss of &quot;JSONarity&quot; that happens when using readarray with NUL:\r\n\r\n    $ readarray -d &quot;&quot; a &lt; &lt;(jq -ncj &#39;[&quot;a\\\\b&quot;,&quot;\\&quot;b\\&quot;&quot;,&quot;c&quot;][]+&quot;\\u0000&quot;&#39;) ; printf &#39;%s\\n&#39; &quot;${a[@]}&quot;\r\n    a\\b\r\n    &quot;b&quot;\r\n    c\r\n\r\n  [1]: http://mywiki.wooledge.org/XyProblem\r\n\r\n",
                "title": "Storing JQ NULL-delimited output in bash array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1561375595,
                "last_edit_date": 1633608757,
                "creation_date": 1560977401,
                "answer_id": 56675644,
                "question_id": 49321015,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m assuming that you want to switch to using a null delimiter instead of _ in order to increase reliability of your scripts. However, the safest way to read json elements is not by using the null delimiter since that is allowed json text according to RFC7159 ([page 8][1]). E.g. if `[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]` were to look like `[&quot;a&quot;,&quot;b\\u0000&quot;,&quot;c&quot;]` and you were to append the null char to each of the strings and parse these with a null delimiter, the &quot;b&quot; element would go into two separate bash array slots.\r\n\r\nInstead, given that newlines are always escaped within json-strings when using e.g. `jq -c` I suggest relying on the part of the spec that says \r\n\r\n&gt; &quot;A string begins and ends with quotation marks.&quot;\r\n\r\nWith that in mind we can define:\r\n\r\n    jsonStripQuotes(){ local t0; while read -r t0; do t0=&quot;${t0%\\&quot;}&quot;; t0=&quot;${t0#\\&quot;}&quot;; printf &#39;%s\\n&#39; &quot;$t0&quot;; done &lt; &lt;(jq &#39;.&#39;);}\r\n    \r\nAnd then, e.g.\r\n\r\n    echo &#39;[&quot;a\\u0000 b\\n&quot;,&quot;b\\nnn&quot;,&quot;c d&quot;]&#39; | jq .[] | jsonStripQuotes\r\n\r\n..should safely print each json string on separate lines(expanded newline appended), with all newlines and null&#39;s within the strings escaped. After that I would do a read with IFS set to newline only:\r\n\r\n    while IFS=$&#39;\\n&#39; do read -r elem; Arr+=(&quot;$elem&quot;) ; done &lt; &lt;(echo &#39;[&quot;a\\u0000 b\\n&quot;,&quot;b\\nnn&quot;,&quot;c d&quot;]&#39; | jq .[] | stripJsonQuotes)\r\n\r\nAnd then if you want to print them with newlines etc. expanded:\r\n\r\n    printf &#39;%b&#39; &quot;${Arr[*]}&quot;\r\n\r\nI believe this is the most reliable way to parse json strings to a bash array.\r\n\r\n\r\n  [1]: https://www.rfc-editor.org/rfc/rfc7159#page-8",
                "title": "Storing JQ NULL-delimited output in bash array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1561375595,
        "creation_date": 1521203979,
        "last_edit_date": 1592644375,
        "question_id": 49321015,
        "body_markdown": "on bash 4.4.12 using jq 1.5 with this one-liner `IFS=_ read -r -a a &lt; &lt;(jq -ncj &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;][]+&quot;_&quot;&#39;) ; printf &#39;%s\\n&#39; &quot;${a[@]}&quot;` I get a properly delimited output\n&gt; a\n&gt;\n&gt; b\n&gt;\n&gt; c\n\nfor elements a, b and c respectively, BUT if I try the same thing with a null delimiter like so: `IFS= read -r -a a &lt; &lt;(jq -ncj &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;][]+&quot;\\u0000&quot;&#39;) ; printf &#39;%s\\n&#39; &quot;${a[@]}&quot;` then I would get only one array element containing\n&gt; abc\n\nWhy doesn&#39;t this work like expected?\n\nFurthermore, if you try `IFS= read -r -d &#39;&#39; -a a &lt; &lt;(jq -ncj &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;][]+&quot;\\u0000&quot;&#39;) ; printf &#39;%s\\n&#39; &quot;${a[@]}`, you will be surprised to get an array with only the first &quot;&lt;b&gt;a&lt;/b&gt;&quot; element:\n&gt; a\n\n\nMy goal is to find an approach without iterating over elements with any kind of a loop.\n\nEdit: ` **readarray -d** ` is not a solution since i need the piece of code to run in bash prior to version 4.4",
        "link": "https://stackoverflow.com/questions/49321015/storing-jq-null-delimited-output-in-bash-array",
        "title": "Storing JQ NULL-delimited output in bash array"
    },
    {
        "tags": [
            "json",
            "bash",
            "select",
            "jq",
            "bitbucket-api"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1521211060,
                "post_id": 49323261,
                "comment_id": 85647893,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521211957,
                "post_id": 49323261,
                "comment_id": 85648572,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521212057,
                "post_id": 49323261,
                "comment_id": 85648646,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 80868,
                    "reputation": 8817,
                    "user_id": 228371,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/3b903cad68504ad4cb4df51b8e8636b7?s=256&d=identicon&r=PG",
                    "display_name": "Freiheit",
                    "link": "https://stackoverflow.com/users/228371/freiheit"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521212165,
                "post_id": 49323261,
                "comment_id": 85648734,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521212404,
                "post_id": 49323261,
                "comment_id": 85648920,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521212467,
                "post_id": 49323261,
                "comment_id": 85648956,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 80868,
                    "reputation": 8817,
                    "user_id": 228371,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/3b903cad68504ad4cb4df51b8e8636b7?s=256&d=identicon&r=PG",
                    "display_name": "Freiheit",
                    "link": "https://stackoverflow.com/users/228371/freiheit"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521212605,
                "post_id": 49323261,
                "comment_id": 85649041,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1521212652,
                "post_id": 49323261,
                "comment_id": 85649082,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521212750,
                "post_id": 49323261,
                "comment_id": 85649158,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521215090,
                "post_id": 49323261,
                "comment_id": 85650676,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1521214627,
                "last_edit_date": 1521214627,
                "creation_date": 1521212621,
                "answer_id": 49323859,
                "question_id": 49323261,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As I understand it:\r\n\r\n- You want globally unique outputs\r\n- You want only items with `downloads==0`\r\n- You want only items whose name contains &quot;SNAPSHOT&quot;\r\n\r\nThe following will accomplish that:\r\n\r\n    jq -r &#39;\r\n    [.values[] | {(.name): .downloads}]\r\n    | add\r\n    | to_entries[]\r\n    | select(.value == 0)\r\n    | .key | select(contains(&quot;SNAPSHOT&quot;))&#39;\r\n\r\nRather than making `unique` an explicit step, this version generates a map from names to download counters (`add`ing the values together -- which means that in case of conflicts, the last one wins), and thereby both ensures that the outputs are unique.\r\n\r\n---\r\n\r\nGiven your test JSON, output is:\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    myproject_1.1-SNAPSHOT_thanks_for_the_reminder_charles_duffy_mc_3.5.0.zip\r\n\r\nApplied to the overall problem context, this strategy can be used to simplify the overall process:\r\n\r\n    jq -r &#39;[.values[] | {(.links.self.href): .downloads}] |  add | to_entries[] | select(.value == 0) | .key | select(contains(&quot;SNAPSHOT&quot;))&#39;\r\n\r\nIt simplifies the overall process by acting on the URL to the file rather than the name only. This simplifies the subsequent DELETE call. The `sort` and `tr` calls can also be removed.",
                "title": "How can I filter by a numeric field using jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1521221729,
                "last_edit_date": 1521221729,
                "creation_date": 1521214380,
                "answer_id": 49324446,
                "question_id": 49323261,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a solution which sums up the `.download` values per `.name` before making the selection based on the total number of downloads:\r\n\r\n    reduce (.values[] | select(.name | contains(&quot;SNAPSHOT&quot;))) as $v\r\n      ({}; .[$v.name] += $v.downloads)\r\n    | with_entries(select(.value == 0))\r\n    | keys_unsorted[]\r\n\r\nExample:\r\n\r\n    $ jq -r -f program.jq input.json\r\n    myproject_1.1-SNAPSHOT_thanks_for_the_reminder_charles_duffy_mc_3.5.0.zip\r\n\r\n## p.s.\r\n&gt; What is wrong with my select statement ...?\r\n\r\nThe problem that jumps out is the bit of the pipeline just before the &quot;select&quot; filter:\r\n \r\n    .values | {name: .[].name, downloads: .[].downloads} \r\n\r\nThe use of `.[]` in this manner results in the Cartesian product being formed -- that is, the above expression will emit n*n JSON sets, where n is the length of `.values`.  You evidently intended to write:\r\n\r\n    .values[] | {name: .name, downloads: .downloads} \r\n\r\nwhich can be abbreviated to:\r\n\r\n    .values[] | {name, downloads} \r\n",
                "title": "How can I filter by a numeric field using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1521231257,
        "creation_date": 1521210914,
        "last_edit_date": 1521231257,
        "question_id": 49323261,
        "body_markdown": "I am writing a script to query the Bitbucket API and delete SNAPSHOT artifacts that have never been downloaded. This script is failing because it gets ALL snapshot artifacts, the select for the number of downloads does not appear to be working.\r\n\r\nWhat is wrong with my `select` statement to filter objects by the number of downloads? \r\n\r\nOf course the more direct solution here would be if I could just query the Bitbucket API with a filter. To the best of my knowledge the API does not support filtering by downloads.\r\n\r\nMy script is:\r\n\r\n    #!/usr/bin/env bash\r\n    curl -X GET --user &quot;me:mykey&quot; &quot;https://api.bitbucket.org/2.0/repositories/myemployer/myproject/downloads?pagelen=100&quot; &gt; downloads.json\r\n    \r\n    # get all values | reduce the set to just be name and downloads | select entries where downloads is zero | select entries where name contains SNAPSHOT | just get the name\r\n    #TODO i screwed up the selection somewhere its returning files that contain SNAPSHOT regardless of number of downloads\r\n    jq &#39;.values | {name: .[].name, downloads: .[].downloads} | select(.downloads==0) | select(.name | contains(&quot;SNAPSHOT&quot;)) | .name&#39; downloads.json &gt; snapshots_without_any_downloads.js\r\n    #unique sort, not sure why jq gives me multiple values\r\n    sort -u snapshots_without_any_downloads.js | tr -d &#39;&quot;&#39; &gt; unique_snapshots_without_downloads.js\r\n    \r\n    cat unique_snapshots_without_downloads.js | xargs -t -I % curl -Ss -X DELETE --user &quot;me:mykey&quot; &quot;https://api.bitbucket.org/2.0/repositories/myemployer/myproject/downloads/%&quot; &gt; deleted_files.txt\r\n\r\nA deidentified sample of the raw input from the API is:\r\n\r\n    {\r\n      &quot;pagelen&quot;: 10,\r\n      &quot;size&quot;: 40,\r\n      &quot;values&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;myproject_1.1-SNAPSHOT_0210f77_mc_3.5.0.zip&quot;,\r\n          &quot;links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;https://api.bitbucket.org/2.0/repositories/myemployer/myproject/downloads/myproject_1.1-SNAPSHOT_0210f77_mc_3.5.0.zip&quot;\r\n            }\r\n          },\r\n          &quot;downloads&quot;: 2,\r\n          &quot;created_on&quot;: &quot;2018-03-15T17:50:00.157310+00:00&quot;,\r\n          &quot;user&quot;: {\r\n            &quot;username&quot;: &quot;me&quot;,\r\n            &quot;display_name&quot;: &quot;me&quot;,\r\n            &quot;type&quot;: &quot;user&quot;,\r\n            &quot;uuid&quot;: &quot;{3051ec5f-cc92-4bc3-b291-38189a490a89}&quot;,\r\n            &quot;links&quot;: {\r\n              &quot;self&quot;: {\r\n                &quot;href&quot;: &quot;https://api.bitbucket.org/2.0/users/me&quot;\r\n              },\r\n              &quot;html&quot;: {\r\n                &quot;href&quot;: &quot;https://bitbucket.org/me/&quot;\r\n              },\r\n              &quot;avatar&quot;: {\r\n                &quot;href&quot;: &quot;https://bitbucket.org/account/me/avatar/32/&quot;\r\n              }\r\n            }\r\n          },\r\n          &quot;type&quot;: &quot;download&quot;,\r\n          &quot;size&quot;: 430894\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;myproject_1.1-SNAPSHOT_thanks_for_the_reminder_charles_duffy_mc_3.5.0.zip&quot;,\r\n          &quot;links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;https://api.bitbucket.org/2.0/repositories/myemployer/myproject/downloads/myproject_1.1-SNAPSHOT_0210f77_mc_3.5.0.zip&quot;\r\n            }\r\n          },\r\n          &quot;downloads&quot;: 0,\r\n          &quot;created_on&quot;: &quot;2018-03-15T17:50:00.157310+00:00&quot;,\r\n          &quot;user&quot;: {\r\n            &quot;username&quot;: &quot;me&quot;,\r\n            &quot;display_name&quot;: &quot;me&quot;,\r\n            &quot;type&quot;: &quot;user&quot;,\r\n            &quot;uuid&quot;: &quot;{3051ec5f-cc92-4bc3-b291-38189a490a89}&quot;,\r\n            &quot;links&quot;: {\r\n              &quot;self&quot;: {\r\n                &quot;href&quot;: &quot;https://api.bitbucket.org/2.0/users/me&quot;\r\n              },\r\n              &quot;html&quot;: {\r\n                &quot;href&quot;: &quot;https://bitbucket.org/me/&quot;\r\n              },\r\n              &quot;avatar&quot;: {\r\n                &quot;href&quot;: &quot;https://bitbucket.org/account/me/avatar/32/&quot;\r\n              }\r\n            }\r\n          },\r\n          &quot;type&quot;: &quot;download&quot;,\r\n          &quot;size&quot;: 430894\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;myproject_1.0_mc_3.5.1.zip&quot;,\r\n          &quot;links&quot;: {\r\n            &quot;self&quot;: {\r\n              &quot;href&quot;: &quot;https://api.bitbucket.org/2.0/repositories/myemployer/myproject/downloads/myproject_1.1-SNAPSHOT_0210f77_mc_3.5.1.zip&quot;\r\n            }\r\n          },\r\n          &quot;downloads&quot;: 5,\r\n          &quot;created_on&quot;: &quot;2018-03-15T17:49:14.885544+00:00&quot;,\r\n          &quot;user&quot;: {\r\n            &quot;username&quot;: &quot;me&quot;,\r\n            &quot;display_name&quot;: &quot;me&quot;,\r\n            &quot;type&quot;: &quot;user&quot;,\r\n            &quot;uuid&quot;: &quot;{3051ec5f-cc92-4bc3-b291-38189a490a89}&quot;,\r\n            &quot;links&quot;: {\r\n              &quot;self&quot;: {\r\n                &quot;href&quot;: &quot;https://api.bitbucket.org/2.0/users/me&quot;\r\n              },\r\n              &quot;html&quot;: {\r\n                &quot;href&quot;: &quot;https://bitbucket.org/me/&quot;\r\n              },\r\n              &quot;avatar&quot;: {\r\n                &quot;href&quot;: &quot;https://bitbucket.org/account/me/avatar/32/&quot;\r\n              }\r\n            }\r\n          },\r\n          &quot;type&quot;: &quot;download&quot;,\r\n          &quot;size&quot;: 430934\r\n        }\r\n      ],\r\n      &quot;page&quot;: 1,\r\n      &quot;next&quot;: &quot;https://api.bitbucket.org/2.0/repositories/myemployer/myproject/downloads?pagelen=10&amp;page=2&quot;\r\n    }\r\n\r\nThe output I want from this snippet is `myproject_1.1-SNAPSHOT_thanks_for_the_reminder_charles_duffy_mc_3.5.0.zip` - that artifact is a SNAPSHOT and has zero downloads.\r\n\r\nI have used this intermediate step to do some debugging:\r\n\r\n    jq &#39;.values | {name: .[].name, downloads: .[].downloads} | select(.downloads&gt;0) | select(.name | contains(&quot;SNAPSHOT&quot;)) | unique&#39; downloads.json &gt; snapshots_with_downloads.js\r\n    jq &#39;.values | {name: .[].name, downloads: .[].downloads} | select(.downloads==0) | select(.name | contains(&quot;SNAPSHOT&quot;)) | .name&#39; downloads.json &gt; snapshots_without_any_downloads.js\r\n    #this returns the same values for each list!\r\n    diff unique_snapshots_with_downloads.js unique_snapshots_without_downloads.js\r\n\r\nThis adjustment gives a cleaner and unique structure, it suggests that theres some sort of splitting or streaming aspect of `jq` that I do not fully understand:\r\n\r\n    #this returns a &quot;unique&quot; array like I expect, adding select to this still does not produce the desired outcome \r\n    jq &#39;.values | [{name: .[].name, downloads: .[].downloads}] | unique&#39; downloads.json\r\n\r\nThe data after this step looks like this. It just removed the cruft I didn&#39;t need from the raw API response:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;myproject_1.0_2400a51_mc_3.4.0.zip&quot;,\r\n        &quot;downloads&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;myproject_1.0_2400a51_mc_3.4.1.zip&quot;,\r\n        &quot;downloads&quot;: 2\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;myproject_1.1-SNAPSHOT_391f4d5_mc_3.5.0.zip&quot;,\r\n        &quot;downloads&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;myproject_1.1-SNAPSHOT_391f4d5_mc_3.5.1.zip&quot;,\r\n        &quot;downloads&quot;: 2\r\n      }\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49323261/how-can-i-filter-by-a-numeric-field-using-jq",
        "title": "How can I filter by a numeric field using jq?"
    },
    {
        "tags": [
            "json",
            "stream",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2435926,
                    "reputation": 23422,
                    "user_id": 2125837,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/760b6ec2b6e1cba2b0218178425f4cde?s=256&d=identicon&r=PG",
                    "display_name": "xpt",
                    "link": "https://stackoverflow.com/users/2125837/xpt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522527441,
                "post_id": 49342129,
                "comment_id": 86191618,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 19,
                "is_accepted": false,
                "score": 19,
                "last_activity_date": 1521323171,
                "creation_date": 1521323171,
                "answer_id": 49342217,
                "question_id": 49342129,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Found it, on the same page, \r\n\r\nhttps://stedolan.github.io/jq/tutorial/#result6\r\n\r\n&gt; If you want to get the output as a single array, you can tell jq to “collect” all of the answers by wrapping the filter in square brackets:\r\n\r\n    jq &#39;[.[] | {message: .commit.message, name: .commit.committer.name}]&#39;",
                "title": "jq to output results as JSON"
            },
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1559316440,
                "last_edit_date": 1559316440,
                "creation_date": 1521325448,
                "answer_id": 49342492,
                "question_id": 49342129,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Technically speaking, unless otherwise instructed (notably with the `-r` command-line option), jq produces a *stream* of JSON entities.\r\n\r\nOne way to convert an input stream of JSON entities into a JSON array containing them is to use the `-s` command-line option.\r\n\r\n## Response to UPDATE\r\n\r\nTo produce a JSON object of the form: \r\n\r\n    { &quot;Commits&quot;: [ {...}, {...}, {...} ] }\r\n\r\nyou could write something like:\r\n\r\n    jq &#39;{Commits: [.[] | {message: .commit.message, name: .commit.committer.name}]}&#39;\r\n\r\n\r\n(jq understands the &#39;{Commits: _}&#39; shorthand.)",
                "title": "jq to output results as JSON"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1707958899,
                "creation_date": 1707958899,
                "answer_id": 77997988,
                "question_id": 49342129,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To answer your direct question, if you are doing something like starting with json, then your jq produces a json stream , \r\n\r\n```sh\r\necho &#39;[{&quot;commit&quot;: {&quot;message&quot;: &quot;hi&quot;}},{&quot;commit&quot;: {&quot;message&quot;: &quot;okay&quot;}},{&quot;commit&quot;: {&quot;message&quot;: &quot;bye&quot;}}]&#39; \\\r\n    | jq &#39;.[] | {message: .commit.message}&#39;\r\n```\r\n```sh\r\n{\r\n  &quot;message&quot;: &quot;hi&quot;\r\n}\r\n{\r\n  &quot;message&quot;: &quot;okay&quot;\r\n}\r\n{\r\n  &quot;message&quot;: &quot;bye&quot;\r\n}\r\n```\r\n\r\n\r\n## Then you just `--slurp` it , like \r\n\r\n```sh\r\necho &#39;[{&quot;commit&quot;: {&quot;message&quot;: &quot;hi&quot;}},{&quot;commit&quot;: {&quot;message&quot;: &quot;okay&quot;}},{&quot;commit&quot;: {&quot;message&quot;: &quot;bye&quot;}}]&#39; \\\r\n    | jq &#39;.[] | {message: .commit.message}&#39;\\\r\n    | jq --slurp\r\n```\r\n\r\n```sh\r\n[\r\n  {\r\n    &quot;message&quot;: &quot;hi&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;okay&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;bye&quot;\r\n  }\r\n]\r\n```\r\n\r\n( NOTE @peak hinted at this , `-s` is short for `--slurp` )",
                "title": "jq to output results as JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 15,
        "last_activity_date": 1707958899,
        "creation_date": 1521322338,
        "last_edit_date": 1559311144,
        "question_id": 49342129,
        "body_markdown": "`jq` is suppose to \r\n\r\n&gt; process/filter JSON inputs and producing the filter&#39;s results ***as JSON***\r\n\r\nHowever, I found that after the `jq` process/filter, output result is no longer in JSON format any more. \r\n\r\nE.g., https://stedolan.github.io/jq/tutorial/#result5, i.e., \r\n\r\n    $ curl -s &#39;https://api.github.com/repos/stedolan/jq/commits?per_page=5&#39; | jq &#39;.[] | {message: .commit.message, name: .commit.committer.name}&#39;\r\n    {\r\n      &quot;message&quot;: &quot;Merge pull request #162 from stedolan/utf8-fixes\\n\\nUtf8 fixes. Closes #161&quot;,\r\n      &quot;name&quot;: &quot;Stephen Dolan&quot;\r\n    }\r\n    {\r\n      &quot;message&quot;: &quot;Reject all overlong UTF8 sequences.&quot;,\r\n      &quot;name&quot;: &quot;Stephen Dolan&quot;\r\n    }\r\n    . . . \r\n\r\nIs there any workaround? \r\n\r\n**UPDATE:**\r\n\r\nHow to wrap the whole return into a json structure of:\r\n\r\n    { &quot;Commits&quot;: [ {...}, {...}, {...} ] }\r\n\r\nI&#39;ve tried:\r\n\r\n    jq &#39;.[] | Commits: [{message: .commit.message, name: .commit.committer.name}]&#39;\r\n    jq &#39;Commits: [.[] | {message: .commit.message, name: .commit.committer.name}]&#39;\r\n\r\nbut neither works. ",
        "link": "https://stackoverflow.com/questions/49342129/jq-to-output-results-as-json",
        "title": "jq to output results as JSON"
    },
    {
        "tags": [
            "datetime",
            "awk",
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1521346135,
                "last_edit_date": 1521346135,
                "creation_date": 1521342825,
                "answer_id": 49344145,
                "question_id": 49343797,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is an all-jq solution that assumes the &quot;Z&quot; (UTC+0) timezone. \r\n\r\nIn brief, simply replace `.T` by:\r\n\r\n    ((.T + &quot;Z&quot;) | fromdate | tostring + &quot;000&quot;)\r\n\r\nTo verify this, consider: \r\n\r\n\r\n### timestamp.jq\r\n\r\n    [splits(&quot;[(),]&quot;)]\r\n    | .[1] |= ((. + &quot;Z&quot;)|fromdate|tostring + &quot;000&quot;)  # milliseconds\r\n    | .[1:length-1]\r\n    | &quot;(&quot; + join(&quot;,&quot;) + &quot;)&quot;\r\n\r\n### Invocation\r\n    jq -rR -f timestamp.jq  input.txt\r\n### Output\r\n\r\n    (1521311400000,0.00012575,0.00012643,0.00012563,0.00012643,383839.45768188,48.465051)\r\n    (1521313200000,0.00012643,0.00012726,0.00012642,0.00012722,207757.18765437,26.30099514)\r\n    (1521315000000,0.00012726,0.00012779,0.00012698,0.00012779,97387.01596624,12.4229077)\r\n    (1521316800000,0.0001276,0.0001278,0.00012705,0.0001275,96850.15260027,12.33316229)\r\n\r\n",
                "title": "jq parsing date to timestamp"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1521362264,
                "last_edit_date": 1521362264,
                "creation_date": 1521345088,
                "answer_id": 49344312,
                "question_id": 49343797,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is an unportable awk solution.  It is not portable because it relies on the system `date` command; on the system I&#39;m using, the relevant invocation looks like: `date -j -f &quot;%Y-%m-%eT%T&quot; STRING &quot;+%s&quot;`\r\n\r\n    awk -F, &#39;BEGIN{OFS=FS}\r\n      NF==0 { next }\r\n      { sub(/\\(/,&quot;&quot;,$1);\r\n        cmd=&quot;date -j -f \\&quot;%Y-%m-%eT%T\\&quot; &quot; $1 &quot; +%s&quot;;\r\n        cmd | getline $1;\r\n        $1=$1 &quot;000&quot;;     # milliseconds\r\n        printf &quot;%s&quot;, &quot;(&quot;;\r\n        print;\r\n      }&#39; input.txt\r\n\r\n### Output\r\n\r\n    (1521325800000,0.00012575,0.00012643,0.00012563,0.00012643,383839.45768188,48.465051)\r\n    (1521327600000,0.00012643,0.00012726,0.00012642,0.00012722,207757.18765437,26.30099514)\r\n    (1521329400000,0.00012726,0.00012779,0.00012698,0.00012779,97387.01596624,12.4229077)\r\n    (1521331200000,0.0001276,0.0001278,0.00012705,0.0001275,96850.15260027,12.33316229)\r\n\r\n",
                "title": "jq parsing date to timestamp"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1521404026,
                "creation_date": 1521404026,
                "answer_id": 49352404,
                "question_id": 49343797,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Solution with sed :\r\n\r\n     sed -e &#39;s/(\\([^,]\\+\\)\\(,.*\\)/echo &quot;(\\$(date -d \\1 +%s%3N),\\2&quot;/g&#39; | ksh\r\n\r\n\r\ntest :\r\n\r\n      &lt;commande_curl&gt; | sed -e &#39;s/(\\([^,]\\+\\)\\(,.*\\)/echo &quot;(\\$(date -d \\1 +%s%3N),\\2&quot;/g&#39; | ksh\r\n\r\n\r\nor :\r\n\r\n      &lt;commande_curl&gt; &gt; results_curl.txt\r\n      cat results_curl.txt | sed -e &#39;s/(\\([^,]\\+\\)\\(,.*\\)/echo &quot;(\\$(date -d \\1 +%s%3N),\\2&quot;/g&#39; | ksh",
                "title": "jq parsing date to timestamp"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1562070352,
        "creation_date": 1521338115,
        "last_edit_date": 1562070352,
        "question_id": 49343797,
        "body_markdown": "I have the following script:\r\n\r\n    curl -s -S &#39;https://bittrex.com/Api/v2.0/pub/market/GetTicks?marketName=BTC-NBT&amp;tickInterval=thirtyMin&amp;_=1521347400000&#39; | jq -r &#39;.result|.[] |[.T,.O,.H,.L,.C,.V,.BV] | @tsv | tostring | gsub(&quot;\\t&quot;;&quot;,&quot;) | &quot;(\\(.))&quot;&#39;\r\n\r\nThis is the output:\r\n\r\n\r\n\r\n    (2018-03-17T18:30:00,0.00012575,0.00012643,0.00012563,0.00012643,383839.45768188,48.465051)\r\n    (2018-03-17T19:00:00,0.00012643,0.00012726,0.00012642,0.00012722,207757.18765437,26.30099514)\r\n    (2018-03-17T19:30:00,0.00012726,0.00012779,0.00012698,0.00012779,97387.01596624,12.4229077)\r\n    (2018-03-17T20:00:00,0.0001276,0.0001278,0.00012705,0.0001275,96850.15260027,12.33316229)\r\n\r\n\r\nI want to replace the date with timestamp.\r\n\r\nI can make this conversion with date in the shell\r\n\r\n    date -d &#39;2018-03-17T18:30:00&#39; +%s%3N\r\n    1521325800000\r\nI want this result:\r\n\r\n \r\n\r\n    (1521325800000,0.00012575,0.00012643,0.00012563,0.00012643,383839.45768188,48.465051)\r\n    (1521327600000,0.00012643,0.00012726,0.00012642,0.00012722,207757.18765437,26.30099514)\r\n    (1521329400000,0.00012726,0.00012779,0.00012698,0.00012779,97387.01596624,12.4229077)\r\n    (1521331200000,0.0001276,0.0001278,0.00012705,0.0001275,96850.15260027,12.33316229)\r\n\r\nThis data is stored in MySQL.\r\n\r\nIs it possible to execute the date conversion with jq or another command like awk, sed, perl in a single command line?\r\n",
        "link": "https://stackoverflow.com/questions/49343797/jq-parsing-date-to-timestamp",
        "title": "jq parsing date to timestamp"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1521413730,
                "post_id": 49353318,
                "comment_id": 85707527,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1521416313,
                "post_id": 49353318,
                "comment_id": 85708147,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2435926,
                    "reputation": 23422,
                    "user_id": 2125837,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/760b6ec2b6e1cba2b0218178425f4cde?s=256&d=identicon&r=PG",
                    "display_name": "xpt",
                    "link": "https://stackoverflow.com/users/2125837/xpt"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521428402,
                "post_id": 49353318,
                "comment_id": 85710681,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2435926,
                    "reputation": 23422,
                    "user_id": 2125837,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/760b6ec2b6e1cba2b0218178425f4cde?s=256&d=identicon&r=PG",
                    "display_name": "xpt",
                    "link": "https://stackoverflow.com/users/2125837/xpt"
                },
                "reply_to_user": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1521429544,
                "post_id": 49353318,
                "comment_id": 85710880,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521457041,
                "post_id": 49353318,
                "comment_id": 85722544,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2435926,
                    "reputation": 23422,
                    "user_id": 2125837,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/760b6ec2b6e1cba2b0218178425f4cde?s=256&d=identicon&r=PG",
                    "display_name": "xpt",
                    "link": "https://stackoverflow.com/users/2125837/xpt"
                },
                "reply_to_user": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521464397,
                "post_id": 49353318,
                "comment_id": 85727330,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1521465280,
                "post_id": 49353318,
                "comment_id": 85728028,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1521436622,
                "creation_date": 1521436622,
                "answer_id": 49356221,
                "question_id": 49353318,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The response is an array of objects that contain commit information. Since you want to filter that array, you usually will want to `map/1` that array and filter using `select/1`: `map(select(...))`. You just need to provide the condition to filter.\r\n\r\n    map(select(.commit | (.author.date[:4] | tonumber) &gt;= 2016 and .comment_count &gt;= 1))\r\n\r\nThe date in this particular case is a date string in iso format. I&#39;m assuming you wanted to get the commits that were in the year 2016 and beyond. Extract the year part and compare.\r\n\r\n    (.author.date[:4] | tonumber) &gt;= 2016\r\n\r\nThen combine that with comparing the comment count.\r\n\r\nNote, I projected to the commit first to minimize repetition in the filter. I could have easily left that part out.\r\n\r\n    map(select((.commit.author.date[:4] | tonumber) &gt;= 2016 and .commit.comment_count &gt;= 1))",
                "title": "jq filtering based on conditions"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1521436622,
        "creation_date": 1521410941,
        "question_id": 49353318,
        "body_markdown": "How can I use `jq` to do filtering based on certain conditions? \r\n\r\nUsing the example from https://stedolan.github.io/jq/tutorial/#result2 for e.g., say I want to filter the results by\r\n\r\n- `.commit.author.date&gt;=2016`, and\r\n- `.commit.comment_count&gt;=1`\r\n\r\nAll the items not satisfying such criteria will not show up in the end result.\r\n\r\nWhat&#39;s the proper `jq` expression to do that? Thx. \r\n",
        "link": "https://stackoverflow.com/questions/49353318/jq-filtering-based-on-conditions",
        "title": "jq filtering based on conditions"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1521496727,
                "last_edit_date": 1521496727,
                "creation_date": 1521484352,
                "answer_id": 49370076,
                "question_id": 49369751,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There is a mismatch between the sample JSON and the rest of the question, e.g. the JSON has no key named &quot;ressources&quot;, and the key corresponding to &quot;app&quot; is &quot;actee_type&quot; (not &quot;actor_type&quot; as in the jq filter). \r\n\r\nBased on the sample JSON (minus the erroneous trailing comma) and the stated query, the appropriate jq filter would simply be:\r\n\r\n    select (.entity.actee_type==&quot;app&quot;)\r\n    | .metadata.updated_at\r\n\r\nwith the result (using the -r command-line option):\r\n\r\n    2018-03-07T17:15:22Z\r\n\r\n## Update\r\nBased on the comment, the relevant query against the complete JSON would be as above but preceded by `.resources[] | `\r\n\r\n\r\n\r\n",
                "title": "Selecting values based on a key value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1561734748,
        "creation_date": 1521483148,
        "last_edit_date": 1561734748,
        "question_id": 49369751,
        "body_markdown": "I have the following json output \r\n\r\n```json\r\n{\r\n         &quot;metadata&quot;: {\r\n            &quot;guid&quot;: &quot;f9787342b-0d3b-45c5-b7a6-f61c2a12de00&quot;,\r\n            &quot;url&quot;: &quot;/v2/events/f67a342b-0d3b-45c5-b7a6-f61c2a12de00&quot;,\r\n            &quot;created_at&quot;: &quot;2018-03-07T17:15:22Z&quot;,\r\n            &quot;updated_at&quot;: &quot;2018-03-07T17:15:22Z&quot;\r\n         },\r\n         &quot;entity&quot;: {\r\n            &quot;type&quot;: &quot;audit.app.update&quot;,\r\n            &quot;actor&quot;: &quot;ae84a203-921d-41a0-97bf-26679342ef47&quot;,\r\n            &quot;actor_type&quot;: &quot;user&quot;,\r\n            &quot;actor_name&quot;: &quot;abc@xyz.org&quot;,\r\n            &quot;actor_username&quot;: &quot;abc.xyz.org&quot;,\r\n            &quot;actee&quot;: &quot;b9dba536-2aae-455d-aadc-8782bd5ee8d5&quot;,\r\n            &quot;actee_type&quot;: &quot;app&quot;,\r\n            &quot;actee_name&quot;: &quot;knpFileUpload&quot;,\r\n            &quot;timestamp&quot;: &quot;2018-03-07T17:15:22Z&quot;,\r\n            &quot;metadata&quot;: {\r\n               &quot;request&quot;: {\r\n                  &quot;state&quot;: &quot;STARTED&quot;\r\n               }\r\n            },\r\n            &quot;space_guid&quot;: &quot;bcz38b4b-9989-42d2-b6bd-702645e344cf&quot;,\r\n            &quot;organization_guid&quot;: &quot;axr09940a-a680-4f54-af30-3abfdb76ea2f&quot;\r\n         }\r\n      },\r\n```\r\n\r\nI am trying to get the value of updated_at if actee_type = app.\r\n\r\nTried the following command \r\n\r\n```shell\r\ncf curl  &quot;/v2/events?q=space_guid:bcz38b4b-9989-42d2-b6bd-702645e344cf&quot; | jq -r &#39;.[] | select (.ressources[].entity.actor_type==&quot;app&quot;) | .resources[].metadata.updated_at&#39;\r\n```\r\n\r\nbut getting an error that Cannot index number with string &quot;ressources&quot; and if I use \r\n\r\n```shell\r\njq -r &#39;select (.ressources[].entity.actor_type==&quot;app&quot;) | .resources[].metadata.updated_at&#39;\r\n```\r\n\r\n```error\r\nCannot iterate over null. Can someone suggest what is the correct syntax.\r\n```\r\n\r\nTIA",
        "link": "https://stackoverflow.com/questions/49369751/selecting-values-based-on-a-key-value",
        "title": "Selecting values based on a key value"
    },
    {
        "tags": [
            "linux",
            "shell",
            "ssh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521527467,
                "post_id": 49377438,
                "comment_id": 85755896,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5665565,
                    "reputation": 2687,
                    "user_id": 4481829,
                    "user_type": "registered",
                    "accept_rate": 55,
                    "profile_image": "https://i.sstatic.net/OQpdM.jpg?s=256",
                    "display_name": "Bhavik Joshi",
                    "link": "https://stackoverflow.com/users/4481829/bhavik-joshi"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521527653,
                "post_id": 49377438,
                "comment_id": 85755971,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521533663,
                "post_id": 49377438,
                "comment_id": 85758935,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1523028288,
                "last_edit_date": 1523028288,
                "creation_date": 1523027969,
                "answer_id": 49696057,
                "question_id": 49377438,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    ssh &quot;$server&quot; &quot;bash -s&quot; &lt;&lt;&#39;EOF&#39;\r\n    [[ -e ~/.docker/config.json ]] || {\r\n      echo &quot;ERROR: $HOME/.docker/config.json does not exist on the remote server&quot; &gt;&amp;2\r\n      exit 1\r\n    }\r\n\r\n    jq &#39;.credsStore = &quot;ecr-login&quot;&#39; \\\r\n      &lt;~/.docker/config.json \\\r\n      &gt;~/.docker/output.json \r\n    EOF",
                "title": "Running jq on a remote machine over ssh and overwrite the file"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1523028288,
        "creation_date": 1521526591,
        "last_edit_date": 1521534054,
        "question_id": 49377438,
        "body_markdown": "I am trying to create a file from the output of `jq` command over ssh command.\r\n\r\n    ssh &lt;server-Name&gt; &quot;jq &#39;.credsStore = &quot;ecr-login&quot;&#39; ~/.docker/config.json &gt; ~/.docker/output.json &quot;\r\n\r\nIt gives me following error:\r\n\r\n`bash: .docker/output.json: No such file or directory`\r\n\r\nAm I not running the command properly or is there any other problem?\r\n",
        "link": "https://stackoverflow.com/questions/49377438/running-jq-on-a-remote-machine-over-ssh-and-overwrite-the-file",
        "title": "Running jq on a remote machine over ssh and overwrite the file"
    },
    {
        "tags": [
            "ssh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1521547135,
                "last_edit_date": 1521547135,
                "creation_date": 1521529559,
                "answer_id": 49378158,
                "question_id": 49377973,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You have a shell quoting issue. You didn&#39;t escape the inner double quotes.\r\n\r\nYou can try the following:\r\n\r\n    ssh &lt;test-server&gt; &#39;jq &quot;.key3 = \\&quot;Value3\\&quot;&quot; .docker/test.json &gt; .docker/test2.json &amp;&amp; mv .docker/test2.json .docker/test.json&#39;\r\n\r\nwhich replace the outer double quote with single ones because you don&#39;t need variable expansion in this statement.",
                "title": "How to edit json file resides on the remote server?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1521547135,
        "creation_date": 1521528875,
        "question_id": 49377973,
        "body_markdown": "I have a json file on my remote server\r\n\r\nlocation at remote host : &quot;.docker/test.josn&quot;\r\n\r\n{\r\n&quot;key1&quot; : &quot;Value1&quot;,\r\n&quot;Key2&quot; : &quot;Value2&quot;\r\n}\r\n\r\nI want to add new element to the test.josn from my local machine. I am trying following command but it is not working. \r\n\r\n    ssh &lt;test-server&gt; &quot;jq &#39;.key3 = &quot;Value3&quot;&#39; .docker/test.json &gt; .docker/test2.json &amp;&amp; mv .docker/test2.json .docker/test.json&quot;\r\n\r\nIts giving me the following error:\r\n\r\n    bash: .docker/test2.json: No such file or directory\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49377973/how-to-edit-json-file-resides-on-the-remote-server",
        "title": "How to edit json file resides on the remote server?"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1521548836,
                "last_edit_date": 1521548836,
                "creation_date": 1521538887,
                "answer_id": 49380773,
                "question_id": 49379953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It appears that .Principal.Service is either a string or an array of strings, so you need to handle both cases. Consider therefore:\r\n\r\n    def to_s: if type == &quot;string&quot; then . else join(&quot;--&quot;) end;\r\n\r\nYou might want to make this more generic to make it more robust or for other reasons.\r\n\r\nYou might also want to streamline your jq filter to make it more intelligible and maintainable, e.g. by using jq variables.  Note also that\r\n\r\n    .x.a + .x.b + x.c \r\n\r\ncan be written as:\r\n\r\n    .x | (.a + .b + .c)",
                "title": "Unable to parse JSON file to CSV with jq-string (&quot;&quot;) and array cannot be added"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1521539436,
                "last_edit_date": 1521539436,
                "creation_date": 1521539115,
                "answer_id": 49380853,
                "question_id": 49379953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Consider adding additional condition to check whether `.Principal.Service` is type of either `array` or `string`:\r\n\r\n    jq -rc &#39;.RoleDetailList \r\n            | map(select((.AssumeRolePolicyDocument.Statement | length &gt; 0) and \r\n            (.AssumeRolePolicyDocument.Statement[].Principal.Service) or \r\n            (.AssumeRolePolicyDocument.Statement[].Principal.AWS) or \r\n            (.AssumeRolePolicyDocument.Statement[].Principal.Federated) or \r\n            (.AttachedManagedPolicies | length &gt;0) or \r\n            (.RolePolicyList | length &gt; 0)) )[] \r\n            | [.RoleName,\r\n               ([.RolePolicyList[].PolicyName,\r\n               ([.AttachedManagedPolicies[].PolicyName] | join(&quot;--&quot;))] \r\n            | join(&quot; &quot;)),\r\n             (.AssumeRolePolicyDocument.Statement[] \r\n            | .Principal.Federated + &quot;&quot; \r\n              + (.Principal.Service | if type == &quot;array&quot; then join(&quot;--&quot;) else . end) \r\n              + &quot;&quot; + .Principal.AWS)] \r\n           | @csv&#39; ./output.json\r\n\r\nThe output:\r\n\r\n    &quot;ADFS-Administrators&quot;,&quot;Administrator-Access &quot;,&quot;arn:aws:iam::279052847476:saml-provider/companyADFS&quot;\r\n    &quot;ADFS-amtest-ro&quot;,&quot;pol-amtest-ro&quot;,&quot;arn:aws:iam::279052847476:saml-provider/companyADFS&quot;\r\n    &quot;adfs-host-role&quot;,&quot;pol-amtest-ro&quot;,&quot;ec2.amazonaws.com&quot;\r\n    &quot;aws-elasticbeanstalk-ec2-role&quot;,&quot;AWSElasticBeanstalkWebTier--AWSElasticBeanstalkMulticontainerDocker--AWSElasticBeanstalkWorkerTier&quot;,&quot;ec2.amazonaws.com&quot;\r\n    &quot;aws-elasticbeanstalk-service-role&quot;,&quot;AWSElasticBeanstalkEnhancedHealth--AWSElasticBeanstalkService&quot;,&quot;elasticbeanstalk.amazonaws.com&quot;\r\n    &quot;AWSAccCorpAdmin&quot;,&quot;AdministratorAccess&quot;,&quot;arn:aws:iam::279052847476:saml-provider/LastPass&quot;\r\n    &quot;AWScompanyCorpAdmin&quot;,&quot;AdministratorAccess&quot;,&quot;arn:aws:iam::279052847476:saml-provider/LastPass&quot;\r\n    &quot;AWScompanyCorpPowerUser&quot;,&quot;PowerUserAccess&quot;,&quot;arn:aws:iam::279052847476:saml-provider/LastPass&quot;\r\n    &quot;AWSServiceRoleForAutoScaling&quot;,&quot;AutoScalingServiceRolePolicy&quot;,&quot;autoscaling.amazonaws.com&quot;\r\n    &quot;AWSServiceRoleForElasticBeanstalk&quot;,&quot;AWSElasticBeanstalkServiceRolePolicy&quot;,&quot;elasticbeanstalk.amazonaws.com&quot;\r\n    &quot;AWSServiceRoleForElasticLoadBalancing&quot;,&quot;AWSElasticLoadBalancingServiceRolePolicy&quot;,&quot;elasticloadbalancing.amazonaws.com&quot;\r\n    &quot;AWSServiceRoleForOrganizations&quot;,&quot;AWSOrganizationsServiceTrustPolicy&quot;,&quot;organizations.amazonaws.com&quot;\r\n    &quot;AWSServiceRoleForRDS&quot;,&quot;AmazonRDSServiceRolePolicy&quot;,&quot;rds.amazonaws.com&quot;\r\n    &quot;Cloudyn&quot;,&quot;ReadOnlyAccess&quot;,&quot;arn:aws:iam::432263259397:root&quot;\r\n    &quot;DatadogAWSIntegrationRole&quot;,&quot;DatadogAWSIntegrationPolicy&quot;,&quot;arn:aws:iam::464622532012:root&quot;\r\n    &quot;datadog_alert_metrics_role&quot;,&quot;AWSLambdaBasicExecutionRole-66abe1f2-cee8-4a90-a026-061b24db1b02&quot;,&quot;lambda.amazonaws.com&quot;\r\n    &quot;dev-instance-role&quot;,&quot;dev-instance-role-policy&quot;,&quot;*&quot;\r\n    &quot;ec2ssmRole&quot;,&quot;AmazonEC2RoleforSSM&quot;,&quot;ssm.amazonaws.com--ec2.amazonaws.com&quot;\r\n    &quot;ecsInstanceRole&quot;,&quot;AmazonEC2ContainerServiceforEC2Role&quot;,&quot;ec2.amazonaws.com&quot;\r\n    &quot;ecsServiceRole&quot;,&quot;AmazonEC2ContainerServiceRole&quot;,&quot;ecs.amazonaws.com&quot;\r\n    &quot;flowlogsRole&quot;,&quot;oneClick_flowlogsRole_1495032428381 &quot;,&quot;vpc-flow-logs.amazonaws.com&quot;\r\n    &quot;companyDevShutdownEC2Instaces&quot;,&quot;oneClick_lambda_basic_execution_1516271285849 &quot;,&quot;lambda.amazonaws.com&quot;\r\n    &quot;companySAMLUser&quot;,&quot;AdministratorAccess&quot;,&quot;arn:aws:iam::279052847476:saml-provider/companyAzureAD&quot;\r\n    &quot;irole-matlabscheduler&quot;,&quot;pol-marketdata-rw&quot;,&quot;ec2.amazonaws.com&quot;\r\n    &quot;jira_role&quot;,&quot;&quot;,&quot;*&quot;\r\n    &quot;lambda-ec2-ami-role&quot;,&quot;lambda-ec2-ami-policy&quot;,&quot;lambda.amazonaws.com&quot;\r\n    &quot;lambda_api_gateway_twilio_processor&quot;,&quot;AWSLambdaBasicExecutionRole-f47a6b57-b716-4740-b2c6-a02fa6480153--AWSLambdaSNSPublishPolicyExecutionRole-d31a9f16-80e7-47c9-868a-f162396cccf6&quot;,&quot;lambda.amazonaws.com&quot;\r\n    &quot;lambda_stop_rundeck_instance&quot;,&quot;oneClick_lambda_basic_execution_1519651160794 &quot;,&quot;lambda.amazonaws.com&quot;\r\n    &quot;OneLoginAdmin&quot;,&quot;AdministratorAccess&quot;,&quot;arn:aws:iam::279052847476:saml-provider/OneLoginAdmin&quot;\r\n    &quot;OneLoginDev&quot;,&quot;PowerUserAccess&quot;,&quot;arn:aws:iam::279052847476:saml-provider/OneLoginDev&quot;\r\n    &quot;rds-host-role&quot;,&quot;&quot;,&quot;ec2.amazonaws.com&quot;\r\n    &quot;rds-monitoring-role&quot;,&quot;AmazonRDSEnhancedMonitoringRole&quot;,&quot;monitoring.rds.amazonaws.com&quot;\r\n    &quot;role-amtest-ro&quot;,&quot;pol-amtest-ro&quot;,&quot;ec2.amazonaws.com&quot;\r\n    &quot;role-amtest-rw&quot;,&quot;pol-amtest-rw&quot;,&quot;ec2.amazonaws.com&quot;\r\n    &quot;Stackdriver&quot;,&quot;ReadOnlyAccess&quot;,&quot;arn:aws:iam::314658760392:root&quot;\r\n    &quot;vmimport&quot;,&quot;vmimport &quot;,&quot;vmie.amazonaws.com&quot;\r\n    &quot;workspaces_DefaultRole&quot;,&quot;SkyLightServiceAccess &quot;,&quot;workspaces.amazonaws.com&quot;",
                "title": "Unable to parse JSON file to CSV with jq-string (&quot;&quot;) and array cannot be added"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1521548836,
        "creation_date": 1521536463,
        "last_edit_date": 1521538538,
        "question_id": 49379953,
        "body_markdown": "Here is output.json: https://1drv.ms/u/s!AizscpxS0QM4hJo5SnYOHAcjng-jww\r\n\r\ni have issues in sts:AsumeRole.Principal.Service part when have multiple Services \r\n\r\n    Principal&quot;: {\r\n                            &quot;Service&quot;: [\r\n                                &quot;ssm.amazonaws.com&quot;, \r\n                                &quot;ec2.amazonaws.com&quot;\r\n                            ]\r\n                        }\r\n\r\nin my code below, it&#39;s `.Principal.Service` field.\r\nIf have only one service, no issues\r\n\r\n\r\n     &quot;InstanceProfileList&quot;: [\r\n                {\r\n                    &quot;InstanceProfileId&quot;: &quot;AIPAJMMLWIVZ2IXTOC3RO&quot;, \r\n                    &quot;Roles&quot;: [\r\n                        {\r\n                            &quot;AssumeRolePolicyDocument&quot;: {\r\n                                &quot;Version&quot;: &quot;2012-10-17&quot;, \r\n                                &quot;Statement&quot;: [\r\n                                    {\r\n                                        &quot;Action&quot;: &quot;sts:AssumeRole&quot;, \r\n                                        &quot;Effect&quot;: &quot;Allow&quot;, \r\n                                        &quot;Principal&quot;: {\r\n                                            &quot;AWS&quot;: &quot;*&quot;\r\n                                        }\r\n                                    }\r\n                                ]\r\n                            }, \r\n                            &quot;RoleId&quot;: &quot;AROAJPHJ4EDQG3G5ZQZT2&quot;, \r\n                            &quot;CreateDate&quot;: &quot;2017-04-04T23:46:47Z&quot;, \r\n                            &quot;RoleName&quot;: &quot;dev-instance-role&quot;, \r\n                            &quot;Path&quot;: &quot;/&quot;, \r\n                            &quot;Arn&quot;: &quot;arn:aws:iam::279052847476:role/dev-instance-role&quot;\r\n                        }\r\n                    ], \r\n                    &quot;CreateDate&quot;: &quot;2017-04-04T23:46:47Z&quot;, \r\n                    &quot;InstanceProfileName&quot;: &quot;bastionServerInstanceProfile&quot;, \r\n                    &quot;Path&quot;: &quot;/&quot;, \r\n                    &quot;Arn&quot;: &quot;arn:aws:iam::279052847476:instance-profile/bastionServerInstanceProfile&quot;\r\n                }\r\n            ], \r\n            &quot;RoleName&quot;: &quot;dev-instance-role&quot;, \r\n            &quot;Path&quot;: &quot;/&quot;, \r\n            &quot;AttachedManagedPolicies&quot;: [\r\n                {\r\n                    &quot;PolicyName&quot;: &quot;dev-instance-role-policy&quot;, \r\n                    &quot;PolicyArn&quot;: &quot;arn:aws:iam::279052847476:policy/dev-instance-role-policy&quot;\r\n                }\r\n            ], \r\n            &quot;RolePolicyList&quot;: [], \r\n            &quot;Arn&quot;: &quot;arn:aws:iam::279052847476:role/dev-instance-role&quot;\r\n        }, \r\n        {\r\n            &quot;AssumeRolePolicyDocument&quot;: {\r\n                &quot;Version&quot;: &quot;2012-10-17&quot;, \r\n                &quot;Statement&quot;: [\r\n                    {\r\n                        &quot;Action&quot;: &quot;sts:AssumeRole&quot;, \r\n                        &quot;Effect&quot;: &quot;Allow&quot;, \r\n                        &quot;Principal&quot;: {\r\n                            &quot;Service&quot;: [\r\n                                &quot;ssm.amazonaws.com&quot;, \r\n                                &quot;ec2.amazonaws.com&quot;\r\n                            ]\r\n                        }\r\n                    }\r\n                ]\r\n            }, \r\n\r\nIf only one service exists, no issues, but if more than one then getting error `string (&quot;&quot;) and array ([&quot;ssm.amazonaws.com) cannot be added`\r\n\r\nHow to get all values for Principal.Service in one row.\r\n\r\nMy code:\r\n\r\n    jq -rc &#39;.RoleDetailList \r\n      | map(select((.AssumeRolePolicyDocument.Statement | length &gt; 0) and \r\n            (.AssumeRolePolicyDocument.Statement[].Principal.Service) or \r\n            (.AssumeRolePolicyDocument.Statement[].Principal.AWS) or \r\n            (.AssumeRolePolicyDocument.Statement[].Principal.Federated) or \r\n            (.AttachedManagedPolicies | length &gt;0) or \r\n            (.RolePolicyList | length &gt; 0)) )[] \r\n          | [.RoleName,\r\n             ([.RolePolicyList[].PolicyName,\r\n              ([.AttachedManagedPolicies[].PolicyName] | join(&quot;--&quot;))] \r\n             | join(&quot; &quot;)),\r\n           (.AssumeRolePolicyDocument.Statement[] \r\n            | .Principal.Federated + &quot;&quot; + .Principal.Service + &quot;&quot;+.Principal.AWS)] \r\n           | @csv&#39; ./output.json\r\n\r\nDesired output:\r\n\r\n    &quot;dev-instance-role&quot;,&quot;dev-instance-role-policy&quot;,&quot;ssm.amazonaws.com--ec2.amazonaws.com--*&quot;\r\n\r\nCurrent output:\r\n\r\n    &quot;dev-instance-role&quot;,&quot;dev-instance-role-policy&quot;,&quot;*&quot;",
        "link": "https://stackoverflow.com/questions/49379953/unable-to-parse-json-file-to-csv-with-jq-string-and-array-cannot-be-added",
        "title": "Unable to parse JSON file to CSV with jq-string (&quot;&quot;) and array cannot be added"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521549921,
                "post_id": 49382979,
                "comment_id": 85769905,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1589065944,
                "last_edit_date": 1589065944,
                "creation_date": 1521545294,
                "answer_id": 49383034,
                "question_id": 49382979,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The *canonical* way :\r\n\r\n    file=&#39;input.json&#39;\r\n    cat &quot;$file&quot; | jq -r &#39;.menu | keys[]&#39; | \r\n    while IFS= read -r value; do\r\n        echo &quot;$value&quot;\r\n    done\r\n\r\n[bash faq #1](http://mywiki.wooledge.org/BashFAQ/001)\r\n\r\n--- \r\n\r\n\r\nBut you seems to want an array, so the syntax is (missing parentheses) :\r\n\r\n    file=&#39;input.json&#39;\r\n\r\n    result=( $(cat &quot;$file&quot; | jq -r &#39;.menu | keys[]&#39;) )\r\n\r\n    for type in &quot;${result[@]}&quot;; do\r\n        echo &quot;--$type--&quot;\r\n    done\r\n\r\n## Output:\r\n\r\n    --id--\r\n    --value--\r\n    --user--\r\n\r\n&lt;!-- boring to add random data just to be able to correct a typo :/ --&gt;",
                "title": "How to loop a json keys result from bash script"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1521550267,
                "last_edit_date": 1521550267,
                "creation_date": 1521549869,
                "answer_id": 49384583,
                "question_id": 49382979,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using `bash` to just print an object keys from JSON data is redundant.&lt;br&gt;\r\n**`Jq`** is able to handle it by itself. Use the following simple **`jq`** solution:\r\n\r\n    jq -r &#39;.menu | keys_unsorted[] | &quot;--&quot;+ . +&quot;--&quot;&#39; input.json\r\n\r\nThe output:\r\n\r\n    --id--\r\n    --value--\r\n    --user--\r\n\r\n",
                "title": "How to loop a json keys result from bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1589065944,
        "creation_date": 1521545086,
        "question_id": 49382979,
        "body_markdown": "\r\ninput.json:-\r\n\r\n    {\r\n    &quot;menu&quot;: {\r\n      &quot;id&quot;: &quot;file&quot;,\r\n      &quot;value&quot;: &quot;File&quot;,\r\n      &quot;user&quot;: {\r\n        &quot;address&quot;: &quot;USA&quot;,\r\n        &quot;email&quot;: &quot;user@gmail.com&quot;\r\n      }\r\n    }\r\n    }\r\n\r\nCommand:-\r\n\r\n    result=$(cat input.json | jq -r &#39;.menu | keys[]&#39;)\r\n\r\nResult:-\r\n\r\n    id\r\n    value\r\n    user\r\n\r\nLoop through result:-\r\n\r\n    for type in &quot;${result[@]}&quot;\r\n    do\r\n    \techo &quot;--$type--&quot;\r\n    done\r\n\r\nOutput:-\r\n\r\n    --id\r\n    value\r\n    user--\r\n\r\nI want to do process the keys values in a loop. When I do the above, It result as a single string.\r\n\r\nHow can I do a loop with json keys result in bash script?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49382979/how-to-loop-a-json-keys-result-from-bash-script",
        "title": "How to loop a json keys result from bash script"
    },
    {
        "tags": [
            "syntax",
            "jq",
            "abbreviation"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2435926,
                    "reputation": 23422,
                    "user_id": 2125837,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/760b6ec2b6e1cba2b0218178425f4cde?s=256&d=identicon&r=PG",
                    "display_name": "xpt",
                    "link": "https://stackoverflow.com/users/2125837/xpt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522526762,
                "post_id": 49398366,
                "comment_id": 86191426,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1521613386,
                "creation_date": 1521613386,
                "answer_id": 49399556,
                "question_id": 49398366,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Perhaps things will be clearer if you begin by thinking of the full data pipeline involved, and recognize when an expression is just an abbreviated form.  \r\n\r\nIn constructing an unabbreviated pipeline, the basic principles regarding &quot;dots&quot; are quite simple:\r\n\r\n* `.` refers to the input\r\n* `.foo` is for accessing the value of the key &quot;foo&quot;\r\n* `.[]` is for expanding an array or object\r\n\r\nThere are many allowed abbreviations.  The two that seem to have confused you the most are:\r\n\r\n* `.foo.bar` for `.foo | .bar`\r\n* `{foo}` for `{&quot;foo&quot;: .foo}`\r\n\r\nAnother important abbreviation is:\r\n\r\n* `E[]` for `E | .[]` where E is a suitably compact expression\r\n\r\nWith these principles and examples in mind, you should be able to master the details as explained in the jq documentation.\r\n",
                "title": "jq, when to use the dot and when not"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1629914142,
        "creation_date": 1521607596,
        "last_edit_date": 1629914142,
        "question_id": 49398366,
        "body_markdown": "Consider [the following `json` string](https://gist.github.com/suntong/5d7d546c3ab075fb17c7693b4d3cc855):\r\n\r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;search&quot;: {\r\n          &quot;repositoryCount&quot;: 24,\r\n          &quot;edges&quot;: [\r\n            {\r\n              &quot;node&quot;: {\r\n                &quot;name&quot;: &quot;leumi-leumicard-bank-data-scraper&quot;,\r\n                &quot;url&quot;: &quot;https://github.com/Urigo/leumi-leumicard-bank-data-scraper&quot;,\r\n                &quot;description&quot;: &quot;Open bank data for Leumi bank and Leumi card credit card&quot;,\r\n                . . . \r\n            },\r\n            {\r\n              &quot;node&quot;: {\r\n                &quot;name&quot;: &quot;puppeteer-demo&quot;,\r\n                &quot;url&quot;: &quot;https://github.com/xJkit/puppeteer-demo&quot;,\r\n                &quot;description&quot;: &quot;A demo for website scrapping by my puppet :&gt;&quot;,\r\n                . . . \r\n\r\n\r\nIf to use `jq` to select the `data`, then it needs a dot (`.`) before it. I.e.:\r\n\r\n    jq &#39;data&#39; \r\n    jq: error: data/0 is not defined at &lt;top-level&gt;, line 1:\r\n    data\r\n    jq: 1 compile error\r\n\r\nHowever `jq &#39;.data&#39;` works fine, and the selected data becomes:\r\n\r\n    {\r\n      &quot;search&quot;: {\r\n        &quot;repositoryCount&quot;: 24,\r\n        &quot;edges&quot;: [\r\n          {\r\n          ...\r\n\r\nIf to use `jq` to select the `search`, *after the pipe*, then it *does not* need a dot (`.`) before it. I.e.:\r\n\r\n    $ jq &#39;.data | {.search} &#39; \r\n    jq: error: syntax error, unexpected FIELD (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .data | {.search}          \r\n    jq: 1 compile error\r\n\r\nHowever `jq &#39;.data.search&#39;` works fine. \r\n\r\nMoreover, a more complicated example, \r\n\r\n    jq &#39;.data.search.edges[] | {node} &#39;\r\n\r\nworks fine, but \r\n\r\n    jq &#39;.data.search.edges[] | {node.name} &#39;\r\n\r\ngives:\r\n\r\n    jq: error: syntax error, unexpected FIELD, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .data.search.edges[] | {node.name}                             \r\n    jq: 1 compile error\r\n\r\nSo, all in all, I&#39;m rather confused when to use the dot (`.`) and when not to, when using `jq`. Please help. Thx. \r\n\r\n",
        "link": "https://stackoverflow.com/questions/49398366/jq-when-to-use-the-dot-and-when-not",
        "title": "jq, when to use the dot and when not"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1521624391,
                "creation_date": 1521624391,
                "answer_id": 49402456,
                "question_id": 49402278,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "How about combining shell variables and [command substitution](https://www.gnu.org/software/bash/manual/bashref.html#Command-Substitution)? \r\n\r\nYou can do something like this in a bash script:\r\n\r\n    cmd=&quot;cmd ls -lah&quot;\r\n    cat &lt;&lt; EOF\r\n    {\r\n      \\&quot;cmd\\&quot;: \\&quot;$cmd\\&quot;,\r\n      \\&quot;time\\&quot;: \\&quot;$(time $cmd)\\&quot;\r\n    }\r\n    EOF\r\n\r\nIf you don&#39;t like the output of `time` or other commands, you can enclose it in a shell function.\r\n\r\n    chrono() {\r\n       command=$1\r\n       result=$(/bin/time $command &gt;/dev/null 2&gt;&amp;1)\r\n       # Awk or sed to give format to the output \r\n    }",
                "title": "Lines in output to JSON format, else not working"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1521626528,
                "creation_date": 1521626528,
                "answer_id": 49403269,
                "question_id": 49402278,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** + **`paste`** solution:\r\n\r\n    jq -R &#39;split(&quot;,&quot;) | {(.[0]) : .[1]}&#39; &lt;(paste -d, - - &lt;statistics.txt)\r\nThe output:\r\n\r\n\r\n    {\r\n      &quot;cmd ls -lah&quot;: &quot;0m1.964s&quot;\r\n    }\r\n    {\r\n      &quot;cmd echo something&quot;: &quot;0m4.183s&quot;\r\n    }\r\n    {\r\n      &quot;cmd setup-environment&quot;: &quot;0m0.401s&quot;\r\n    }\r\n\r\n",
                "title": "Lines in output to JSON format, else not working"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1521636044,
                "last_edit_date": 1521636044,
                "creation_date": 1521634174,
                "answer_id": 49406004,
                "question_id": 49402278,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "All-jq solution:\r\n\r\n    jq -Rn &#39;{ (inputs): input }&#39; statistics.txt\r\n\r\nThe command-line options are:\r\n\r\n* -R for raw input\r\n* -n so that the `inputs` filter sees the first line\r\n\r\n### {&quot;cmd&quot;: _, &quot;value&quot;: _}\r\n\r\nIt might make more sense to produce JSON objects with more structure, e.g. of the form `{&quot;cmd&quot;: _, &quot;value&quot;: _}`.  Assuming the &quot;cmd&quot; line always begins as in statistics.txt, this can also easily be achieved, e.g. by:\r\n\r\n    jq -Rn &#39;{ cmd: inputs[4:], value: input }&#39; statistics.txt\r\n\r\n### If your jq does not have `inputs`\r\n\r\n    jq -R -s &#39;split(&quot;\\n&quot;)\r\n    | recurse( .[2:] | select(length&gt;0))\r\n    | {(.[0]): .[1]}&#39; statistics.txt",
                "title": "Lines in output to JSON format, else not working"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1521698728,
        "creation_date": 1521623856,
        "last_edit_date": 1521698728,
        "question_id": 49402278,
        "body_markdown": "I&#39;m trying to convert time statistics from one of our scripts to JSON format for further processing, but have failed to do so. Here&#39;s an example of what the statistics output looks like:\r\n\r\n    cmd ls -lah\r\n    0m1.964s\r\n    cmd echo something\r\n    0m4.183s\r\n    cmd setup-environment\r\n    0m0.401s\r\n\r\nI would like to have the line starting with &quot;cmd&quot; as the key, and the time value in the next line as &quot;value&quot;.\r\n\r\nI can get &quot;cmd&quot; as key name and the actual command as cmd.value but that is not exactly what I&#39;m aiming for:\r\n\r\n    cat statistics.txt | jq -R &#39;split(&quot;\\n&quot;) - [&quot;&quot;]&#39; | jq &#39;.[] | if select( contains(&quot;cmd&quot;)) then { &quot;cmd&quot;: . } else { &quot;time&quot;: . } end&#39;\r\n\r\nI also know that &quot;if&quot; and &quot;select&quot; can mean pretty much the same thing with jq, but I don&#39;t know how else I could achieve what I want (&quot;else&quot; doesn&#39;t even produce anything in my example). This is what I get currently:\r\n\r\n    {\r\n      &quot;cmd&quot;: &quot;cmd ls -lah&quot;\r\n    }\r\n    {\r\n      &quot;cmd&quot;: &quot;cmd echo something&quot;\r\n    }\r\n    {\r\n      &quot;cmd&quot;: &quot;cmd setup-environment&quot;\r\n    }\r\n\r\nCan someone help me on this?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49402278/lines-in-output-to-json-format-else-not-working",
        "title": "Lines in output to JSON format, else not working"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521645145,
                "post_id": 49408717,
                "comment_id": 85821479,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1521707354,
                "last_edit_date": 1521707354,
                "creation_date": 1521642902,
                "answer_id": 49409139,
                "question_id": 49408717,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -r &#39;.[].recordList.record[].Production \r\n           | &quot;\\(if ((type == &quot;array&quot; and .[0].creator.name !=&quot;&quot;) \r\n                     or (type == &quot;object&quot; and .creator.name and .creator.name !=&quot;&quot;)) \r\n                then 1 else 0 end),&quot;&#39; file.json\r\nThe output:\r\n\r\n    1,\r\n    0,\r\n    1,\r\n\r\n",
                "title": "Accessing field with jq that can be string or array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1521649044,
                "creation_date": 1521649044,
                "answer_id": 49411510,
                "question_id": 49408717,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Simplified jq solution:\r\n\r\n    jq -r &#39;.[].recordList.record[].Production \r\n       | ((type == &quot;array&quot; and .[0].creator.name) or .creator.name) \r\n       | if . then &quot;1,&quot; else &quot;0,&quot; end&#39; file.json",
                "title": "Accessing field with jq that can be string or array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1521707354,
        "creation_date": 1521641727,
        "question_id": 49408717,
        "body_markdown": "I have a large dump of data in json that looks like:\r\n\r\n    [{\r\n       &quot;recordList&quot; : {\r\n          &quot;record&quot; : [{\r\n              &quot;Production&quot; : {\r\n            \t  &quot;creator&quot; : {\r\n            \t\t  &quot;name&quot; : &quot;A&quot;\r\n            \t  }\r\n              }\r\n          },\r\n          {\r\n              &quot;Production&quot; : {}\r\n          },\r\n    \t  {\r\n              &quot;Production&quot; : [{\r\n            \t  &quot;creator&quot; : {\r\n            \t\t  &quot;name&quot; : &quot;B&quot;\r\n            \t  },\r\n            \t  &quot;creator&quot; : {\r\n            \t\t  &quot;name&quot; : &quot;C&quot;\r\n               \t  }\r\n                  }]\r\n              }]\r\n          }\r\n    }]\r\n\r\nI need to check if there is at least one creator in a record or not. If there is I give a 1 else a 0 for that field in a CSV-file.\r\n\r\nMy code:\r\n\r\n    jq -r &#39;.[].recordList.record[]|&quot;\\(if ((.Production.creator.name)? // (.Production[]?.creator.name)?) == null or ((.Production.creator.name)?|length // (.Production[]?.creator.name)?|length) == 0 then 0 else 1 end),&quot;&#39; file.json\r\n\r\nThe problem is that the field &#39;Production&#39; is only an array when there are multiple creators.\r\n\r\nThe result I want to get in this case is:\r\n\r\n    1,\r\n    0,\r\n    1,",
        "link": "https://stackoverflow.com/questions/49408717/accessing-field-with-jq-that-can-be-string-or-array",
        "title": "Accessing field with jq that can be string or array"
    },
    {
        "tags": [
            "json",
            "jq",
            "collect",
            "recursive-descent"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521648552,
                "post_id": 49410611,
                "comment_id": 85824278,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521659291,
                "post_id": 49410611,
                "comment_id": 85831045,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1521652738,
                "last_edit_date": 1521652738,
                "creation_date": 1521649554,
                "answer_id": 49411699,
                "question_id": 49410611,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Not sure what you&#39;re expecting to get in your results... but it seems like you&#39;re trying to get all the repositories and their topics in a flat array. I don&#39;t see any reason why you should use recurse here, you&#39;re only selecting from one class of objects. Just reference them directly.\r\n\r\n    [.data.search.edges[].node | {name,topic:(.repositoryTopics.nodes[].topic.topics)}]\r\n\r\nFor your particular input produces:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;leumi-leumicard-bank-data-scraper&quot;,\r\n        &quot;topic&quot;: &quot;banking&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;leumi-leumicard-bank-data-scraper&quot;,\r\n        &quot;topic&quot;: &quot;leumi&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;leumi-leumicard-bank-data-scraper&quot;,\r\n        &quot;topic&quot;: &quot;api&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;leumi-leumicard-bank-data-scraper&quot;,\r\n        &quot;topic&quot;: &quot;puppeteer&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;leumi-leumicard-bank-data-scraper&quot;,\r\n        &quot;topic&quot;: &quot;scraper&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;leumi-leumicard-bank-data-scraper&quot;,\r\n        &quot;topic&quot;: &quot;open-api&quot;\r\n      }\r\n    ]\r\n\r\nhttps://jqplay.org/s/G2inYAJNLS\r\n\r\n&lt;hr&gt;\r\n\r\nIf you wanted to have an array of topics within the nodes instead, just collect them in an array by putting the filter that selects the topics within `[]`.\r\n\r\n    [.data.search.edges[].node | {name,topic:[.repositoryTopics.nodes[].topic.topics]}]\r\n\r\n&lt;!-- --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;leumi-leumicard-bank-data-scraper&quot;,\r\n        &quot;topic&quot;: [\r\n          &quot;banking&quot;,\r\n          &quot;leumi&quot;,\r\n          &quot;api&quot;,\r\n          &quot;puppeteer&quot;,\r\n          &quot;scraper&quot;,\r\n          &quot;open-api&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;echarts-scrappeteer&quot;,\r\n        &quot;topic&quot;: []\r\n      }\r\n    ]\r\n\r\nhttps://jqplay.org/s/0AFneNK89i\r\n",
                "title": "Use jq to collect recursive-descent results into a single array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1521650548,
                "last_edit_date": 1521650548,
                "creation_date": 1521649999,
                "answer_id": 49411847,
                "question_id": 49410611,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One way to collect the non-falsey values:\r\n\r\n    .data.search.edges[].node \r\n    | {name, topics: [.. | .topics? | select(.)]}\r\n\r\nThe result would be:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;leumi-leumicard-bank-data-scraper&quot;,\r\n      &quot;topics&quot;: [\r\n        &quot;banking&quot;,\r\n        &quot;leumi&quot;,\r\n        &quot;api&quot;,\r\n        &quot;puppeteer&quot;,\r\n        &quot;scraper&quot;,\r\n        &quot;open-api&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;echarts-scrappeteer&quot;,\r\n      &quot;topics&quot;: []\r\n    }\r\n\r\n",
                "title": "Use jq to collect recursive-descent results into a single array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1521664427,
        "creation_date": 1521646735,
        "last_edit_date": 1521664427,
        "question_id": 49410611,
        "body_markdown": "Is it possible to collect [recursive-descent](https://stedolan.github.io/jq/manual/#TypesandValues) results into a single array with `jq`? \r\n\r\nWould `flatten` help? Looks so to me, but I just cannot get it working. Take a look how far I am now at https://jqplay.org/s/6bxD-Wq0QE, anyone can make it working? \r\n\r\nBTW,\r\n\r\n- `.data.search.edges[].node | {name, topics: ..|.topics?}` works, but I want all topics from the same node to be in one array, instead of having same `name` in all different returned results. \r\n- `flatten` alone will give me `Cannot iterate over null`, and\r\n- that&#39;s why I&#39;m trying to use `map(select(.? != null))` to filter the `null`s out. However, I&#39;d get `Cannot iterate over null` as well for my `map-select`. \r\n\r\nSo now it all comes down to how to filter out those `null`s?\r\n\r\n**UPDATE:**, by _&quot;collect into a single array&quot;_ I meant to get something like this:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;leumi-leumicard-bank-data-scraper&quot;,\r\n        &quot;topics&quot;: [&quot;banking&quot;, &quot;leumi&quot;, &quot;api&quot;, &quot;puppeteer&quot;, &quot;scraper&quot;, &quot;open-api&quot;]\r\n      }\r\n    ]\r\n\r\ninstead of having same `name` duplicated in all different returned results. Thus recursively descends seems to me to be the option, but I&#39;m open to any solution as long as I can get result like above. Is that possible? Thx. \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49410611/use-jq-to-collect-recursive-descent-results-into-a-single-array",
        "title": "Use jq to collect recursive-descent results into a single array"
    },
    {
        "tags": [
            "arrays",
            "object",
            "special-characters",
            "jq",
            "is-empty"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521726259,
                "post_id": 49427529,
                "comment_id": 85862078,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2806962,
                    "reputation": 35,
                    "user_id": 2414013,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2d86e0d3bbd02905c43053454177c537?s=256&d=identicon&r=PG",
                    "display_name": "Tine",
                    "link": "https://stackoverflow.com/users/2414013/tine"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521727899,
                "post_id": 49427529,
                "comment_id": 85863373,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2806962,
                    "reputation": 35,
                    "user_id": 2414013,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2d86e0d3bbd02905c43053454177c537?s=256&d=identicon&r=PG",
                    "display_name": "Tine",
                    "link": "https://stackoverflow.com/users/2414013/tine"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521728306,
                "post_id": 49427529,
                "comment_id": 85863672,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1521733191,
                "creation_date": 1521733191,
                "answer_id": 49432793,
                "question_id": 49427529,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -r &#39;.[].recordList.record[].Production \r\n           | &quot;\\(if ((type == &quot;array&quot; and any(.[&quot;creator.role&quot;].term !=&quot;&quot;)) \r\n                or (type == &quot;object&quot; and .[&quot;creator.role&quot;].term and .[&quot;creator.role&quot;].term !=&quot;&quot;))\r\n                then 1 else 0 end),&quot;&#39; file.json",
                "title": "Accessing field with jq that contains a special character and can be an object or an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1521733191,
        "creation_date": 1521718181,
        "last_edit_date": 1521728118,
        "question_id": 49427529,
        "body_markdown": "I have a large dump of data in a file.json that looks like:\r\n\r\n    [{\r\n       &quot;recordList&quot; : {\r\n          &quot;record&quot; : [{\r\n              &quot;Production&quot; : {\r\n                  &quot;creator.role&quot; : {\r\n                      &quot;term&quot; : &quot;A&quot;\r\n                  }\r\n              }\r\n          },\r\n          {\r\n              &quot;Production&quot; : {}\r\n          },\r\n          {\r\n              &quot;Production&quot; : {\r\n                  &quot;creator.role&quot; : {\r\n                      &quot;term&quot; : &quot;&quot;\r\n                  }\r\n              }\r\n          },\r\n          {\r\n              &quot;Production&quot; : [\r\n                  {\r\n                  &quot;creator.role&quot; : {&quot;term&quot; : &quot;B&quot;}\r\n                  },\r\n                  {\r\n                  &quot;creator.role&quot; : {&quot;term&quot; : &quot;&quot;}\r\n                  }\r\n              ]\r\n          }]\r\n       }\r\n    }]\r\n\r\nI need to check if there is at least one &#39;term&#39; (that is not empty) for &#39;creator.role&#39; in a record or not. If there is I give a 1 else a 0 for that field in a CSV-file.\r\n\r\nThanks to the answers on an earlier post, I managed to access a field &#39;creator&#39; although it could be an object or an array (see: https://stackoverflow.com/questions/49408717/accessing-field-with-jq-that-can-be-string-or-array).\r\n\r\nBut now I also have the same problem for the field &#39;creator.role&#39; with the special character &#39;.&#39; and don&#39;t know how to handle that.\r\n\r\nThe code I tried:\r\n\r\n    jq -r &#39;.[].recordList.record[].Production | &quot;\\(if ((type == &quot;array&quot; and .[0][&quot;creator.role&quot;].term and .[0][&quot;creator.role&quot;].term !=&quot;&quot;) or (type == &quot;object&quot; and [&quot;creator.role&quot;].term and [&quot;creator.role&quot;].term !=&quot;&quot;)) then 1 else 0 end),&quot;&#39; file.json\r\n\r\nI get this Error:\r\n\r\n    Cannot index array with string &quot;term&quot;\r\n\r\nThe output I want to get in this case is:\r\n\r\n    1,\r\n    0,\r\n    0,\r\n    1,",
        "link": "https://stackoverflow.com/questions/49427529/accessing-field-with-jq-that-contains-a-special-character-and-can-be-an-object-o",
        "title": "Accessing field with jq that contains a special character and can be an object or an array"
    },
    {
        "tags": [
            "json",
            "recursion",
            "jq",
            "fromjson"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1521752575,
                "post_id": 49438164,
                "comment_id": 85878854,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521754984,
                "post_id": 49438164,
                "comment_id": 85879853,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1486150,
                    "reputation": 30132,
                    "user_id": 1394393,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/mSjIL.jpg?s=256",
                    "display_name": "jpmc26",
                    "link": "https://stackoverflow.com/users/1394393/jpmc26"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521757028,
                "post_id": 49438164,
                "comment_id": 85880661,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1521754771,
                "last_edit_date": 1521754771,
                "creation_date": 1521752366,
                "answer_id": 49438359,
                "question_id": 49438164,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; Is there a filter I am missing ...?\r\n\r\nThe filter you&#39;ll need is `fromjson`, but it should only be applied to the stringified JSON; consider therefore using `|=` as illustrated using your fragment:\r\n\r\n    echo &#39;{&quot;achievements&quot;: { &quot;Vales&quot;: &quot;[{\\&quot;id\\&quot;:0,\\&quot;gamePack\\&quot;:\\&quot;GAME.PACK.0.KK\\&quot;,\\&quot;marblesAmount\\&quot;:50}]&quot;}}&#39; | \r\n      jq &#39;.achievements.Vales |= fromjson&#39;\r\n    \r\n    {\r\n      &quot;achievements&quot;: {\r\n        &quot;Vales&quot;: [\r\n          {\r\n            &quot;id&quot;: 0,\r\n            &quot;gamePack&quot;: &quot;GAME.PACK.0.KK&quot;,\r\n            &quot;marblesAmount&quot;: 50\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\n## recursively/1\r\n\r\nIf you want to apply `fromjson` recursively wherever possible, then `recursively` is your friend:\r\n\r\n    def recursively(f):\r\n      . as $in\r\n      | if type == &quot;object&quot; then\r\n          reduce keys[] as $key\r\n            ( {}; . + { ($key):  ($in[$key]  | recursively(f) )} )\r\n      elif type == &quot;array&quot; then map( recursively(f) )\r\n      else try (f as $f | if $f == . then . else ($f | recursively(f)) end) catch $in\r\n      end;\r\n\r\nThis would be applied as follows:\r\n\r\n    recursively(fromjson)\r\n   \r\n### Example\r\n\r\n    {a: ({b: &quot;xyzzy&quot;}) | tojson} | tojson \r\n    | recursively(fromjson)\r\n\r\nyields:\r\n\r\n    {\r\n      &quot;a&quot;: {\r\n        &quot;b&quot;: &quot;xyzzy&quot;\r\n      }\r\n    }\r\n\r\n",
                "title": "Parse JSON and JSON values with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1522387331,
        "creation_date": 1521751645,
        "last_edit_date": 1522387331,
        "question_id": 49438164,
        "body_markdown": "I have an API that returns JSON - big blocks of it.  Some of the key value pairs have more blocks of JSON as the value associated with a key.  jq does a great job of parsing the main JSON levels.  But I can&#39;t find a way to get it to &#39;recurse&#39; into the values associated with the keys and pretty print them as well.  \r\n\r\nHere is the start of one of the JSON returns.  Note it is only a small percent of the full return:\r\n\r\n        {\r\n      &quot;code&quot;: 200,\r\n      &quot;status&quot;: &quot;OK&quot;,\r\n      &quot;data&quot;: {\r\n        &quot;PlayFabId&quot;: &quot;xxxxxxx&quot;,\r\n        &quot;InfoResultPayload&quot;: {\r\n          &quot;AccountInfo&quot;: {\r\n            &quot;PlayFabId&quot;: &quot;xxxxxxxx&quot;,\r\n            &quot;Created&quot;: &quot;2018-03-22T19:23:29.018Z&quot;,\r\n            &quot;TitleInfo&quot;: {\r\n              &quot;Origination&quot;: &quot;IOS&quot;,\r\n              &quot;Created&quot;: &quot;2018-03-22T19:23:29.033Z&quot;,\r\n              &quot;LastLogin&quot;: &quot;2018-03-22T19:23:29.033Z&quot;,\r\n              &quot;FirstLogin&quot;: &quot;2018-03-22T19:23:29.033Z&quot;,\r\n              &quot;isBanned&quot;: false\r\n            },\r\n            &quot;PrivateInfo&quot;: {},\r\n            &quot;IosDeviceInfo&quot;: {\r\n              &quot;IosDeviceId&quot;: &quot;xxxxxxxxx&quot;\r\n            }\r\n          },\r\n          &quot;UserVirtualCurrency&quot;: {\r\n            &quot;GT&quot;: 10,\r\n            &quot;MB&quot;: 70\r\n          },\r\n          &quot;UserVirtualCurrencyRechargeTimes&quot;: {},\r\n          &quot;UserData&quot;: {},\r\n          &quot;UserDataVersion&quot;: 15,\r\n          &quot;UserReadOnlyData&quot;: {\r\n            &quot;DataVersion&quot;: {\r\n              &quot;Value&quot;: &quot;6&quot;,\r\n              &quot;LastUpdated&quot;: &quot;2018-03-22T19:48:59.543Z&quot;,\r\n              &quot;Permission&quot;: &quot;Public&quot;\r\n            },\r\n            &quot;achievements&quot;: {\r\n              &quot;Value&quot;: &quot;[{\\&quot;id\\&quot;:0,\\&quot;gamePack\\&quot;:\\&quot;GAME.PACK.0.KK\\&quot;,\\&quot;marblesAmount\\&quot;:50,\\&quot;achievements\\&quot;:[{\\&quot;id\\&quot;:2,\\&quot;name\\&quot;:\\&quot;Correct Round 4\\&quot;,\\&quot;description\\&quot;:\\&quot;Round 4 answered correctly\\&quot;,\\&quot;maxValue\\&quot;:10,\\&quot;increment\\&quot;:1,\\&quot;currentValue\\&quot;:3,\\&quot;valueUnit\\&quot;:\\&quot;unit\\&quot;,\\&quot;awardOnIncrement\\&quot;:true,\\&quot;marbles\\&quot;:10,\\&quot;image\\&quot;:\\&quot;https://www.jamandcandy.com/kissinkuzzins/achievements/icons/sphinx\\&quot;,\\&quot;SuccessKey\\&quot;:[\\&quot;0_3_4_0\\&quot;,\\&quot;0_5_4_0\\&quot;,\\&quot;0_6_4_0\\&quot;,\\&quot;0_7_4_0\\&quot;,\\&quot;0_8_4_0\\&quot;,\\&quot;0_9_4_0\\&quot;,\\&quot;0_10_4_0\\&quot;],\\&quot;event\\&quot;:\\&quot;Player_answered_round\\&quot;,\\&quot;achieved\\&quot;:false},{\\&quot;id\\&quot;:0,\\&quot;name\\&quot;:\\&quot;Complete\r\nThis was parsed using jq but as you can see when you get to the \r\n\r\n    &quot;achievements&quot;: { &quot;Vales&quot;: &quot;[{\\&quot;id\\&quot;:0,\\&quot;gamePack\\&quot;:\\&quot;GAME.PACK.0.KK\\&quot;,\\&quot;marblesAmount\\&quot;:50,\\\r\nlq does no further parse the value at is also JSON.\r\n\r\nIs there a filter I am missing to get it to parse the values as well as the higher level structure?",
        "link": "https://stackoverflow.com/questions/49438164/parse-json-and-json-values-with-jq",
        "title": "Parse JSON and JSON values with jq"
    },
    {
        "tags": [
            "arrays",
            "maps",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1521759597,
                "creation_date": 1521759597,
                "answer_id": 49439782,
                "question_id": 49439519,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq is Turing-complete, so you&#39;re in luck :-)\r\n\r\nYour requirements aren&#39;t completely clear, but the following produces the output you expect and should get you on your way:\r\n\r\n\r\n    .data.assets |= map(\r\n        .newkey1 = if any(.tags[].value; . == &quot;system&quot;) then &quot;system&quot; else null end\r\n      | .newkey2 = if any(.tags[].value; . == &quot;market&quot;) then &quot;market&quot; else null end \r\n    )\r\n\r\nThe key points here are:\r\n\r\n* `|=` can be used for updates;\r\n* `any(stream; condition)` checks whether the condition is true for any item in the stream\r\n \r\n\r\n",
                "title": "jq json retrieve value from an inner array based on condition and add it outside of array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1521759597,
        "creation_date": 1521758026,
        "question_id": 49439519,
        "body_markdown": "My Input\r\n\r\n    {\r\n\t&quot;data&quot;: {\r\n\t\t&quot;assets&quot;: [{\r\n\t\t\t&quot;aDASD&quot;: &quot;1056bda9-2598-4fdf-bd99-db3924464a75&quot;,\r\n\t\t\t&quot;KEY&quot;: &quot;a7e2ef79-41aa-4a36-9ca1-1f388917eb12.ahnl&quot;,\r\n\t\t\t&quot;key2&quot;: &quot;store-order-picking-units-api&quot;,\r\n\t\t\t&quot;key3&quot;: &quot;1.0.1&quot;,\r\n\t\t\t&quot;tags&quot;: [{\r\n\t\t\t\t\t&quot;value&quot;: &quot;abcd&quot;,\r\n\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;value&quot;: &quot;rest&quot;,\r\n\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;value&quot;: &quot;123&quot;,\r\n\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t}, {\r\n\t\t\t\t\t&quot;value&quot;: &quot;system&quot;,\r\n\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t&quot;mutable&quot;: true\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;value&quot;: &quot;market&quot;,\r\n\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t&quot;mutable&quot;: true\r\n\t\t\t\t}\r\n\t\t\t],\r\n\t\t\t&quot;type&quot;: &quot;mytype&quot;\r\n\t\t}]\r\n\t}\r\n}\r\n\r\n\r\nI would like to have output as below\r\n\r\n    {\r\n\t&quot;data&quot;: {\r\n\t\t&quot;assets&quot;: [{\r\n\t\t\t&quot;aDASD&quot;: &quot;1056bda9-2598-4fdf-bd99-db3924464a75&quot;,\r\n\t\t\t&quot;KEY&quot;: &quot;a7e2ef79-41aa-4a36-9ca1-1f388917eb12.ahnl&quot;,\r\n\t\t\t&quot;key2&quot;: &quot;store-order-picking-units-api&quot;,\r\n\t\t\t&quot;key3&quot;: &quot;1.0.1&quot;,\r\n\t\t\t&quot;tags&quot;: [{\r\n\t\t\t\t\t&quot;value&quot;: &quot;abcd&quot;,\r\n\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;value&quot;: &quot;rest&quot;,\r\n\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;value&quot;: &quot;123&quot;,\r\n\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t}, {\r\n\t\t\t\t\t&quot;value&quot;: &quot;system&quot;,\r\n\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t&quot;mutable&quot;: true\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;value&quot;: &quot;market&quot;,\r\n\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t&quot;mutable&quot;: true\r\n\t\t\t\t}\r\n\t\t\t],\r\n\t\t\t&quot;type&quot;: &quot;mytype&quot;,\r\n            &quot;newkey1&quot;: &quot;system&quot;,\r\n            &quot;newkey2&quot;: &quot;market&quot;\r\n\t\t}]\r\n\t}\r\n}\r\n\r\nresponse contains newkey1 and newkey2. Now here comes the tricky part. When populating newkey1, the values can be &quot;system&quot; &quot;process&quot; etc. and for newkey2, the values can be &quot;market&quot;, &quot;finance&quot; etc..\r\n\r\nIn other words, newkey1 should be populated if any of the `.data.assets[].tags[].values` is system or process etc...similarly newkey2 only if market, finance etc.\r\n\r\nIs it complex or first of all achievable using jq? Please help.",
        "link": "https://stackoverflow.com/questions/49439519/jq-json-retrieve-value-from-an-inner-array-based-on-condition-and-add-it-outside",
        "title": "jq json retrieve value from an inner array based on condition and add it outside of array"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521797793,
                "post_id": 49446308,
                "comment_id": 85894488,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5420834,
                    "reputation": 67,
                    "user_id": 4314495,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/e55152d8f16261b0a3e1ad03bc8fa639?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Akash Khandelwal",
                    "link": "https://stackoverflow.com/users/4314495/akash-khandelwal"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521797940,
                "post_id": 49446308,
                "comment_id": 85894571,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1521798351,
                "creation_date": 1521798351,
                "answer_id": 49446623,
                "question_id": 49446308,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -r &#39;.name as $n | .data[] | [$n, .type, .value] | @csv&#39; file.json\r\nThe output:\r\n\r\n    &quot;a&quot;,&quot;string&quot;,&quot;mykeypair&quot;\r\n    &quot;a&quot;,&quot;int&quot;,123\r\n\r\n\r\n----------\r\nIf it&#39;s mandatory to output unquoted values:\r\n\r\n    jq -r &#39;.name as $n | .data[] | [$n, .type, &quot;\\(.value)&quot;] | join(&quot;,&quot;)&#39; file.json\r\nThe output:\r\n\r\n    a,string,mykeypair\r\n    a,int,123\r\n\r\n",
                "title": "Jq getting output from nested hash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1521798452,
        "creation_date": 1521797425,
        "last_edit_date": 1521798452,
        "question_id": 49446308,
        "body_markdown": "Hi I am trying to parse below hash with jq\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    {\r\n        &quot;name&quot;: &quot;a&quot;,\r\n        &quot;data&quot;: [\r\n        {\r\n            &quot;sensitive&quot;: false,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;value&quot;: &quot;mykeypair&quot;\r\n        },\r\n        {\r\n            &quot;sensitive&quot;: false,\r\n            &quot;type&quot;: &quot;int&quot;,\r\n            &quot;value&quot;: 123\r\n        }\r\n        ]\r\n    }\r\n\r\nand get output like\r\n\r\n&lt;!-- language: lang-none --&gt;\r\n\r\n    a,string,mykeypair\r\n    a,int,123\r\n\r\nI am able to get output like this\r\n\r\n&lt;!-- language: lang-none --&gt;\r\n\r\n    a,string,mykeypair\r\n    a,int,mykeypair\r\n    a,string,123\r\n    a,int,123\r\n",
        "link": "https://stackoverflow.com/questions/49446308/jq-getting-output-from-nested-hash",
        "title": "Jq getting output from nested hash"
    },
    {
        "tags": [
            "json",
            "path",
            "nested",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521802941,
                "post_id": 49448001,
                "comment_id": 85898019,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 12435098,
                    "reputation": 71,
                    "user_id": 9055860,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-Sa2kJs7jyMM/AAAAAAAAAAI/AAAAAAAANGs/ddRYOv78avA/s256-rj/photo.jpg",
                    "display_name": "Александр Королёв",
                    "link": "https://stackoverflow.com/users/9055860/%d0%90%d0%bb%d0%b5%d0%ba%d1%81%d0%b0%d0%bd%d0%b4%d1%80-%d0%9a%d0%be%d1%80%d0%be%d0%bb%d1%91%d0%b2"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521805167,
                "post_id": 49448001,
                "comment_id": 85899400,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1521806349,
                "creation_date": 1521806349,
                "answer_id": 49449206,
                "question_id": 49448001,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -r &#39;. as $o | paths \r\n           | select(length == 3) \r\n           | select($o[.[0]][.[1]][.[2]] == 1) \r\n           | .[0] +&quot;.&quot;+ .[1]&#39; file.json\r\nThe output:\r\n\r\n    schema1.table2\r\n    schema2.table2\r\n\r\n",
                "title": "how to get parent objects keys in nested object in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1521810347,
                "creation_date": 1521810347,
                "answer_id": 49450384,
                "question_id": 49448001,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following uses `to_entries` (twice) to produce the array as requested:\r\n\r\n    [to_entries[]\r\n     |  .key as $k\r\n     | .value | to_entries | map(select(.value.status == 1))[]\r\n     | [$k, .key]\r\n     | join(&quot;.&quot;) ]\r\n\r\n\r\n",
                "title": "how to get parent objects keys in nested object in jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1521812449,
                "last_edit_date": 1521812449,
                "creation_date": 1521811546,
                "answer_id": 49450722,
                "question_id": 49448001,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the input document were so large that it would not fit comfortably in memory, then a solution using jq&#39;s streaming parser would be appropriate.\r\n\r\nTo this end, consider program.jq as follows:\r\n\r\n    select(length==2 and .[-1] == 1 and .[0][-1] == &quot;status&quot;)\r\n    | .[0][:-1]\r\n    | join(&quot;.&quot;)\r\n\r\n(Here `[:-1]` is a compact way of writing `[0:-1]`, which in effect takes all but the last items in an array.)\r\n\r\nThe invocation: `jq --stream -f program.jq input.json`\r\n\r\nwould produce the stream:\r\n\r\n    &quot;schema1.table2&quot;\r\n    &quot;schema2.table2&quot;\r\n\r\nIf an array of values is required, you could pipe this stream into `jq -s .`\r\n\r\nNotice also that program.jq as above actually solves the generic problem in which the nesting can be arbitrarily deep.\r\n",
                "title": "how to get parent objects keys in nested object in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1521822454,
                "last_edit_date": 1521822454,
                "creation_date": 1521821841,
                "answer_id": 49454124,
                "question_id": 49448001,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In this case, you could use `paths(scalars)` (formerly `leaf_paths`) to obtain paths to all the scalar values. With these paths, you could use `getpath/1` to get the value and output the desired strings.\r\n\r\n    paths(scalars) as $p\r\n      | select($p[-1] == &quot;status&quot; and getpath($p) == 1)\r\n      | &quot;\\([$p[1,0]] | join(&quot;.&quot;)) \\(getpath($p))&quot;\r\n\r\n&lt;hr&gt;\r\n\r\nIf you want to get fancy, you can also use streams to get paths and values in one go.\r\n\r\n    tostream as [$p,$v]\r\n      | select($p[-1] == &quot;status&quot; and $v == 1)\r\n      | &quot;\\([$p[1,0]] | join(&quot;.&quot;)) \\($v)&quot;\r\n\r\n&lt;hr&gt;\r\n\r\nBut considering your comment, if you just need the paths, it could all be boiled down to simply:\r\n\r\n    [tostream as [$p,$v]\r\n      | select($p[-1] == &quot;status&quot; and $v == 1)\r\n      | $p[:2] | join(&quot;.&quot;)\r\n    ]",
                "title": "how to get parent objects keys in nested object in jq?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1521915917,
                "creation_date": 1521915917,
                "answer_id": 49468306,
                "question_id": 49448001,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;ve choose such solution\r\n\r\n    path(.[]|.[]|select(.status==1))|join(&quot;.&quot;)\r\n\r\n ",
                "title": "how to get parent objects keys in nested object in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 2,
        "last_activity_date": 1521915917,
        "creation_date": 1521802359,
        "last_edit_date": 1521911140,
        "question_id": 49448001,
        "body_markdown": "I have JSON with nested objects\r\n\r\n    {\r\n     &quot;schema1&quot;: {\r\n        &quot;table1&quot;: {\r\n            &quot;status&quot;: 0\r\n        },\r\n        &quot;table2&quot;: {\r\n            &quot;status&quot;: 1\r\n        }\r\n     },\r\n     &quot;schema2&quot;: {\r\n        &quot;table1&quot;: {\r\n            &quot;status&quot;: 0\r\n        },\r\n        &quot;table2&quot;: {\r\n            &quot;status&quot;: 1\r\n        }\r\n     }\r\n    }\r\n\r\nI need in list of schema.table filtered by status==1.\r\nMy first approach is\r\n\r\n    .[]|.[]|(select(.status==1))|&quot;table.schema  \\(.status)&quot;\r\n\r\nHow to replace table.schema with appropriated keys of parent objects?\r\n\r\n[Here is jq play with example][1]\r\n\r\nThe expected result is:\r\n\r\n    [ &quot;schema1.table2&quot;, &quot;schema2.table2&quot; ]\r\n\r\n  [1]: https://jqplay.org/s/2sNgnu-__L",
        "link": "https://stackoverflow.com/questions/49448001/how-to-get-parent-objects-keys-in-nested-object-in-jq",
        "title": "how to get parent objects keys in nested object in jq?"
    },
    {
        "tags": [
            "arrays",
            "jq",
            "flatten"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12550010,
                    "reputation": 7963,
                    "user_id": 9132049,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://lh4.googleusercontent.com/-s4THmh4Z9p4/AAAAAAAAAAI/AAAAAAAAAJY/MEXx5ikQuWk/s256-rj/photo.jpg",
                    "display_name": "Luis felipe De jesus Munoz",
                    "link": "https://stackoverflow.com/users/9132049/luis-felipe-de-jesus-munoz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521825121,
                "post_id": 49455052,
                "comment_id": 85912994,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1521826479,
                "post_id": 49455052,
                "comment_id": 85913726,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1521996719,
                "last_edit_date": 1521996719,
                "creation_date": 1521826822,
                "answer_id": 49455512,
                "question_id": 49455052,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following seems to meet the descriptive requirements:\r\n\r\n    .data.assets |=\r\n      map( if any(.tags[].value; . == &quot;sourcing&quot;)\r\n           then . + {&quot;domain&quot;:&quot;sourcing&quot;}\r\n           else .\r\n           end )\r\n\r\nThis produces the desired output except for the key-value pair `&quot;domain&quot;: &quot;supply-chain&quot;` that is inconsistent with the descriptive requirements.\r\n\r\n\r\n\r\nThe following, by contrast, takes its cue from (that is, produces) the given output:\r\n\r\n    .data.assets |=\r\n      map( if any(.tags[].value; . == &quot;sourcing&quot;) then . + {&quot;domain&quot;:&quot;sourcing&quot;}\r\n           elif any(.tags[].value; . == &quot;supply-chain&quot;) then . + {&quot;domain&quot;:&quot;supply-chain&quot;}\r\n           else . end )\r\n\r\n### Setting &quot;domain&quot; to all the tag values\r\n\r\n    .data.assets |= map( .domain += [.tags[].value] )",
                "title": "jq inner array value as new key outside the array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1521996719,
        "creation_date": 1521824894,
        "question_id": 49455052,
        "body_markdown": "Input:\r\n\r\n    {\r\n\t&quot;data&quot;: {\r\n\t\t&quot;assets&quot;: [{\r\n\t\t\t\t&quot;organizationId&quot;: &quot;1056bda9-2598-4fdf-bd99-db3924464a75&quot;,\r\n\t\t\t\t&quot;createdAt&quot;: &quot;2018-03-14T14:41:41.154Z&quot;,\r\n\t\t\t\t&quot;tags&quot;: [{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;raml&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;rest&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;api&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;v1&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: &quot;product-api-version&quot;,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;has-mule4-connector&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;has-mule3-connector&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;system&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: true\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;sourcing&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: true\r\n\t\t\t\t\t}\r\n\t\t\t\t],\r\n\t\t\t\t&quot;type&quot;: &quot;rest-api&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n                &quot;organizationId&quot;: &quot;SASAAs&quot;,\r\n\t\t\t\t&quot;createdAt&quot;: &quot;2018-03-14T14:41:41.154Z&quot;,\r\n\t\t\t\t&quot;tags&quot;: [{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;raml&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;rest&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;api&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;v1&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: &quot;product-api-version&quot;,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;has-mule4-connector&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;has-mule3-connector&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;system&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: true\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;supply-chain&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: true\r\n\t\t\t\t\t}\r\n\t\t\t\t],\r\n\t\t\t\t&quot;type&quot;: &quot;rest-api&quot;\r\n\t\t\t}   \r\n\t\t]\r\n\t}\r\n}\r\n\r\n\r\nExpected output:\r\n\r\n    {\r\n\t&quot;data&quot;: {\r\n\t\t&quot;assets&quot;: [{\r\n\t\t\t\t&quot;organizationId&quot;: &quot;1056bda9-2598-4fdf-bd99-db3924464a75&quot;,\r\n\t\t\t\t&quot;createdAt&quot;: &quot;2018-03-14T14:41:41.154Z&quot;,\r\n\t\t\t\t&quot;tags&quot;: [{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;raml&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;rest&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;api&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;v1&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: &quot;product-api-version&quot;,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;has-mule4-connector&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;has-mule3-connector&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;system&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: true\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;sourcing&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: true\r\n\t\t\t\t\t}\r\n\t\t\t\t],\r\n\t\t\t\t&quot;type&quot;: &quot;rest-api&quot;,\r\n                &quot;domain&quot;: &quot;sourcing&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n                &quot;organizationId&quot;: &quot;SASAAs&quot;,\r\n\t\t\t\t&quot;createdAt&quot;: &quot;2018-03-14T14:41:41.154Z&quot;,\r\n\t\t\t\t&quot;tags&quot;: [{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;raml&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;rest&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;api&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;v1&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: &quot;product-api-version&quot;,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;has-mule4-connector&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;has-mule3-connector&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: false\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;system&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: true\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;value&quot;: &quot;supply-chain&quot;,\r\n\t\t\t\t\t\t&quot;key&quot;: null,\r\n\t\t\t\t\t\t&quot;mutable&quot;: true\r\n\t\t\t\t\t}\r\n\t\t\t\t],\r\n\t\t\t\t&quot;type&quot;: &quot;rest-api&quot;,\r\n                &quot;domain&quot;: &quot;supply-chain&quot;\r\n\t\t\t}   \r\n\t\t]\r\n\t}\r\n}\r\n\r\n\r\nSO far, I tried this which worked partially for me.\r\n\r\n**.data.assets[] | select (.tags[].value==&quot;sourcing&quot;) | . += {&quot;domain&quot;:&quot;sourcing&quot;}**\r\n\r\nThe problem is that I want this condition to apply for every object inside the array but I&#39;m not able to do that. It is getting applied to the first object only.\r\n\r\nWhere am i doing wrong? Any suggestions please?\r\n",
        "link": "https://stackoverflow.com/questions/49455052/jq-inner-array-value-as-new-key-outside-the-array",
        "title": "jq inner array value as new key outside the array"
    },
    {
        "tags": [
            "json",
            "string",
            "decimal",
            "jq",
            "scientific-notation"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522107213,
                "post_id": 49502120,
                "comment_id": 86008494,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1606089264,
                "last_edit_date": 1606089264,
                "creation_date": 1522124500,
                "answer_id": 49504320,
                "question_id": 49502120,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unfortunately there is currently no way in jq to modify the representation of JSON numbers as such; the best one can do is modify their representation as strings.  Here is a simple illustration of what can be done.\r\n\r\n`to_decimal` takes as input a JSON number (or a valid JSON string representation of a number, possibly with a leading &quot;+&quot;) as input, and converts it into a suitable string, e.g.:\r\n```\r\n[&quot;0&quot;,&quot;1&quot;,&quot;-1&quot;,&quot;123&quot;,&quot;-123&quot;,&quot;.00000123&quot;,&quot;1230000&quot;,&quot;-.00000123&quot;,&quot;-0.123&quot;,&quot;0.123&quot;,&quot;0.001&quot;]\r\n\r\n```\r\nproduces:\r\n``` \r\n[0,&quot;0&quot;]\r\n[&quot;+1&quot;,&quot;1&quot;]\r\n[-1,&quot;-1&quot;]\r\n[123,&quot;123&quot;]\r\n[-123,&quot;-123&quot;]\r\n[1.23e-06,&quot;.00000123&quot;]\r\n[1230000,&quot;1230000&quot;]\r\n[-1.23e-06,&quot;-.00000123&quot;]\r\n[-0.123,&quot;-0.123&quot;]\r\n[0.123,&quot;0.123&quot;]\r\n[0.001,&quot;0.001&quot;]\r\n\r\n``` \r\nNotice that any leading &quot;+&quot; is dropped.\r\n\r\n### to_decimal\r\n```\r\ndef to_decimal:\r\n  def rpad(n): if (n &gt; length) then . + ((n - length) * &quot;0&quot;) else . end;\r\n  def lpad(n): if (n &gt; length) then ((n - length) * &quot;0&quot;) + . else . end;\r\n\r\n  tostring\r\n  | . as $s\r\n  | capture( &quot;(?&lt;sgn&gt;[+-]?)(?&lt;left&gt;[0-9]*)(?&lt;p&gt;\\\\.?)(?&lt;right&gt;[0-9]*)(?&lt;e&gt;[Ee]?)(?&lt;exp&gt;[+-]?[0-9]+)&quot; )\r\n  | if .e == &quot;&quot; then (if .sgn == &quot;+&quot; then $s[1:] else $s end)\r\n    else (.left|length) as $len\r\n    | (.exp|tonumber) as $exp\r\n    | (if .sgn == &quot;-&quot; then &quot;-&quot; else &quot;&quot; end ) as $sgn\r\n    | if $exp &lt; 0 then &quot;.&quot; + (.left | lpad(1 - $exp - $len)) + .right\r\n      else (.left | rpad($exp - $len)) + &quot;.&quot; + .right\r\n      end\r\n      | $sgn + .\r\n    end ;\r\n```\r\n\r\n\r\n",
                "title": "In jq, how to get tonumber to output decimal instead of scientific notation"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1606089264,
        "creation_date": 1522106446,
        "last_edit_date": 1522535898,
        "question_id": 49502120,
        "body_markdown": "In a JSON object, given the string `&quot;0.0000086900&quot;` as the value of a key-value pair, if I do `|tonumber` on this, `8.69e-06` gets returned.\r\n\r\nHow can I ensure that only decimals are ever returned?\r\nIn the case above, this would be `0.0000086900`\r\n\r\n**SOLUTION (based on Peak&#39;s code snippet below)**\r\n\r\n    def to_decimal:\r\n      def rpad(n): if (n &gt; length) then . + ((n - length) * &quot;0&quot;) else . end;\r\n      def lpad(n): if (n &gt; length) then ((n - length) * &quot;0&quot;) + . else . end;\r\n\r\n    tostring\r\n      | . as $s\r\n      | [match( &quot;(?&lt;sgn&gt;[+-]?)(?&lt;left&gt;[0-9]*)(?&lt;p&gt;\\\\.?)(?&lt;right&gt;[0-9]*)(?&lt;e&gt;[Ee]?)(?&lt;exp&gt;[+-]?[0-9]+)&quot; )\r\n          .captures[].string] as [$sgn, $left, $p, $right, $e, $exp]\r\n      | if $e == &quot;&quot; then .\r\n        else ($exp|tonumber) as $exp\r\n        | ($left|length) as $len\r\n        | if $exp &lt; 0 then &quot;0.&quot; + ($left | lpad(1 - $exp - $len)) + $right\r\n          else ($left | rpad($exp - $len)) + &quot;.&quot; + $right\r\n          end\r\n          | $sgn + .\r\n        end;",
        "link": "https://stackoverflow.com/questions/49502120/in-jq-how-to-get-tonumber-to-output-decimal-instead-of-scientific-notation",
        "title": "In jq, how to get tonumber to output decimal instead of scientific notation"
    },
    {
        "tags": [
            "json",
            "path",
            "edit",
            "reduce",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522159386,
                "post_id": 49514084,
                "comment_id": 86034841,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 39429,
                    "reputation": 1959,
                    "user_id": 113705,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/ea06c92a5109f7ff2e9175328ff14a3a?s=256&d=identicon&r=PG",
                    "display_name": "Stewart",
                    "link": "https://stackoverflow.com/users/113705/stewart"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522160174,
                "post_id": 49514084,
                "comment_id": 86035483,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1522221223,
                "last_edit_date": 1522221223,
                "creation_date": 1522161826,
                "answer_id": 49515961,
                "question_id": 49514084,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    .dependencies |= with_entries(\r\n      if .key|test(&quot;^acme-&quot;) then .value = &quot;mytagname&quot; else . end )\r\n\r\nOne could also use &#39;startswith&#39;. It might be appropriate to use &#39;walk&#39;.\r\n\r\nTo use &#39;setpath&#39;, one could use &#39;reduce&#39; (e.g. with &#39;paths&#39;), e.g.:\r\n\r\n    reduce paths as $p (.;\r\n      if $p[-1] | test(&quot;^acme-&quot;) then setpath($p; &quot;mytagname&quot;) else . end)",
                "title": "How do I set multiple path values in jq at once?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1522221223,
        "creation_date": 1522157018,
        "last_edit_date": 1522162512,
        "question_id": 49514084,
        "body_markdown": "I have figured out how to set a value in my JSON file, package.json, using `setpath`. Can I do this using a pattern?\r\n\r\n    cat package.json | jq &#39;setpath([&quot;dependencies&quot;, &quot;acme-a&quot;]; &quot;mytagname&quot;)&#39;\r\n\r\nWhat I would like to do is use a pattern like the following so it also sets the paths at &quot;acme-b&quot;, &quot;acme-c&quot;, and so on:\r\n\r\n    cat package.json | jq &#39;setpath([&quot;dependencies&quot;, &quot;acme-*&quot;]; &quot;mytagname&quot;)&#39;\r\n\r\nDoes jq support that, and if so, how is it accomplished?",
        "link": "https://stackoverflow.com/questions/49514084/how-do-i-set-multiple-path-values-in-jq-at-once",
        "title": "How do I set multiple path values in jq at once?"
    },
    {
        "tags": [
            "jq",
            "mc"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1527152854,
                "last_edit_date": 1527152854,
                "creation_date": 1522231799,
                "answer_id": 49531735,
                "question_id": 49531563,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Two minutes after I submitted my question I&#39;ve been revealed.\r\n\r\nI thought that maybe `jq` does not produce standard output... It led me to this question: [How to use `jq` in a shell pipeline?](https://stackoverflow.com/questions/33247228/how-to-use-jq-in-a-shell-pipeline) and so I have modified the extension file to look like:\r\n\r\n    # json\r\n    regex/\\.json$\r\n        View=%view{ascii} jq &#39;.&#39; &lt; %f\r\n\r\nAnd now it works as expected, piping result of `jq` to the internal `mc` viewer.\r\n\r\nThank you, me ;)",
                "title": "View JSON file in Midnight Commander using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1615472070,
                "creation_date": 1615472070,
                "answer_id": 66584291,
                "question_id": 49531563,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t have to use redirection **&lt;** here, you could use just a plain filename **%f**:\r\n\r\n```json\r\n# json\r\nregex/\\.json$\r\n    View=%view{ascii} jq &#39;.&#39; %f\r\n```\r\n\r\nand as you [mentioned][1] you have to use a simple filter: **.**\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/49531735/1832863",
                "title": "View JSON file in Midnight Commander using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1675539258,
                "creation_date": 1675539258,
                "answer_id": 75347822,
                "question_id": 49531563,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For anyone wondering, why this no longer works. In version 4.8.29, MC switched from `mc.ext` to the new `mc.ext.ini` ini file, which has slightly different syntax. The new entry should look like this\r\n```\r\n[JSON]\r\nRegex=\\.json$\r\nView=%view{ascii} jq &#39;.&#39; &lt; %f\r\n```\r\nThe `[JSON]` line is necessary.",
                "title": "View JSON file in Midnight Commander using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1675539258,
        "creation_date": 1522231246,
        "question_id": 49531563,
        "body_markdown": "So there is that awesome tool for working with JSON data called [jq](https://stedolan.github.io/jq/).\r\n\r\nAnd there is that awesome linux file manager called [mc](https://midnight-commander.org/).\r\n\r\nOne day (today) I came around an idea to integrate these two, so I could easily preview JSON files in a pretty/formatted way using F3 keyboard shortcut when in Midnight Commander.\r\n\r\nI opened MC extension file using `Command` → `Edit extension file` menu actions and then added following to such opened configuration file:\r\n\r\n    # json\r\n    regex/\\.json$\r\n       View=%view{ascii} jq &lt; %f\r\n\r\nI thought it is straightforward, but unexpectedly it does not work: trying to view the JSON (F3) results in error popup with contents of `jq`&#39;s help page (the same as when you type `jq` by itself), so starting with: &quot;*jq - commandline JSON processr [version 1.5]...*&quot;\r\n\r\nCan anybody tell me why this configuration is incorrect?",
        "link": "https://stackoverflow.com/questions/49531563/view-json-file-in-midnight-commander-using-jq",
        "title": "View JSON file in Midnight Commander using jq"
    },
    {
        "tags": [
            "json",
            "bigdata",
            "jq",
            "stream-processing"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522240807,
                "post_id": 49531722,
                "comment_id": 86075913,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1522259626,
                "last_edit_date": 1522259626,
                "creation_date": 1522258258,
                "answer_id": 49540776,
                "question_id": 49531722,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If your input file consists of a single very large JSON entity that is too big for the regular jq parser to handle in your environment, then there is the distinct possibility that you won&#39;t have enough memory to reconstitute the JSON document.\r\n\r\nWith that caveat, the following may be worth a try. The key insight is that reconstruction can be accomplished using `reduce`.\r\n\r\nThe following uses a bunch of temporary files for the sake of clarity:\r\n\r\n    TMP=/tmp/$$\r\n    \r\n    jq -c --stream &#39;select(length==2)&#39; input.json &gt; $TMP.streamed\r\n    \r\n    jq -c &#39;select(.[0][0] != &quot;filter_this&quot;)&#39; $TMP.streamed &gt; $TMP.1\r\n    \r\n    jq -c &#39;select(.[0][0] == &quot;filter_this&quot;)&#39; $TMP.streamed |\r\n      jq -nc &#39;reduce inputs as [$p,$x] (null; setpath($p;$x))\r\n              | .filter_this |= map(select(.keep==&quot;true&quot;))\r\n              | tostream\r\n              | select(length==2)&#39; &gt; $TMP.2\r\n    \r\n    # Reconstruction\r\n    jq -n &#39;reduce inputs as [$p,$x] (null; setpath($p;$x))&#39; $TMP.1 $TMP.2\r\n\r\n## Output\r\n\r\n    {\r\n      &quot;keep_untouched&quot;: {\r\n        &quot;keep_this&quot;: [\r\n          &quot;this&quot;,\r\n          &quot;list&quot;\r\n        ]\r\n      },\r\n      &quot;filter_this&quot;: [\r\n        {\r\n          &quot;keep&quot;: &quot;true&quot;\r\n        },\r\n        {\r\n          &quot;keep&quot;: &quot;true&quot;,\r\n          &quot;extra&quot;: &quot;keeper&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "jq streaming - filter nested list and retain global structure"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1522348605,
                "last_edit_date": 1522348605,
                "creation_date": 1522341131,
                "answer_id": 49561029,
                "question_id": 49531722,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Many thanks to @peak. I found his approach really useful, but unrealistic in terms of performance. Stealing some of @peak&#39;s ideas, though, I came up with the following:\r\n\r\nExtract the &#39;parent&#39; object:\r\n    \r\n    jq -c --stream &#39;select(length==2)&#39; input.json | \r\n      jq -c &#39;select(.[0][0] != &quot;filter_this&quot;)&#39;  | \r\n      jq -n &#39;reduce inputs as [$p,$x] (null; setpath($p;$x))&#39; &gt; $TMP.parent\r\n\r\nExtract the &#39;keepers&#39; - though this means reading the file twice (:-&lt;):\r\n\r\n    jq -nc --stream &#39;[fromstream(2|truncate_stream(inputs))\r\n                      | select(type == &quot;object&quot; and .keep == &quot;true&quot;)]             \r\n                    &#39; input.json &gt; $TMP.keepers\r\n\r\nInsert the filtered list into the parent object. \r\n\r\n    jq -nc -s &#39;inputs as $items\r\n               | $items[0] as $parent\r\n               | $parent\r\n               | .filter_this |= $items[1]\r\n              &#39;  $TMP.parent $TMP.keepers &gt; result.json",
                "title": "jq streaming - filter nested list and retain global structure"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1538013315,
                "last_edit_date": 1538013315,
                "creation_date": 1522362630,
                "answer_id": 49565968,
                "question_id": 49531722,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a simplified version of @PeteC&#39;s script. It requires one fewer invocations of jq.\r\n\r\nIn both cases, please note that the invocation of jq that uses &quot;2|truncate_stream(_)&quot; requires a more recent version of jq than 1.5.\r\n\r\n    TMP=/tmp/$$\r\n    \r\n    INPUT=input.json\r\n    \r\n    # Extract all but .filter_this\r\n    &lt; $INPUT jq -c --stream &#39;select(length==2 and .[0][0] != &quot;filter_this&quot;)&#39; |\r\n        jq -nc &#39;reduce inputs as [$p,$x] (null; setpath($p;$x))\r\n               &#39; &gt; $TMP.parent\r\n    \r\n    # Need jq &gt; 1.5\r\n    # Extract the &#39;keepers&#39;\r\n    &lt; $INPUT jq -n -c --stream &#39;\r\n      [fromstream(2|truncate_stream(inputs))\r\n       | select(type == &quot;object&quot; and .keep == &quot;true&quot;)]\r\n      &#39; $INPUT &gt; $TMP.keepers\r\n    \r\n    # Insert the filtered list into the parent object:\r\n    jq -s &#39;. as $in | .[0] | (.filter_this |= $in[1])\r\n          &#39; $TMP.parent $TMP.keepers &gt; result.json\r\n\r\n",
                "title": "jq streaming - filter nested list and retain global structure"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 5,
        "last_activity_date": 1538013315,
        "creation_date": 1522231754,
        "last_edit_date": 1522258904,
        "question_id": 49531722,
        "body_markdown": "In a large json file, I want to remove some elements from a nested list, but keep the overall structure of the document. \r\n\r\nMy example input it this (but the real one is large enough to demand streaming).\r\n\r\n    {\r\n      &quot;keep_untouched&quot;: {\r\n        &quot;keep_this&quot;: [\r\n          &quot;this&quot;,\r\n          &quot;list&quot;\r\n        ]\r\n      },\r\n      &quot;filter_this&quot;:\r\n      [\r\n        {&quot;keep&quot; : &quot;true&quot;},\r\n        {\r\n          &quot;keep&quot;: &quot;true&quot;,\r\n          &quot;extra&quot;: &quot;keeper&quot;\r\n        } ,\r\n        {\r\n          &quot;keep&quot;: &quot;false&quot;,\r\n          &quot;extra&quot;: &quot;non-keeper&quot;\r\n        }\r\n      ]\r\n    }\r\n \r\n\r\nThe required output just has one element of the &#39;filter_this&#39; block removed: \r\n\r\n    {\r\n      &quot;keep_untouched&quot;: {\r\n        &quot;keep_this&quot;: [\r\n          &quot;this&quot;,\r\n          &quot;list&quot;\r\n        ]\r\n      },\r\n      &quot;filter_this&quot;:\r\n      [\r\n        {&quot;keep&quot; : &quot;true&quot;},\r\n        {\r\n          &quot;keep&quot;: &quot;true&quot;,\r\n          &quot;extra&quot;: &quot;keeper&quot;\r\n        } ,\r\n      ]\r\n    }\r\n\r\nThe standard way to handle such cases appears to be using &#39;truncate_stream&#39; to reconstitute streamed objects, before filtering those in the usual jq way. Specifically, the command: \r\n\r\n    jq -nc --stream &#39;fromstream(1|truncate_stream(inputs))&#39; \r\n\r\ngives access to a stream of objects: \r\n\r\n    {&quot;keep_this&quot;:[&quot;this&quot;,&quot;list&quot;]}\r\n    [{&quot;keep&quot;:&quot;true&quot;},{&quot;keep&quot;:&quot;true&quot;,&quot;extra&quot;:&quot;keeper&quot;}, \r\n     {&quot;keep&quot;:&quot;false&quot;,&quot;extra&quot;:&quot;non-keeper&quot;}]\r\n\r\nat which point it is easy to filter for the required objects. However, this strips the results from the context of their parent object, which is not what I want. \r\n\r\nLooking at the streaming structure: \r\n\r\n    [[&quot;keep_untouched&quot;,&quot;keep_this&quot;,0],&quot;this&quot;]\r\n    [[&quot;keep_untouched&quot;,&quot;keep_this&quot;,1],&quot;list&quot;]\r\n    [[&quot;keep_untouched&quot;,&quot;keep_this&quot;,1]]\r\n    [[&quot;keep_untouched&quot;,&quot;keep_this&quot;]]\r\n    [[&quot;filter_this&quot;,0,&quot;keep&quot;],&quot;true&quot;]\r\n    [[&quot;filter_this&quot;,0,&quot;keep&quot;]]\r\n    [[&quot;filter_this&quot;,1,&quot;keep&quot;],&quot;true&quot;]\r\n    [[&quot;filter_this&quot;,1,&quot;extra&quot;],&quot;keeper&quot;]\r\n    [[&quot;filter_this&quot;,1,&quot;extra&quot;]]\r\n    [[&quot;filter_this&quot;,2,&quot;keep&quot;],&quot;false&quot;]\r\n    [[&quot;filter_this&quot;,2,&quot;extra&quot;],&quot;non-keeper&quot;]\r\n    [[&quot;filter_this&quot;,2,&quot;extra&quot;]]\r\n    [[&quot;filter_this&quot;,2]]\r\n    [[&quot;filter_this&quot;]]\r\n\r\nit seems I need to select all the &#39;filter_this&#39; rows, truncate those rows only (using &#39;truncate_stream&#39;), rebuild these rows as objects (using &#39;from_stream&#39;), filter them, and turn the objects back into the stream data format (using &#39;tostream&#39;) to join the stream of &#39;keep untouched&#39; rows, which are still in the streaming format. At that point it would be possible to re-build the whole json. If that is the right approach - which seems overly converluted to me - how do I do that? Or is there a better way? \r\n",
        "link": "https://stackoverflow.com/questions/49531722/jq-streaming-filter-nested-list-and-retain-global-structure",
        "title": "jq streaming - filter nested list and retain global structure"
    },
    {
        "tags": [
            "json",
            "recursion",
            "key",
            "yaml",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1522292879,
                "last_edit_date": 1522292879,
                "creation_date": 1522265562,
                "answer_id": 49542738,
                "question_id": 49541634,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;s not clear to me whether the YAML that you gave is just a &quot;view&quot; of your JSON or whether you actually want to start with YAML. If your document really is YAML, then one approach would be to use a tool\r\n(such as yaml2json or [yq][1]) to convert the yaml to JSON, and then run jq\r\nas shown below; another would be to use jq as a text-processor,\r\nbut in that case you could just as well use awk.\r\n\r\n    yaml2json input.yaml |\r\n      jq -c &#39;[.. | objects | to_entries[] \r\n              | select(.value | has(&quot;description&quot;)?) | .key]&#39;\r\n\r\n### Output\r\n    [&quot;normal&quot;,&quot;one&quot;,&quot;two&quot;]\r\n\r\n## Streaming parser\r\nThis type of problem is also well-suited to jq&#39;s streaming parser, which is especially handy when dealing with very large JSON texts.  Using `jq --stream`, a suitable jq filter would be:\r\n\r\n    [select(length==2) | .[0] | select(.[-1] == &quot;description&quot;) | .[-2]] \r\n\r\nThe ordering of the results will depend on the ordering of the keys produced by the YAML-to-JSON conversion tool.\r\n\r\n\r\n  [1]: https://github.com/kislyuk/yq",
                "title": "Use jq to recursively select key names of an object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1522292879,
        "creation_date": 1522261553,
        "last_edit_date": 1522270947,
        "question_id": 49541634,
        "body_markdown": "I have a JSON document that looks like:\r\n\r\n    simple: 42\r\n    \r\n    normal:\r\n      description: &quot;NORMAL&quot;\r\n    \r\n    combo:\r\n      one:\r\n        description: &quot;ONE&quot;\r\n      two:\r\n        description: &quot;TWO&quot;\r\n      arbitrary:\r\n        foo: 42\r\n\r\nI want to use a `jq` expression to generate the following:\r\n\r\n    [&quot;normal&quot;, &quot;one&quot;, &quot;two&quot;]\r\n\r\nThe condition to select the key is that its corresponding value is an `object` type that has a key `description`. In this case, keys `simple` and `arbitrary` don&#39;t qualify.\r\n\r\nI&#39;m having a hard time to craft the filter. Looked into `with_entries` and `recurse/2` but can&#39;t solve it myself.\r\n\r\nTIA.",
        "link": "https://stackoverflow.com/questions/49541634/use-jq-to-recursively-select-key-names-of-an-object",
        "title": "Use jq to recursively select key names of an object"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522915495,
                "post_id": 49542398,
                "comment_id": 86344152,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1522915402,
                "creation_date": 1522915402,
                "answer_id": 49667151,
                "question_id": 49542398,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you want to form a subarray of items satisfying some condition, just add map(select( CONDITION )) to the pipeline, e.g.\r\n\r\n    .module | .data | keys | map(select(test(&quot;^orderTotal_&quot;)))\r\n\r\nIf you just want a stream of the items matching the condition, then you could first form the stream, and then make the selection:\r\n\r\n    .module | .data | keys[] | select(test(&quot;^orderTotal_&quot;))\r\n\r\nFor efficiency and other reasons, you might want to consider using `keys_unsorted` instead of `keys`.\r\n",
                "title": "How to get a json key that contains a specific string with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1522917645,
        "creation_date": 1522264259,
        "last_edit_date": 1522917645,
        "question_id": 49542398,
        "body_markdown": "I have a json data like this:\r\n\r\n    {\r\n      &quot;success&quot;: true,\r\n      &quot;module&quot;: {\r\n        &quot;endpoint&quot;: {\r\n          &quot;mode&quot;: &quot;pc&quot;,\r\n          &quot;protocolVersion&quot;: &quot;2.0&quot;\r\n        },\r\n        &quot;reload&quot;: true,\r\n        &quot;data&quot;: {\r\n          &quot;leftContainer_CL&quot;: {\r\n            &quot;id&quot;: &quot;CL&quot;,\r\n            &quot;tag&quot;: &quot;leftContainer&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;css&quot;: {\r\n                &quot;floatPosition&quot;: &quot;left&quot;,\r\n                &quot;width&quot;: &quot;788px&quot;\r\n              },\r\n              &quot;tag&quot;: &quot;leftContainer&quot;\r\n            },\r\n            &quot;type&quot;: &quot;container&quot;\r\n          },\r\n          &quot;container_C&quot;: {\r\n            &quot;id&quot;: &quot;C&quot;,\r\n            &quot;tag&quot;: &quot;container&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;css&quot;: {\r\n                &quot;marginTop&quot;: &quot;12px&quot;\r\n              },\r\n              &quot;tag&quot;: &quot;container&quot;\r\n            },\r\n            &quot;type&quot;: &quot;container&quot;\r\n          },\r\n          &quot;delivery_dfdaf8a8a&quot;: {\r\n            &quot;id&quot;: &quot;dfdaf8a8a&quot;,\r\n            &quot;tag&quot;: &quot;delivery&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;selectPos&quot;: &quot;right&quot;,\r\n              &quot;deliveryBy&quot;: {\r\n                &quot;text&quot;: &quot;Disediakan oleh&quot;,\r\n                &quot;poster&quot;: &quot;ALL ITEM STORE&quot;\r\n              },\r\n              &quot;options&quot;: [\r\n                {\r\n                  &quot;highlight&quot;: false,\r\n                  &quot;deliveryId&quot;: &quot;STANDARD&quot;,\r\n                  &quot;bgColor&quot;: &quot;#fafafa&quot;,\r\n                  &quot;price&quot;: &quot;Rp18.900&quot;,\r\n                  &quot;disable&quot;: false,\r\n                  &quot;reachTime&quot;: &quot;Dapatkan pada\\n 3-4 Apr 2018&quot;,\r\n                  &quot;liveUp&quot;: false,\r\n                  &quot;selected&quot;: true\r\n                }\r\n              ],\r\n              &quot;style&quot;: &quot;bar&quot;\r\n            },\r\n            &quot;type&quot;: &quot;biz&quot;\r\n          },\r\n          &quot;rightContainer_CR&quot;: {\r\n            &quot;id&quot;: &quot;CR&quot;,\r\n            &quot;tag&quot;: &quot;rightContainer&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;css&quot;: {\r\n                &quot;floatPosition&quot;: &quot;right&quot;,\r\n                &quot;width&quot;: &quot;388px&quot;\r\n              },\r\n              &quot;tag&quot;: &quot;rightContainer&quot;\r\n            },\r\n            &quot;type&quot;: &quot;container&quot;\r\n          },\r\n          &quot;delivery_d43597338a&quot;: {\r\n            &quot;id&quot;: &quot;d43597338a&quot;,\r\n            &quot;tag&quot;: &quot;delivery&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;selectPos&quot;: &quot;right&quot;,\r\n              &quot;deliveryBy&quot;: {\r\n                &quot;text&quot;: &quot;Disediakan oleh&quot;,\r\n                &quot;poster&quot;: &quot;incredible accessories hp&quot;\r\n              },\r\n              &quot;options&quot;: [\r\n                {\r\n                  &quot;highlight&quot;: false,\r\n                  &quot;deliveryId&quot;: &quot;STANDARD&quot;,\r\n                  &quot;bgColor&quot;: &quot;#fafafa&quot;,\r\n                  &quot;price&quot;: &quot;Rp37.800&quot;,\r\n                  &quot;disable&quot;: false,\r\n                  &quot;reachTime&quot;: &quot;Dapatkan pada\\n 3-4 Apr 2018&quot;,\r\n                  &quot;liveUp&quot;: false,\r\n                  &quot;selected&quot;: true\r\n                }\r\n              ],\r\n              &quot;style&quot;: &quot;bar&quot;\r\n            },\r\n            &quot;type&quot;: &quot;biz&quot;\r\n          },\r\n          &quot;orderSummary_6&quot;: {\r\n            &quot;id&quot;: &quot;6&quot;,\r\n            &quot;tag&quot;: &quot;orderSummary&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;isOpen&quot;: &quot;false&quot;,\r\n              &quot;summarys&quot;: [\r\n                {\r\n                  &quot;tail&quot;: &quot;(3 barang)&quot;,\r\n                  &quot;title&quot;: &quot;Subtotal&quot;,\r\n                  &quot;value&quot;: &quot;Rp23.557&quot;\r\n                },\r\n                {\r\n                  &quot;title&quot;: &quot;Biaya pengiriman&quot;,\r\n                  &quot;value&quot;: &quot;Rp56.700&quot;\r\n                }\r\n              ],\r\n              &quot;title&quot;: &quot;Ringkasan Pesanan\\r\\n&quot;\r\n            },\r\n            &quot;type&quot;: &quot;biz&quot;\r\n          },\r\n          &quot;root_0&quot;: {\r\n            &quot;id&quot;: &quot;0&quot;,\r\n            &quot;tag&quot;: &quot;root&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;count&quot;: 3,\r\n              &quot;title&quot;: &quot;Troli belanja Saya&quot;\r\n            },\r\n            &quot;type&quot;: &quot;root&quot;\r\n          },\r\n          &quot;item_i77997d6b&quot;: {\r\n            &quot;id&quot;: &quot;i77997d6b&quot;,\r\n            &quot;tag&quot;: &quot;item&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;img&quot;: &quot;https://id-live.slatic.net/original/08c1396908dc240625751b09decb4211.jpg&quot;,\r\n              &quot;quantity&quot;: {\r\n                &quot;qtyPrefix&quot;: &quot;Kuantitas&quot;,\r\n                &quot;min&quot;: 1,\r\n                &quot;autoOptions&quot;: false,\r\n                &quot;quantity&quot;: 1,\r\n                &quot;max&quot;: 5,\r\n                &quot;editable&quot;: true,\r\n                &quot;showIncrDecr&quot;: true,\r\n                &quot;showOptions&quot;: false,\r\n                &quot;step&quot;: 1\r\n              },\r\n              &quot;sellerName&quot;: &quot;ALL ITEM STORE&quot;,\r\n              &quot;title&quot;: &quot;Case Slim Black Matte Xiaomi Redmi 4A Softcase Black&quot;,\r\n              &quot;stockTip&quot;: {},\r\n              &quot;valid&quot;: true,\r\n              &quot;itemId&quot;: &quot;143800088&quot;,\r\n              &quot;operations&quot;: [\r\n                &quot;wishlist&quot;,\r\n                &quot;delete&quot;\r\n              ],\r\n              &quot;sellerId&quot;: &quot;100124080&quot;,\r\n              &quot;price&quot;: {\r\n                &quot;price&quot;: 6000,\r\n                &quot;currentPrice&quot;: &quot;Rp6.000&quot;,\r\n                &quot;originPrice&quot;: &quot;Rp30.000&quot;,\r\n                &quot;promotionRatio&quot;: &quot;-80%&quot;\r\n              },\r\n              &quot;restriction&quot;: false,\r\n              &quot;isGift&quot;: false,\r\n              &quot;sku&quot;: {\r\n                &quot;skuText&quot;: &quot;Softcase, Hitam&quot;,\r\n                &quot;productVariant&quot;: &quot;SO908ELAAVYY4AANID-72544754&quot;,\r\n                &quot;brandId&quot;: &quot;17818&quot;,\r\n                &quot;skuId&quot;: &quot;157608391&quot;\r\n              },\r\n              &quot;itemUrl&quot;: &quot;https://www.lazada.co.id/products/i143800088-s157608391.html?urlFlag=true&amp;mp=1&quot;,\r\n              &quot;cartItemId&quot;: 2006547819\r\n            },\r\n            &quot;type&quot;: &quot;biz&quot;\r\n          },\r\n          &quot;location_2&quot;: {\r\n            &quot;id&quot;: &quot;2&quot;,\r\n            &quot;tag&quot;: &quot;location&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;buttonText&quot;: &quot;GANTI\\r\\n&quot;,\r\n              &quot;editable&quot;: true,\r\n              &quot;postCode&quot;: &quot;&quot;,\r\n              &quot;style&quot;: &quot;casAddress&quot;,\r\n              &quot;label&quot;: &quot;Lokasi&quot;,\r\n              &quot;title&quot;: &quot;Jawa Tengah,Kab. Boyolali,Ampel&quot;,\r\n              &quot;addressId&quot;: &quot;R2388357-R80010396-R80015219&quot;\r\n            },\r\n            &quot;type&quot;: &quot;biz&quot;\r\n          },\r\n          &quot;voucherInput_7&quot;: {\r\n            &quot;id&quot;: &quot;7&quot;,\r\n            &quot;tag&quot;: &quot;voucherInput&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;buttonText&quot;: &quot;GUNAKAN&quot;,\r\n              &quot;placeHolder&quot;: &quot;Masukkan Kode Voucher&quot;,\r\n              &quot;status&quot;: &quot;default&quot;\r\n            },\r\n            &quot;type&quot;: &quot;biz&quot;,\r\n            &quot;validate&quot;: {\r\n              &quot;value&quot;: [\r\n                {\r\n                  &quot;msg&quot;: &quot;Maaf, voucher ini tidak dapat digunakan. Silahkan periksa jika ada kesalahan penulisan&quot;,\r\n                  &quot;regex&quot;: &quot;^$|^[ ]{0,5}[A-Za-z0-9~!@#%&amp;*()_+？&lt;&gt;{}|-]{1,100}[ ]{0,5}$&quot;\r\n                }\r\n              ]\r\n            }\r\n          },\r\n          &quot;shop_43597338a_s2c&quot;: {\r\n            &quot;id&quot;: &quot;43597338a_s2c&quot;,\r\n            &quot;tag&quot;: &quot;shop&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;badges&quot;: [],\r\n              &quot;link&quot;: &quot;//www.lazada.co.id/shop/incredible-accessories-hp&quot;,\r\n              &quot;name&quot;: &quot;incredible accessories hp&quot;\r\n            },\r\n            &quot;type&quot;: &quot;biz&quot;\r\n          },\r\n          &quot;item_i7799f86e&quot;: {\r\n            &quot;id&quot;: &quot;i7799f86e&quot;,\r\n            &quot;tag&quot;: &quot;item&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;img&quot;: &quot;http://id-live-02.slatic.net/p/2/case-anti-shock-anti-crack-elegant-softcase-for-xiaomi-redmi-5a-white-clear-free-tempered-glass-1273-94487227-9f8ddff53bde3f8de9eb514ba2172361-catalog.jpg&quot;,\r\n              &quot;quantity&quot;: {\r\n                &quot;qtyPrefix&quot;: &quot;Kuantitas&quot;,\r\n                &quot;min&quot;: 1,\r\n                &quot;autoOptions&quot;: false,\r\n                &quot;quantity&quot;: 1,\r\n                &quot;max&quot;: 5,\r\n                &quot;editable&quot;: true,\r\n                &quot;showIncrDecr&quot;: true,\r\n                &quot;showOptions&quot;: false,\r\n                &quot;step&quot;: 1\r\n              },\r\n              &quot;sellerName&quot;: &quot;incredible accessories hp&quot;,\r\n              &quot;title&quot;: &quot;Case Anti Shock / Anti Crack Elegant Softcase  for Xiaomi Redmi 5A - White Clear + Free Tempered Glass&quot;,\r\n              &quot;stockTip&quot;: {},\r\n              &quot;valid&quot;: true,\r\n              &quot;itemId&quot;: &quot;160714927&quot;,\r\n              &quot;operations&quot;: [\r\n                &quot;wishlist&quot;,\r\n                &quot;delete&quot;\r\n              ],\r\n              &quot;sellerId&quot;: &quot;53631&quot;,\r\n              &quot;price&quot;: {\r\n                &quot;price&quot;: 13580,\r\n                &quot;currentPrice&quot;: &quot;Rp13.580&quot;,\r\n                &quot;originPrice&quot;: &quot;Rp25.000&quot;,\r\n                &quot;promotionRatio&quot;: &quot;-46%&quot;\r\n              },\r\n              &quot;restriction&quot;: false,\r\n              &quot;isGift&quot;: false,\r\n              &quot;sku&quot;: {\r\n                &quot;skuText&quot;: &quot;Softcase, Bening&quot;,\r\n                &quot;productVariant&quot;: &quot;SO908ELAB716EPANID-97510528&quot;,\r\n                &quot;brandId&quot;: &quot;17818&quot;,\r\n                &quot;skuId&quot;: &quot;183461134&quot;\r\n              },\r\n              &quot;itemUrl&quot;: &quot;https://www.lazada.co.id/products/i160714927-s183461134.html?urlFlag=true&amp;mp=1&quot;,\r\n              &quot;cartItemId&quot;: 2006579310\r\n            },\r\n            &quot;type&quot;: &quot;biz&quot;\r\n          },\r\n          &quot;package_p43597338a&quot;: {\r\n            &quot;id&quot;: &quot;p43597338a&quot;,\r\n            &quot;tag&quot;: &quot;package&quot;,\r\n            &quot;fields&quot;: {},\r\n            &quot;type&quot;: &quot;biz&quot;\r\n          },\r\n          &quot;listHeader_H&quot;: {\r\n            &quot;id&quot;: &quot;H&quot;,\r\n            &quot;tag&quot;: &quot;listHeader&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;middle&quot;: &quot;HARGA&quot;,\r\n              &quot;left&quot;: &quot;3 barang&quot;,\r\n              &quot;right&quot;: &quot;KUANTITAS&quot;\r\n            },\r\n            &quot;type&quot;: &quot;biz&quot;\r\n          },\r\n          &quot;delivery_3&quot;: {\r\n            &quot;id&quot;: &quot;3&quot;,\r\n            &quot;tag&quot;: &quot;delivery&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;selectPos&quot;: &quot;left&quot;,\r\n              &quot;options&quot;: [\r\n                {\r\n                  &quot;highlight&quot;: false,\r\n                  &quot;deliveryId&quot;: &quot;STANDARD&quot;,\r\n                  &quot;bgColor&quot;: &quot;#fafafa&quot;,\r\n                  &quot;price&quot;: &quot;Rp56.700&quot;,\r\n                  &quot;disable&quot;: false,\r\n                  &quot;icon&quot;: &quot;https://laz-img-cdn.alicdn.com/tfs/TB1UpyCpfDH8KJjy1XcXXcpdXXa-72-72.png&quot;,\r\n                  &quot;name&quot;: &quot;Standar&quot;,\r\n                  &quot;reachTime&quot;: &quot;Dapatkan pada\\n 3-4 Apr 2018&quot;,\r\n                  &quot;liveUp&quot;: false,\r\n                  &quot;selected&quot;: true\r\n                }\r\n              ],\r\n              &quot;style&quot;: &quot;card&quot;,\r\n              &quot;title&quot;: &quot;Pengiriman yang dipilih&quot;\r\n            },\r\n            &quot;type&quot;: &quot;biz&quot;\r\n          },\r\n          &quot;orderTotal_8&quot;: {\r\n            &quot;id&quot;: &quot;8&quot;,\r\n            &quot;tag&quot;: &quot;orderTotal&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;button&quot;: {\r\n                &quot;enable&quot;: true,\r\n                &quot;text&quot;: &quot;LANJUTKAN KE PEMBAYARAN&quot;,\r\n                &quot;clicked&quot;: false\r\n              },\r\n              &quot;payment&quot;: {\r\n                &quot;taxTip&quot;: &quot;Termasuk PPN, jika berlaku&quot;,\r\n                &quot;pay&quot;: &quot;Rp80.257&quot;,\r\n                &quot;title&quot;: &quot;Total&quot;\r\n              }\r\n            },\r\n            &quot;type&quot;: &quot;biz&quot;\r\n          },\r\n          &quot;shop_fdaf8a8a_s23f9&quot;: {\r\n            &quot;id&quot;: &quot;fdaf8a8a_s23f9&quot;,\r\n            &quot;tag&quot;: &quot;shop&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;badges&quot;: [],\r\n              &quot;link&quot;: &quot;//www.lazada.co.id/shop/all-item-store&quot;,\r\n              &quot;name&quot;: &quot;ALL ITEM STORE&quot;\r\n            },\r\n            &quot;type&quot;: &quot;biz&quot;\r\n          },\r\n          &quot;floatTips_4&quot;: {\r\n            &quot;id&quot;: &quot;4&quot;,\r\n            &quot;tag&quot;: &quot;floatTips&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;tips&quot;: []\r\n            },\r\n            &quot;type&quot;: &quot;biz&quot;\r\n          },\r\n          &quot;item_i7790e0f9&quot;: {\r\n            &quot;id&quot;: &quot;i7790e0f9&quot;,\r\n            &quot;tag&quot;: &quot;item&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;img&quot;: &quot;http://id-live-02.slatic.net/p/2/case-anti-shock-anti-crack-elegant-softcase-for-xiaomi-redmi-note4x-white-clear-8431-85175402-0bec01e88741744ae5461c4b3a4ae160-catalog.jpg&quot;,\r\n              &quot;quantity&quot;: {\r\n                &quot;qtyPrefix&quot;: &quot;Kuantitas&quot;,\r\n                &quot;min&quot;: 1,\r\n                &quot;autoOptions&quot;: false,\r\n                &quot;quantity&quot;: 1,\r\n                &quot;max&quot;: 5,\r\n                &quot;editable&quot;: true,\r\n                &quot;showIncrDecr&quot;: true,\r\n                &quot;showOptions&quot;: false,\r\n                &quot;step&quot;: 1\r\n              },\r\n              &quot;sellerName&quot;: &quot;incredible accessories hp&quot;,\r\n              &quot;title&quot;: &quot;Case Anti Shock / Anti Crack Elegant Softcase  for Xiaomi Redmi Note 4x - White Clear&quot;,\r\n              &quot;stockTip&quot;: {},\r\n              &quot;valid&quot;: true,\r\n              &quot;itemId&quot;: &quot;108849535&quot;,\r\n              &quot;operations&quot;: [\r\n                &quot;wishlist&quot;,\r\n                &quot;delete&quot;\r\n              ],\r\n              &quot;sellerId&quot;: &quot;53631&quot;,\r\n              &quot;price&quot;: {\r\n                &quot;price&quot;: 3977,\r\n                &quot;currentPrice&quot;: &quot;Rp3.977&quot;,\r\n                &quot;originPrice&quot;: &quot;Rp15.000&quot;,\r\n                &quot;promotionRatio&quot;: &quot;-73%&quot;\r\n              },\r\n              &quot;restriction&quot;: false,\r\n              &quot;isGift&quot;: false,\r\n              &quot;sku&quot;: {\r\n                &quot;skuText&quot;: &quot;Sarung, Bening&quot;,\r\n                &quot;productVariant&quot;: &quot;CA529ELAAC6GUEANID-27304198&quot;,\r\n                &quot;brandId&quot;: &quot;10464&quot;,\r\n                &quot;skuId&quot;: &quot;110628148&quot;\r\n              },\r\n              &quot;itemUrl&quot;: &quot;https://www.lazada.co.id/products/i108849535-s110628148.html?urlFlag=true&amp;mp=1&quot;,\r\n              &quot;cartItemId&quot;: 2005983481\r\n            },\r\n            &quot;type&quot;: &quot;biz&quot;\r\n          },\r\n          &quot;package_pfdaf8a8a&quot;: {\r\n            &quot;id&quot;: &quot;pfdaf8a8a&quot;,\r\n            &quot;tag&quot;: &quot;package&quot;,\r\n            &quot;fields&quot;: {},\r\n            &quot;type&quot;: &quot;biz&quot;\r\n          }\r\n        },\r\n        &quot;hierarchy&quot;: {\r\n          &quot;component&quot;: [\r\n            &quot;container&quot;,\r\n            &quot;delivery&quot;,\r\n            &quot;item&quot;,\r\n            &quot;shop&quot;,\r\n            &quot;package&quot;,\r\n            &quot;listHeader&quot;,\r\n            &quot;orderSummary&quot;,\r\n            &quot;leftContainer&quot;,\r\n            &quot;orderTotal&quot;,\r\n            &quot;floatTips&quot;,\r\n            &quot;root&quot;,\r\n            &quot;location&quot;,\r\n            &quot;rightContainer&quot;,\r\n            &quot;voucherInput&quot;\r\n          ],\r\n          &quot;root&quot;: &quot;root_0&quot;,\r\n          &quot;structure&quot;: {\r\n            &quot;package_p43597338a&quot;: [\r\n              &quot;delivery_d43597338a&quot;,\r\n              &quot;shop_43597338a_s2c&quot;,\r\n              &quot;item_i7799f86e&quot;,\r\n              &quot;item_i7790e0f9&quot;\r\n            ],\r\n            &quot;leftContainer_CL&quot;: [\r\n              &quot;delivery_3&quot;,\r\n              &quot;listHeader_H&quot;,\r\n              &quot;package_pfdaf8a8a&quot;,\r\n              &quot;package_p43597338a&quot;\r\n            ],\r\n            &quot;container_C&quot;: [\r\n              &quot;leftContainer_CL&quot;,\r\n              &quot;rightContainer_CR&quot;\r\n            ],\r\n            &quot;rightContainer_CR&quot;: [\r\n              &quot;location_2&quot;,\r\n              &quot;orderSummary_6&quot;\r\n            ],\r\n            &quot;orderSummary_6&quot;: [\r\n              &quot;voucherInput_7&quot;,\r\n              &quot;orderTotal_8&quot;\r\n            ],\r\n            &quot;root_0&quot;: [\r\n              &quot;container_C&quot;,\r\n              &quot;floatTips_4&quot;\r\n            ],\r\n            &quot;package_pfdaf8a8a&quot;: [\r\n              &quot;delivery_dfdaf8a8a&quot;,\r\n              &quot;shop_fdaf8a8a_s23f9&quot;,\r\n              &quot;item_i77997d6b&quot;\r\n            ]\r\n          }\r\n        },\r\n        &quot;linkage&quot;: {\r\n          &quot;input&quot;: [],\r\n          &quot;request&quot;: [\r\n            &quot;voucherInput_7&quot;,\r\n            &quot;item_i7799f86e&quot;,\r\n            &quot;delivery_3&quot;,\r\n            &quot;orderTotal_8&quot;,\r\n            &quot;item_i7790e0f9&quot;,\r\n            &quot;location_2&quot;,\r\n            &quot;item_i77997d6b&quot;\r\n          ],\r\n          &quot;common&quot;: {\r\n            &quot;compress&quot;: true,\r\n            &quot;queryParams&quot;: &quot;^^$$1afe141216814f45e9fc6dba84d4863d{$_$}H4sIAAAAAAAAAFWU247bRgyGXyXQ9caYGXJOe5fkJmmLot3de4Ez5OwKlSVBklMkQd69lJsNHBgwZIHfz9NPf+t2Wc/DRGN3/61bRtrbvJ67+26p3V230LPoc6V1777fdROd5XGh+vpu05DLJuu7bRuep0OgjrRtf2rYETGfTyN9JabTNfh0nlnG02Xc13k6LbTSeTv9fZH1y1/XZxVbZWJZ3w9ff7xRxXGutA/z9DTs46H6G/1Lb55keqaXu9+pnN68n7/MI43D3bvzIqOKEPMq2/aJNfrBQUrg49uHZIw1kMP/T97ZfPQ3b/sHrUoju+/aoJa8zJNM+/aoDdF+WeXa1TztNEyy9h800jUoDoPFWnMIVHwCMMiWCJ2zgVRX+xw+a2M9aHyMsbpqwcUChTgxeMZqbWzkJXl7G88IPkeARApKMCYQeJNYojCEVPTboMcCmOIvibgxtURXLrRaKGKrWdhHMslkE1ss2TjnCA+ujTPtT8Oy9XgkilVQsgEX2AXJgQ3UZCNb1yKEY1LDLud+iDEbMS0rYwAzx+KbE6JmcgCbs02YJShhyi2TI4eiTAHr0ROiZS0mOteYW9JChZwR+CVPbikce2Ev4HJiJmuab6TJIApIkZo4JFZmlKZb/LmiP66jqzVlEhe5GJEUs/XNk6csxYacDmrY9o9C6rf+oxJAHqAkJMc69RbZu+yBQKxFqTEcxA8r9u5wgagLRISDNuECYjAFk3NYUnU+Htczryr+eDmfSRcUlNEukSyVmqLXeNG9NnWF16RBV95emad5p7FPx5QNGnSUpHDUllsyGINQUKSp78L1Rus/eqb9cmsdgGp1vmpLcKjD1JsNTUGdqmu6olvuxjmlpaa7KV6wtkqU1UimOXA6gIjXk1mH55fbaT8olhJJMhFrrlwxRwuAmK00ELD6+8Dmee9Ndz9dxvGu217mpf9Zb7+5qirZ1YoYOXJlWw1r1Zz1w7kAxKvKlXutVzG4WlFvGUyKxkhB9RNL9ibmmoGTnkJFBT/Pl/oi66dpuex9VMa65LRQ0fRWnDjSZDogFZJkkYL+HfwHDyba3BsFAAA=&quot;,\r\n            &quot;submitParams&quot;: &quot;^^$$f7898231e0216a924bcaa64d213a61ba{$_$}H4sIAAAAAAAAADXMQQrDMAwEwL/oHPSA3PqBUsgLto4bDJJtJPvS4L/XCfS2uwx7UoumKUNoPakK2qeY0ko10EIVR5w5wBqNhTI0bhXhv/kk3aM93NORr4MgcH9OdomiLPhiB9+YtexRuEuzkrnCoM5bf2tqr7vQGD8eVpdVjwAAAA==&quot;\r\n          },\r\n          &quot;signature&quot;: &quot;89dffd9ca23307e603556a4c896e4c56&quot;\r\n        }\r\n      }\r\n    }\r\n\r\n\r\nWith `jq` I can do this:\r\n```\r\n[me@linux]$ cat /tmp/json | jq &#39;.module | .data | keys&#39;\r\n[\r\n  &quot;container_C&quot;,\r\n  &quot;delivery_3&quot;,\r\n  &quot;delivery_d43597338a&quot;,\r\n  &quot;delivery_dfdaf8a8a&quot;,\r\n  &quot;floatTips_4&quot;,\r\n  &quot;item_i7790e0f9&quot;,\r\n  &quot;item_i77997d6b&quot;,\r\n  &quot;item_i7799f86e&quot;,\r\n  &quot;leftContainer_CL&quot;,\r\n  &quot;listHeader_H&quot;,\r\n  &quot;location_2&quot;,\r\n  &quot;orderSummary_6&quot;,\r\n  &quot;orderTotal_8&quot;,\r\n  &quot;package_p43597338a&quot;,\r\n  &quot;package_pfdaf8a8a&quot;,\r\n  &quot;rightContainer_CR&quot;,\r\n  &quot;root_0&quot;,\r\n  &quot;shop_43597338a_s2c&quot;,\r\n  &quot;shop_fdaf8a8a_s23f9&quot;,\r\n  &quot;voucherInput_7&quot;\r\n]\r\n```\r\nI need to get `orderTotal_8` but please note that the number `8` is always changing, so it can be `orderTotal_10` or `orderTotal_3` etc... How can I get this key with pure `jq` command if possible, without the help of grep / awk ? So the result should be like this `orderTotal_8`",
        "link": "https://stackoverflow.com/questions/49542398/how-to-get-a-json-key-that-contains-a-specific-string-with-jq",
        "title": "How to get a json key that contains a specific string with jq?"
    },
    {
        "tags": [
            "json",
            "regex",
            "split",
            "substring",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1522318874,
                "post_id": 49551805,
                "comment_id": 86114274,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 12913668,
                    "reputation": 1920,
                    "user_id": 9338645,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/F3UWT.jpg?s=256",
                    "display_name": "Chrᴉz remembers Monica",
                    "link": "https://stackoverflow.com/users/9338645/chr%e1%b4%89z-remembers-monica"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1522330099,
                "post_id": 49551805,
                "comment_id": 86122168,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1627427388,
                "last_edit_date": 1627427388,
                "creation_date": 1522316062,
                "answer_id": 49552592,
                "question_id": 49551805,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For input `&quot;countries-sapi-1.0&quot;`, use: `.[] | match( &quot;\\\\d&quot;; &quot;ig&quot;)` which will give you the following output:\r\n    \r\n    {\r\n      &quot;offset&quot;: 15,\r\n      &quot;length&quot;: 1,\r\n      &quot;string&quot;: &quot;1&quot;,\r\n      &quot;captures&quot;: []\r\n    }\r\n    {\r\n      &quot;offset&quot;: 17,\r\n      &quot;length&quot;: 1,\r\n      &quot;string&quot;: &quot;0&quot;,\r\n      &quot;captures&quot;: []\r\n    }\r\n    \r\n    \r\nThis uses the first object&#39;s offset value and tries to slice it from the starting position to the received offset.\r\n    \r\nSlice from beginning:\t`$ jq -c &#39;.[:15]&#39;`\r\n\r\nIn our case we got 15 as the offset for the first object so we used `:15` for the slice.\r\n",
                "title": "jq split string by a pattern"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1522331776,
                "last_edit_date": 1522331776,
                "creation_date": 1522328807,
                "answer_id": 49556889,
                "question_id": 49551805,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It looks like you need to study up on regular expressions (regex); see for example https://regexone.com/ or https://github.com/zeeshanu/learn-regex or dozens of others.\r\n\r\nUsing jq, in your particular case, you could start with:\r\n\r\n    sub(&quot; *- *[0-9]+\\\\.[0-9]+.*$&quot;; &quot;&quot;)\r\n\r\nNote that two backslashes are required here because the &quot;from&quot; expression must be (or evaluate to) a valid JSON string.",
                "title": "jq split string by a pattern"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1551056502,
                "last_edit_date": 1551056502,
                "creation_date": 1550651430,
                "answer_id": 54781874,
                "question_id": 49551805,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&lt;!-- language-all: none --&gt;\r\n\r\nI got here searching for how to split by regex instead of substring in `jq`, but I found out that you have to give two arguments to the `split` function (where the second argument contains flags for the regex, but it can be just an empty string).\r\n\r\n    $ jq -n &#39;&quot;axxbxxxc&quot;|split(&quot;x+&quot;;&quot;&quot;)&#39;\r\n    [\r\n      &quot;a&quot;,\r\n      &quot;b&quot;,\r\n      &quot;c&quot;\r\n    ]\r\n\r\nFrom the manual:\r\n\r\n    split\r\n        Splits an input string on the separator argument.\r\n\r\n            jq &#39;split(&quot;, &quot;)&#39;\r\n               &quot;a, b,c,d, e, &quot;\r\n            =&gt; [&quot;a&quot;,&quot;b,c,d&quot;,&quot;e&quot;,&quot;&quot;]\r\n\r\n    [...]\r\n\r\n    split(regex; flags)\r\n        For backwards compatibility, split splits on a string, not a regex.\r\n",
                "title": "jq split string by a pattern"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1710181255,
                "last_edit_date": 1710181255,
                "creation_date": 1710121109,
                "answer_id": 78138055,
                "question_id": 49551805,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another option, using `match` and assuming versions start with `/-\\d+\\./`:\r\n\r\n```bash\r\n$ echo &#39;[&quot;countries-sapi-1.0&quot;, &quot;inventory-list-api-1.0-snapshot&quot;]&#39; | \\\r\njq &#39;.[] | match(&quot;^.*(?=-\\\\d+\\\\.)&quot;) | .string&#39;\r\n&quot;countries-sapi&quot;\r\n&quot;inventory-list-api&quot;\r\n```\r\n\r\nIf you can assume all versions start with `-1.`:\r\n\r\n```bash\r\n$ echo &#39;[&quot;countries-sapi-1.0&quot;, &quot;inventory-list-api-1.0-snapshot&quot;]&#39; | \\\r\njq &#39;.[] | split(&quot;-1.&quot;) | first&#39;\r\n&quot;countries-sapi&quot;\r\n&quot;inventory-list-api&quot;\r\n```",
                "title": "jq split string by a pattern"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 8,
        "last_activity_date": 1710181255,
        "creation_date": 1522313724,
        "last_edit_date": 1661713808,
        "question_id": 49551805,
        "body_markdown": "I have a json object with one of field having values for example &quot;**countries-`sapi`-`1.0`**&quot;, &quot;**inventory-list-`api`-`1.0-snapshot`**&quot;\r\n\r\nNote that the first one has `sapi` and the other one has `api`.\r\n\r\nUsing `jq`, how can i get countries-sapi  or inventory-list-api I mean whatever is there before the version. the version can be as simple as `1.0` or `1.0.1-snapshot` etc..",
        "link": "https://stackoverflow.com/questions/49551805/jq-split-string-by-a-pattern",
        "title": "jq split string by a pattern"
    },
    {
        "tags": [
            "json",
            "regex",
            "object",
            "jq",
            "capturing-group"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7095226,
                    "reputation": 529,
                    "user_id": 5429075,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/902e93ce18895308c55265b2384da860?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Naveen K Reddy",
                    "link": "https://stackoverflow.com/users/5429075/naveen-k-reddy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522319701,
                "post_id": 49553691,
                "comment_id": 86114803,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522323648,
                "post_id": 49553691,
                "comment_id": 86117441,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522327500,
                "post_id": 49553691,
                "comment_id": 86120289,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7095226,
                    "reputation": 529,
                    "user_id": 5429075,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/902e93ce18895308c55265b2384da860?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Naveen K Reddy",
                    "link": "https://stackoverflow.com/users/5429075/naveen-k-reddy"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522330252,
                "post_id": 49553691,
                "comment_id": 86122284,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7095226,
                    "reputation": 529,
                    "user_id": 5429075,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/902e93ce18895308c55265b2384da860?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Naveen K Reddy",
                    "link": "https://stackoverflow.com/users/5429075/naveen-k-reddy"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522334019,
                "post_id": 49553691,
                "comment_id": 86125328,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7095226,
                    "reputation": 529,
                    "user_id": 5429075,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/902e93ce18895308c55265b2384da860?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Naveen K Reddy",
                    "link": "https://stackoverflow.com/users/5429075/naveen-k-reddy"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522425291,
                "post_id": 49553691,
                "comment_id": 86162501,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1522335020,
                "last_edit_date": 1522335020,
                "creation_date": 1522319705,
                "answer_id": 49553891,
                "question_id": 49553691,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\nSample `input.json`:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;abc&quot;,\r\n        &quot;name&quot;: &quot;name-middlenane-lastname-1&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;123&quot;,\r\n        &quot;name&quot;: &quot;fname-flast-2&quot;\r\n      }\r\n    ]\r\n\r\n\r\n\r\n----------\r\n\r\n    jq &#39;map(. + (.name | capture(&quot;(?&lt;newkey&gt;.+)-[0-9]+&quot;)) )&#39; input.json\r\n\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;abc&quot;,\r\n        &quot;name&quot;: &quot;name-middlenane-lastname-1&quot;,\r\n        &quot;newkey&quot;: &quot;name-middlenane-lastname&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;123&quot;,\r\n        &quot;name&quot;: &quot;fname-flast-2&quot;,\r\n        &quot;newkey&quot;: &quot;fname-flast&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "jq add capturing group result outside"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1522387197,
        "creation_date": 1522319132,
        "last_edit_date": 1522387197,
        "question_id": 49553691,
        "body_markdown": "For example,\r\n\r\nInput:\r\n\r\n        {\r\n           &quot;id&quot;:&quot;abc&quot;,\r\n           &quot;name&quot;: &quot;name-middlenane-lastname-1&quot;\r\n        },\r\n\r\n        {\r\n            &quot;id&quot;:&quot;123&quot;,\r\n            &quot;name&quot;: &quot;fname-flast-2&quot;\r\n        }\r\n\r\nresponse:\r\n\r\n        {\r\n             &quot;id&quot;:&quot;abc&quot;,\r\n             &quot;name&quot;: &quot;name-middlename-lastname-1&quot;,\r\n             &quot;newkey&quot;: &quot;name-middlename-lastname&quot;\r\n        },\r\n\r\n        {\r\n              &quot;id&quot;:&quot;123&quot;,\r\n              &quot;name&quot;: &quot;fname-flast-2&quot;,\r\n              &quot;newkey&quot;: &quot;fname-flast&quot;\r\n        }\r\n\r\nThe filed **name** in each object is a string with characters and numbers separated by **&quot;-&quot;** hyphen. I need the complete string from beginning till the starting number. I don&#39;t want anything which is there after the number. And then the add **new** field with key as **newkey** and value should be extracted string without the number. Thus, the output should contain old fields as well as new one.",
        "link": "https://stackoverflow.com/questions/49553691/jq-add-capturing-group-result-outside",
        "title": "jq add capturing group result outside"
    },
    {
        "tags": [
            "json",
            "bash",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11381172,
                    "reputation": 26772,
                    "user_id": 8344060,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/1UbPk.png?s=256",
                    "display_name": "kvantour",
                    "link": "https://stackoverflow.com/users/8344060/kvantour"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1522327431,
                "post_id": 49556242,
                "comment_id": 86120239,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1522327622,
                "creation_date": 1522327622,
                "answer_id": 49556489,
                "question_id": 49556242,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use the [`keys` builtin function](https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions#keys,keys_unsorted) of `jq`.\r\n\r\nAssuming your input JSON is stored in the file `input.json`:\r\n\r\n    $ cat input.json | jq &#39;keys&#39;\r\n\r\nproduces:\r\n\r\n    [\r\n      &quot;201110131738QP27N&quot;,\r\n      &quot;201803271459ICV69&quot;,\r\n      &quot;2018032715008ZM2G&quot;,\r\n      &quot;201803281536PSKR4&quot;\r\n    ]\r\n\r\n\r\n",
                "title": "Get data from a JSON output using &#39;jq&#39;"
            },
            {
                "up_vote_count": 13,
                "is_accepted": true,
                "score": 13,
                "last_activity_date": 1522328350,
                "last_edit_date": 1522328350,
                "creation_date": 1522327795,
                "answer_id": 49556547,
                "question_id": 49556242,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To get the raw output without an array use `|.[]` to unwrap it\r\n\r\n    jq --raw-output &#39;keys | .[]&#39;  input.json\r\n\r\nproduces\r\n\r\n    201110131738QP27N\r\n    201803271459ICV69\r\n    2018032715008ZM2G\r\n    201803281536PSKR4\r\n\r\nor more simply written as just `jq --raw-output &#39;keys[]&#39;`\r\n",
                "title": "Get data from a JSON output using &#39;jq&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1522331109,
        "creation_date": 1522326900,
        "last_edit_date": 1522331109,
        "question_id": 49556242,
        "body_markdown": "I have the following JSON output:\r\n\r\n    {\r\n      &quot;201110131738QP27N&quot;: {\r\n        &quot;parent&quot;: 17,\r\n        &quot;name&quot;: &quot;CentralServer&quot;,\r\n        &quot;status&quot;: &quot;Active&quot;,\r\n        &quot;count&quot;: 6\r\n      },\r\n      &quot;201803271459ICV69&quot;: {\r\n        &quot;name&quot;: &quot;subaccount1&quot;,\r\n        &quot;status&quot;: &quot;Active&quot;,\r\n        &quot;count&quot;: 1\r\n      },\r\n      &quot;2018032715008ZM2G&quot;: {\r\n        &quot;name&quot;: &quot;subaccount2&quot;,\r\n        &quot;status&quot;: &quot;Active&quot;,\r\n        &quot;count&quot;: 1\r\n      },\r\n      &quot;201803281536PSKR4&quot;: {\r\n        &quot;name&quot;: &quot;Este e um teste&quot;,\r\n        &quot;status&quot;: &quot;Active&quot;\r\n      }\r\n    }\r\n\r\nAnd I&#39;m trying to get only the following data:\r\n\r\n    201110131738QP27N\r\n    201803271459ICV69\r\n    2018032715008ZM2G\r\n    201803281536PSKR4\r\n\r\nTo get the desired data, I&#39;m trying to use the `jq` command, but so far I have not succeeded.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49556242/get-data-from-a-json-output-using-jq",
        "title": "Get data from a JSON output using &#39;jq&#39;"
    },
    {
        "tags": [
            "json",
            "regex",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1522363686,
                "creation_date": 1522363686,
                "answer_id": 49566127,
                "question_id": 49565829,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    with_entries( select(.key | test(&quot;^toPayBtn_&quot;)) )\r\n\r\nproduces the output you want.  You might want to tweak the regex.",
                "title": "How to search JSON key that contains specific string with jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1522412595,
                "creation_date": 1522412595,
                "answer_id": 49574375,
                "question_id": 49565829,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is angular filter example search text in search box it will only show object which have a search key.\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-html --&gt;\r\n\r\n    &lt;html ng-app=&quot;app&quot;&gt;\r\n    &lt;head&gt;\r\n        &lt;title&gt;App&lt;/title&gt;\r\n        &lt;link rel=&quot;stylesheet&quot; href=&quot;https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css&quot;&gt;\r\n        &lt;script src=&quot;https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.6.5/angular.min.js&quot;&gt;&lt;/script&gt;\r\n        &lt;script src=&quot;https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js&quot;&gt;\r\n        &lt;/script&gt;\r\n        &lt;script src=&quot;https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js&quot;&gt;\r\n        &lt;/script&gt;\r\n\r\n\r\n        &lt;style&gt;\r\n            th {\r\n                display: table-cell;\r\n                vertical-align: inherit;\r\n                font-weight: bold;\r\n                text-align: center;\r\n            }\r\n        &lt;/style&gt;\r\n    &lt;/head&gt;\r\n\r\n    &lt;body&gt;\r\n        &lt;div ng-controller=&quot;ctrl&quot;&gt;\r\n           &lt;input type=&quot;text&quot; ng-model=&quot;search&quot; placeholder=&quot;Search&quot;&gt;\r\n           {{search}}\r\n            &lt;table class=&quot;table table-bordered&quot;&gt;\r\n                &lt;thead&gt;\r\n                    &lt;tr&gt;\r\n                        &lt;th&gt;OBJECT&lt;/th&gt;\r\n               \r\n                    &lt;/tr&gt;\r\n                &lt;/thead&gt;\r\n                &lt;h4&gt;{{displayById}}&lt;/h4&gt;\r\n                &lt;tbody&gt;\r\n                    &lt;tr ng-repeat=&quot;x in jsonData | filter: search&quot;&gt;\r\n                        &lt;td&gt;{{x}}&lt;/td&gt;\r\n                    &lt;/tr&gt;\r\n                &lt;/tbody&gt;\r\n            &lt;/table&gt;\r\n\r\n        &lt;/div&gt;\r\n        &lt;script&gt;\r\n            var ngmodule = angular.module(&quot;app&quot;, []);\r\n\r\n            ngmodule.controller(&quot;ctrl&quot;, [&quot;$scope&quot;, &quot;$log&quot;,&quot;$timeout&quot;,\r\n                function ($scope, $log, $timeout) {\r\n\r\n                    $scope.init = function(){\r\n                        console.log(&quot;$timeout&quot;)\r\n                    }\r\n                    $timeout($scope.init);\r\n\r\n                    $scope.jsonData = [{\r\n        &quot;orderTotal_1&quot;: {\r\n            &quot;fields&quot;: {\r\n                &quot;button&quot;: {\r\n                    &quot;actionDialog&quot;: null,\r\n                    &quot;actionUrl&quot;: null,\r\n                    &quot;clicked&quot;: false,\r\n                    &quot;enable&quot;: true,\r\n                    &quot;text&quot;: &quot;LANJUTKAN KE PEMBAYARAN&quot;,\r\n                    &quot;textColor&quot;: null\r\n                },\r\n                &quot;payment&quot;: {\r\n                    &quot;pay&quot;: &quot;Rp1.953.800&quot;,\r\n                    &quot;taxTip&quot;: &quot;Termasuk PPN, jika berlaku.&quot;,\r\n                    &quot;title&quot;: &quot;Total&quot;\r\n                },\r\n                &quot;timestamp&quot;: 1522355946093\r\n            },\r\n            &quot;id&quot;: &quot;1&quot;,\r\n            &quot;tag&quot;: &quot;orderTotal&quot;,\r\n            &quot;type&quot;: &quot;biz&quot;\r\n            },\r\n        &quot;rightContainer_10010&quot;: {\r\n            &quot;fields&quot;: {\r\n                &quot;css&quot;: {\r\n                    &quot;backgroundColor&quot;: null,\r\n                    &quot;floatPosition&quot;: &quot;right&quot;,\r\n                    &quot;marginTop&quot;: null,\r\n                    &quot;width&quot;: &quot;388px&quot;\r\n                }\r\n            },\r\n            &quot;id&quot;: &quot;10010&quot;,\r\n            &quot;tag&quot;: &quot;rightContainer&quot;,\r\n            &quot;type&quot;: &quot;container&quot;\r\n        },\r\n        &quot;toPayBtn_10021&quot;: {\r\n            &quot;fields&quot;: {\r\n                &quot;clicked&quot;: false,\r\n                &quot;enable&quot;: true,\r\n                &quot;text&quot;: &quot;LANJUTKAN KE PEMBAYARAN&quot;\r\n            },\r\n            &quot;id&quot;: &quot;10021&quot;,\r\n            &quot;tag&quot;: &quot;toPayBtn&quot;,\r\n            &quot;type&quot;: &quot;biz&quot;\r\n        },\r\n        &quot;voucherInput_1&quot;: {\r\n            &quot;fields&quot;: {\r\n                &quot;buttonText&quot;: &quot;GUNAKAN&quot;,\r\n                &quot;placeHolder&quot;: &quot;Masukkan Kode Voucher&quot;,\r\n                &quot;status&quot;: &quot;default&quot;\r\n            },\r\n            &quot;id&quot;: &quot;1&quot;,\r\n            &quot;tag&quot;: &quot;voucherInput&quot;,\r\n            &quot;type&quot;: &quot;biz&quot;\r\n        }\r\n    }];\r\n            }]);\r\n        &lt;/script&gt;\r\n    &lt;/body&gt;\r\n\r\n    &lt;/html&gt;\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n",
                "title": "How to search JSON key that contains specific string with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1522412595,
        "creation_date": 1522361911,
        "last_edit_date": 1522380968,
        "question_id": 49565829,
        "body_markdown": "I have a JSON data:\r\n\r\n    {\r\n    \t&quot;orderTotal_1&quot;: {\r\n    \t\t&quot;fields&quot;: {\r\n    \t\t\t&quot;button&quot;: {\r\n    \t\t\t\t&quot;actionDialog&quot;: null,\r\n    \t\t\t\t&quot;actionUrl&quot;: null,\r\n    \t\t\t\t&quot;clicked&quot;: false,\r\n    \t\t\t\t&quot;enable&quot;: true,\r\n    \t\t\t\t&quot;text&quot;: &quot;LANJUTKAN KE PEMBAYARAN&quot;,\r\n    \t\t\t\t&quot;textColor&quot;: null\r\n    \t\t\t},\r\n    \t\t\t&quot;payment&quot;: {\r\n    \t\t\t\t&quot;pay&quot;: &quot;Rp1.953.800&quot;,\r\n    \t\t\t\t&quot;taxTip&quot;: &quot;Termasuk PPN, jika berlaku.&quot;,\r\n    \t\t\t\t&quot;title&quot;: &quot;Total&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;timestamp&quot;: 1522355946093\r\n    \t\t},\r\n    \t\t&quot;id&quot;: &quot;1&quot;,\r\n    \t\t&quot;tag&quot;: &quot;orderTotal&quot;,\r\n    \t\t&quot;type&quot;: &quot;biz&quot;\r\n    \t\t},\r\n    \t&quot;rightContainer_10010&quot;: {\r\n    \t\t&quot;fields&quot;: {\r\n    \t\t\t&quot;css&quot;: {\r\n    \t\t\t\t&quot;backgroundColor&quot;: null,\r\n    \t\t\t\t&quot;floatPosition&quot;: &quot;right&quot;,\r\n    \t\t\t\t&quot;marginTop&quot;: null,\r\n    \t\t\t\t&quot;width&quot;: &quot;388px&quot;\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t&quot;id&quot;: &quot;10010&quot;,\r\n    \t\t&quot;tag&quot;: &quot;rightContainer&quot;,\r\n    \t\t&quot;type&quot;: &quot;container&quot;\r\n    \t},\r\n    \t&quot;toPayBtn_10021&quot;: {\r\n    \t\t&quot;fields&quot;: {\r\n    \t\t\t&quot;clicked&quot;: false,\r\n    \t\t\t&quot;enable&quot;: true,\r\n    \t\t\t&quot;text&quot;: &quot;LANJUTKAN KE PEMBAYARAN&quot;\r\n    \t\t},\r\n    \t\t&quot;id&quot;: &quot;10021&quot;,\r\n    \t\t&quot;tag&quot;: &quot;toPayBtn&quot;,\r\n    \t\t&quot;type&quot;: &quot;biz&quot;\r\n    \t},\r\n    \t&quot;voucherInput_1&quot;: {\r\n    \t\t&quot;fields&quot;: {\r\n    \t\t\t&quot;buttonText&quot;: &quot;GUNAKAN&quot;,\r\n    \t\t\t&quot;placeHolder&quot;: &quot;Masukkan Kode Voucher&quot;,\r\n    \t\t\t&quot;status&quot;: &quot;default&quot;\r\n    \t\t},\r\n    \t\t&quot;id&quot;: &quot;1&quot;,\r\n    \t\t&quot;tag&quot;: &quot;voucherInput&quot;,\r\n    \t\t&quot;type&quot;: &quot;biz&quot;\r\n    \t}\r\n    }\r\n\r\nI want to get `toPayBtn_10021` but the number `10021` is dynamic. So it can be `toPayBtn_34` `toPayBtn_21` etc. \r\n\r\nThis is the output that I want to achieve:\r\n\r\n    &quot;toPayBtn_10021&quot;: {\r\n    \t&quot;fields&quot;: {\r\n    \t\t&quot;clicked&quot;: false,\r\n    \t\t&quot;enable&quot;: true,\r\n    \t\t&quot;text&quot;: &quot;LANJUTKAN KE PEMBAYARAN&quot;\r\n    \t},\r\n    \t&quot;id&quot;: &quot;10021&quot;,\r\n    \t&quot;tag&quot;: &quot;toPayBtn&quot;,\r\n    \t&quot;type&quot;: &quot;biz&quot;\r\n    }\r\nThis is what I have tried:\r\n\r\n    jq &#39;.toPayBtn*&#39;\r\n\r\nBut it results in:\r\n\r\n    jq: error: syntax error, unexpected $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .toPayBtn*         \r\n    jq: 1 compile error\r\n    exit status 3\r\n\r\nRegex doesn&#39;t seem to work with `jq` How do I fix it ?",
        "link": "https://stackoverflow.com/questions/49565829/how-to-search-json-key-that-contains-specific-string-with-jq",
        "title": "How to search JSON key that contains specific string with jq?"
    },
    {
        "tags": [
            "json",
            "regex",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522372117,
                "post_id": 49566793,
                "comment_id": 86142564,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6887896,
                    "reputation": 1031,
                    "user_id": 5292423,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/c7f9d01d792f43aa663d6b7603d9cf89?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Joe",
                    "link": "https://stackoverflow.com/users/5292423/joe"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522378163,
                "post_id": 49566793,
                "comment_id": 86143892,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1522378642,
                "creation_date": 1522378642,
                "answer_id": 49567800,
                "question_id": 49566793,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    .[] | select( test(&quot;^toPayBtn_&quot;) )\r\n\r\n",
                "title": "How to use regex to match a JSON value with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1522486993,
        "creation_date": 1522368675,
        "last_edit_date": 1522486993,
        "question_id": 49566793,
        "body_markdown": "My JSON data:\r\n\r\n    [\r\n      &quot;delivery_1b36940ef75c49a8864d8cb3ea6a3a9f&quot;,\r\n      &quot;toPayBtn_10021&quot;,\r\n      &quot;item_fdd0772d0dd74dea93033761ca14e781&quot;,\r\n      &quot;item_4f1a3f6fd3afdb940be008a0d325f9ad&quot;,\r\n      &quot;delivery_d69dc5e9df971c9b2b1736c2231cb4a9&quot;,\r\n      &quot;orderTotal_1&quot;,\r\n      &quot;address_BILLING#1&quot;,\r\n      &quot;delivery_185e36d98d5e4cc1808e59e44df8c71c&quot;,\r\n      &quot;voucherInput_1&quot;,\r\n      &quot;address_DELIVERY#1&quot;,\r\n      &quot;item_864e1a7daf2aa424cbcb2251d55abda9&quot;,\r\n      &quot;item_913196f953cbe8cfc2851c8fa9498607&quot;\r\n    ]\r\n\r\nI want to match `toPayBtn_10021` but the number after `toPayBtn_` is dynamic, it can be `toPayBtn_10` `toPayBtn_2` `toPayBtn_847` etc...\r\nI have tried \r\n\r\n    jq &#39;.toPayBtn_*&#39;\r\n\r\nbut it doesn&#39;t work, how do I fix it ?",
        "link": "https://stackoverflow.com/questions/49566793/how-to-use-regex-to-match-a-json-value-with-jq",
        "title": "How to use regex to match a JSON value with jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522407638,
                "post_id": 49573125,
                "comment_id": 86153714,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4734553,
                    "reputation": 1499,
                    "user_id": 3829310,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/blWdU.jpg?s=256",
                    "display_name": "Steve Amerige",
                    "link": "https://stackoverflow.com/users/3829310/steve-amerige"
                },
                "reply_to_user": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522409772,
                "post_id": 49573125,
                "comment_id": 86154612,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1522412898,
                "post_id": 49573125,
                "comment_id": 86156273,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1522413058,
                "creation_date": 1522413058,
                "answer_id": 49574483,
                "question_id": 49573125,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A simpler way to get three objects is `jq &#39;{(.entity.name): .metadata.guid}&#39; input.json`.\r\n\r\nWrapping the key (`.entity.name`) into parentheses tells `jq` to [evaluate it as an expression](https://stedolan.github.io/jq/manual/#ObjectConstruction:{}), not as a string.\r\n\r\nThis leads to a simpler form of what you already have (using two invocations of `jq`):\r\n\r\n    $ jq &#39;{(.entity.name): .metadata.guid}&#39; input.json | jq -s add\r\n    {\r\n      &quot;first&quot;: &quot;07f90eed-105d-41b2-bc20-4c20dfb51653&quot;,\r\n      &quot;second&quot;: &quot;da187e3a-8db9-49fd-8c05-41f29cf87f51&quot;,\r\n      &quot;third&quot;: &quot;6685c3af-5427-4add-8764-7b18ae3c23bb&quot;\r\n    }\r\n\r\n",
                "title": "jq: How to combine disjoint object values as a single object of key/value pairs?"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1522416647,
                "creation_date": 1522416647,
                "answer_id": 49575424,
                "question_id": 49573125,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With single **`jq`** command:\r\n\r\n    jq -s &#39;[.[] | { (.entity.name): .metadata.guid }] | add&#39; input.json\r\n\r\n- `-s` (`--slurp`) - instead of running the filter for each JSON object in the input, read the entire input stream into a large array and run the filter just once.\r\n\r\n\r\n----------\r\n\r\n\r\nThe output:\r\n\r\n    {\r\n      &quot;first&quot;: &quot;07f90eed-105d-41b2-bc20-4c20dfb51653&quot;,\r\n      &quot;second&quot;: &quot;da187e3a-8db9-49fd-8c05-41f29cf87f51&quot;,\r\n      &quot;third&quot;: &quot;6685c3af-5427-4add-8764-7b18ae3c23bb&quot;\r\n    }\r\n\r\n",
                "title": "jq: How to combine disjoint object values as a single object of key/value pairs?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1522416647,
        "creation_date": 1522407435,
        "last_edit_date": 1522411270,
        "question_id": 49573125,
        "body_markdown": "If I have a JSON input data:\r\n\r\n**input.json**\r\n\r\n    {\r\n       &quot;metadata&quot;: {\r\n          &quot;guid&quot;: &quot;07f90eed-105d-41b2-bc20-4c20dfb51653&quot;\r\n       },\r\n       &quot;entity&quot;: {\r\n          &quot;name&quot;: &quot;first&quot;\r\n       }\r\n    }\r\n    {\r\n       &quot;metadata&quot;: {\r\n          &quot;guid&quot;: &quot;da187e3a-8db9-49fd-8c05-41f29cf87f51&quot;\r\n       },\r\n       &quot;entity&quot;: {\r\n          &quot;name&quot;: &quot;second&quot;\r\n       }\r\n    }\r\n    {\r\n       &quot;metadata&quot;: {\r\n          &quot;guid&quot;: &quot;6685c3af-5427-4add-8764-7b18ae3c23bb&quot;\r\n       },\r\n       &quot;entity&quot;: {\r\n          &quot;name&quot;: &quot;third&quot;\r\n       }\r\n    }\r\n\r\nand I want to create from it the following:\r\n\r\n    {\r\n      &quot;first&quot;: &quot;07f90eed-105d-41b2-bc20-4c20dfb51653&quot;,\r\n      &quot;second&quot;: &quot;da187e3a-8db9-49fd-8c05-41f29cf87f51&quot;,\r\n      &quot;third&quot;: &quot;6685c3af-5427-4add-8764-7b18ae3c23bb&quot;\r\n    }\r\n\r\nThat is, the input data is a collection of separate JSON objects, each of which has the structure shown. I want the output to be a single JSON object where the key is the `.entity.name` and the value is the `.metadata.guid`.\r\n\r\nI have tried:\r\n\r\n    jq -r &#39;{.entity.name: .metadata.guid}&#39; input.json\r\n    jq -r &#39;map({(.entity.name): .metadata.guid})&#39; input.json\r\n\r\nbut these just yields a syntax error. The closest I got was:\r\n\r\n    jq -r &#39;.entity.name as $name|.metadata.guid as $guid | { ($name) : ($guid) }&#39; input.json\r\n    {\r\n      &quot;first&quot;: &quot;07f90eed-105d-41b2-bc20-4c20dfb51653&quot;\r\n    }\r\n    {\r\n      &quot;second&quot;: &quot;da187e3a-8db9-49fd-8c05-41f29cf87f51&quot;\r\n    }\r\n    {\r\n      &quot;third&quot;: &quot;6685c3af-5427-4add-8764-7b18ae3c23bb&quot;\r\n    }\r\n\r\nBut, the there are still 3 objects (not 1).\r\n\r\nI did get one form to give me what I want, but I suspect there is an easier way to do this:\r\n\r\n    jq -r &#39;.entity.name as $name|.metadata.guid as $guid | { ($name) : ($guid) }&#39; input.json | jq -s add\r\n    {\r\n      &quot;first&quot;: &quot;07f90eed-105d-41b2-bc20-4c20dfb51653&quot;,\r\n      &quot;second&quot;: &quot;da187e3a-8db9-49fd-8c05-41f29cf87f51&quot;,\r\n      &quot;third&quot;: &quot;6685c3af-5427-4add-8764-7b18ae3c23bb&quot;\r\n    }\r\n\r\nAny thoughts how how to do this properly?",
        "link": "https://stackoverflow.com/questions/49573125/jq-how-to-combine-disjoint-object-values-as-a-single-object-of-key-value-pairs",
        "title": "jq: How to combine disjoint object values as a single object of key/value pairs?"
    },
    {
        "tags": [
            "json",
            "bash",
            "select",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1522415246,
                "creation_date": 1522415246,
                "answer_id": 49575050,
                "question_id": 49574764,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -r &#39;to_entries[] | select(.value.name == &quot;subaccount1&quot;).key&#39; file.json\r\nThe output:\r\n\r\n    201803271459ICV69",
                "title": "How to get the keyid of an object in a JSON file if one of the fields contains a specific string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1522415246,
        "creation_date": 1522414085,
        "question_id": 49574764,
        "body_markdown": "I have the following JSON:\r\n\r\n    {\r\n      &quot;201110131738QP27N&quot;: {\r\n        &quot;parent&quot;: 17,\r\n        &quot;name&quot;: &quot;CentralServer&quot;,\r\n        &quot;status&quot;: &quot;Active&quot;,\r\n        &quot;count&quot;: 6\r\n      },\r\n      &quot;201803271459ICV69&quot;: {\r\n        &quot;name&quot;: &quot;subaccount1&quot;,\r\n        &quot;status&quot;: &quot;Active&quot;,\r\n        &quot;count&quot;: 1\r\n      },\r\n      &quot;2018032715008ZM2G&quot;: {\r\n        &quot;name&quot;: &quot;subaccount2&quot;,\r\n        &quot;status&quot;: &quot;Active&quot;,\r\n        &quot;count&quot;: 1\r\n      },\r\n      &quot;201803281536PSKR4&quot;: {\r\n        &quot;name&quot;: &quot;Este e um teste&quot;,\r\n        &quot;status&quot;: &quot;Active&quot;\r\n      }\r\n    }\r\n\r\nI would like to know if there is any way I can enter the contents of the key name and &quot;jq&quot; gives me the KeyID?\r\nFor example:\r\nI inform &quot;**subaccount1**&quot; on the command and jq returns me: **201803271459ICV69**&quot;\r\n\r\nI&#39;m trying the following command but with no success.\r\n\r\n    cat file.json | jq -r &#39;. | select(.[].name | contains(&quot;subaccount2&quot;)) | keys &#39;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49574764/how-to-get-the-keyid-of-an-object-in-a-json-file-if-one-of-the-fields-contains-a",
        "title": "How to get the keyid of an object in a JSON file if one of the fields contains a specific string"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7095226,
                    "reputation": 529,
                    "user_id": 5429075,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/902e93ce18895308c55265b2384da860?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Naveen K Reddy",
                    "link": "https://stackoverflow.com/users/5429075/naveen-k-reddy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522425238,
                "post_id": 49577421,
                "comment_id": 86162469,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1375260,
                    "reputation": 5506,
                    "user_id": 1309377,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/146f2e565bbff3a4a8220665e7155086?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Andrew L",
                    "link": "https://stackoverflow.com/users/1309377/andrew-l"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522425995,
                "post_id": 49577421,
                "comment_id": 86162841,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7095226,
                    "reputation": 529,
                    "user_id": 5429075,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/902e93ce18895308c55265b2384da860?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Naveen K Reddy",
                    "link": "https://stackoverflow.com/users/5429075/naveen-k-reddy"
                },
                "reply_to_user": {
                    "account_id": 1375260,
                    "reputation": 5506,
                    "user_id": 1309377,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/146f2e565bbff3a4a8220665e7155086?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Andrew L",
                    "link": "https://stackoverflow.com/users/1309377/andrew-l"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522426266,
                "post_id": 49577421,
                "comment_id": 86162943,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1522430612,
                "creation_date": 1522430612,
                "answer_id": 49578673,
                "question_id": 49577421,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Simple **`jq`** approach:\r\n\r\n    jq &#39;.[] |= . + {(.server):.status}&#39; file.json\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;organizationId&quot;: &quot;org1&quot;,\r\n        &quot;runtimeVersion&quot;: &quot;3545&quot;,\r\n        &quot;type&quot;: &quot;rest-api&quot;,\r\n        &quot;server&quot;: &quot;test1&quot;,\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;test1&quot;: &quot;UP&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "jq update json - key being value of some key and value being value of some other key"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1522435029,
                "last_edit_date": 1522435029,
                "creation_date": 1522431985,
                "answer_id": 49578960,
                "question_id": 49577421,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In the spirit of Polya&#39;s &quot;How to Solve It&quot;, let&#39;s start by observing that the fact that the object to be updated is in an array is a distraction, so let&#39;s focus on the task at hand: \r\n     &gt; adding a key-value pair to a JSON object\r\n\r\n&quot;Add&quot; is thus a helpful word to keep in mind, and indeed looking at the jq manual, you will find both &quot;+&quot; and &quot;add&quot;.  If . is the starting object, then we could achieve the update by writing:\r\n\r\n    . + {(.server): .status}\r\n\r\n(The parentheses around `.server` are necessary as `.server` has to be evaluated.)\r\nThe above expression is a filter, and the usual way of applying a filter to each member of an array is using `map`.  This leads to what might be the most &quot;elementary&quot; (as in &quot;my dear Watson&quot;) solution to the problem:\r\n\r\n    map(. + {(.server): .status})\r\n\r\nAnother approach would be to use the &quot;assignment syntax&quot; to add (or modify) a key, leading to an even shorter solution:\r\n\r\n    map( .[.server] = .status )\r\n\r\nMaybe that is no less elementary ...\r\n\r\n",
                "title": "jq update json - key being value of some key and value being value of some other key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1522435029,
        "creation_date": 1522425165,
        "last_edit_date": 1522425733,
        "question_id": 49577421,
        "body_markdown": "&gt; Sample **input.json**\r\n\r\n&lt;pre&gt;&lt;code&gt;\r\n    [{\r\n  \t&quot;organizationId&quot;: &quot;org1&quot;,\r\n  \t&quot;runtimeVersion&quot;: &quot;3545&quot;,\r\n  \t&quot;type&quot;: &quot;rest-api&quot;,\r\n    &quot;server&quot;: &quot;test1&quot;,\r\n    &quot;status&quot;: &quot;UP&quot;\r\n   }]\r\n&lt;/pre&gt;&lt;/code&gt;\r\n\r\n\r\n&gt; Expected **output.json**\r\n\r\n&lt;pre&gt;&lt;code&gt;\r\n      [{\r\n  \t&quot;organizationId&quot;: &quot;org1&quot;,\r\n  \t&quot;runtimeVersion&quot;: &quot;3545&quot;,\r\n  \t&quot;type&quot;: &quot;rest-api&quot;,\r\n    &quot;server&quot;: &quot;test1&quot;,\r\n    &quot;status&quot;: &quot;UP&quot;,\r\n    &quot;test1&quot;: &quot;UP&quot;\r\n  }]\r\n&lt;/pre&gt;&lt;/code&gt;\r\n\r\nThe input is an array object. I need to add new key which is the value of key **server**. The value of this new key should value of the key **status**. \r\n\r\nAny solutions on achieving this using **jq**",
        "link": "https://stackoverflow.com/questions/49577421/jq-update-json-key-being-value-of-some-key-and-value-being-value-of-some-other",
        "title": "jq update json - key being value of some key and value being value of some other key"
    },
    {
        "tags": [
            "merge",
            "grouping",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522499941,
                "post_id": 49586355,
                "comment_id": 86183287,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7095226,
                    "reputation": 529,
                    "user_id": 5429075,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/902e93ce18895308c55265b2384da860?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Naveen K Reddy",
                    "link": "https://stackoverflow.com/users/5429075/naveen-k-reddy"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522510124,
                "post_id": 49586355,
                "comment_id": 86186428,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1522509997,
                "creation_date": 1522509997,
                "answer_id": 49589366,
                "question_id": 49586355,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For wider audience, solution to get all objects (grouped &amp; ungrouped), use below\r\n\r\n`jq -s &#39;[ .[0] + .[1] | group_by(.organizationId)[] |add ]&#39; &#236;nput1.json input2.json`\r\n\r\nIf only grouped objects, then use below.\r\n\r\n`jq -s &#39;[ .[0] + .[1] | group_by(.organizationId)[] | select(length &gt; 1) | add ]&#39; &#236;nput1.json input2.json`\r\n\r\nI have to say **jq is so powerful**! :)",
                "title": "how to compare one field that is common in each object of an array in two files and do update the array as well"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1522509997,
        "creation_date": 1522489231,
        "last_edit_date": 1522509772,
        "question_id": 49586355,
        "body_markdown": "&gt; Sample **input1.json**\r\n\r\n&lt;pre&gt;&lt;code&gt;\r\n[{\r\n\t&quot;organizationId&quot;: &quot;org1&quot;,\r\n\t&quot;test1&quot;: &quot;UP&quot;,\r\n\t&quot;key1&quot;: &quot;value1&quot;\r\n}, \r\n{\r\n\t&quot;organizationId&quot;: &quot;org2&quot;,\r\n\t&quot;test1&quot;: &quot;UP&quot;,\r\n\t&quot;key1&quot;: &quot;value3&quot;\r\n}]\r\n&lt;/pre&gt;&lt;/code&gt;\r\n\r\n&gt; Sample **input2.json**\r\n\r\n&lt;pre&gt;&lt;code&gt;\r\n[{\r\n\t&quot;organizationId&quot;: &quot;org1&quot;,\r\n\t&quot;test2&quot;: &quot;DOWN&quot;,\r\n\t&quot;key1&quot;: &quot;value4&quot;\r\n}, \r\n{\r\n\t&quot;organizationId&quot;: &quot;org3&quot;,\r\n\t&quot;test2&quot;: &quot;DOWN&quot;,\r\n\t&quot;key1&quot;: &quot;value5&quot;\r\n}]\r\n&lt;/pre&gt;&lt;/code&gt;\r\n\r\n&gt; Expected **output.json**\r\n\r\n&lt;pre&gt;&lt;code&gt;\r\n[{\r\n\t\t&quot;organizationId&quot;: &quot;org1&quot;,\r\n\t\t&quot;test1&quot;: &quot;UP&quot;,\r\n\t\t&quot;key1&quot;: &quot;value4&quot;,\r\n\t\t&quot;test2&quot;: &quot;DOWN&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;organizationId&quot;: &quot;org2&quot;,\r\n\t\t&quot;test1&quot;: &quot;UP&quot;,\r\n\t\t&quot;key1&quot;: &quot;value3&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;organizationId&quot;: &quot;org3&quot;,\r\n\t\t&quot;test2&quot;: &quot;DOWN&quot;,\r\n\t\t&quot;key1&quot;: &quot;value5&quot;\r\n\t}\r\n]\r\n&lt;/pre&gt;&lt;/code&gt;\r\n\r\nThe input is an array object of two files. My objective is to merge two objects if they have same value and leave other objects intact. I partially achieved this by grouping \r\n\r\n`jq -s &#39;[ .[0] + .[1] | group_by(.organizationId)[] | select(length &gt; 1) |add ]&#39; &#236;nput1.json input2.json`\r\n\r\nGroup objects by **organizationId**. In both the inputs, **&quot;organizationId&quot;: &quot;org1&quot;** is available so it can be grouped. Now the problem I&#39;m facing is I&#39;m loosing other objects **&quot;organizationId&quot;: &quot;org2&quot;** from **input1.json** and **&quot;organizationId&quot;: &quot;org3&quot;** from **input2.json** which doesn&#39;t exist in each others file. \r\n\r\nThe basic principle of grouping is achieved but I do need to preserve any other objects from both the files even if there is no match. Should we use **group_by** if we want to preserve other objects? If not, how can I achieve the expected output using **jq**?",
        "link": "https://stackoverflow.com/questions/49586355/how-to-compare-one-field-that-is-common-in-each-object-of-an-array-in-two-files",
        "title": "how to compare one field that is common in each object of an array in two files and do update the array as well"
    },
    {
        "tags": [
            "json",
            "insert",
            "edit",
            "key-value",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1522687836,
                "post_id": 49589613,
                "comment_id": 86237070,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1522719581,
                "last_edit_date": 1522719581,
                "creation_date": 1522519179,
                "answer_id": 49590787,
                "question_id": 49589613,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The simplest approach would be to use `to_entries` to convert `.hierarchy.structure` into an array, perform the insertion, and then use `from_entries` to reconstitute the object, along the lines of:\r\n\r\n    .hierarchy.structure |= (to_entries\r\n      | ... as $ix\r\n      | .[:$ix] + ($x | to_entries) + .[$ix:]\r\n      | from_entries)\r\n \r\nThe above sketch of course would need to be modified if it is possible that the item defining the insertion point cannot be found.\r\n      \r\n## `indexof/1`\r\n\r\nHere&#39;s a useful &quot;def&quot; for finding the least index for which some condition holds:\r\n\r\n    # If the input is an array, emit the least index, $i, \r\n    # for which `.[$i]|f` is truthy, otherwise emit null.\r\n    # Works similarly if the input is a JSON object.\r\n    def indexof(f):\r\n      label $out\r\n      | foreach .[] as $x (null; .+1;\r\n          if ($x|f) then (.-1, break $out) else empty end) // null;\r\n\r\n## Solution using `indexof`\r\n \r\nPutting the above pieces together:\r\n\r\n    {&quot;offline_11018&quot;: [ &quot;instruction_908&quot;, &quot;checkboxList_11019&quot; ]} as $x\r\n    | .hierarchy.structure |= (to_entries\r\n        | (1 + indexof( .value | index(&quot;mainContainer_11007&quot;) )) as $ix\r\n        | .[:$ix] + ($x | to_entries) + .[$ix:]\r\n        | from_entries)\r\n\r\n",
                "title": "How to insert a key-value pair after a specified key in a JSON object using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1522719581,
        "creation_date": 1522511432,
        "last_edit_date": 1522566156,
        "question_id": 49589613,
        "body_markdown": "I have a JSON file like this\r\n\r\n    {\r\n    \t&quot;hierarchy&quot;: {\r\n    \t\t&quot;structure&quot;: {\r\n    \t\t\t&quot;card_11001&quot;: [\r\n    \t\t\t\t&quot;addCard_4111&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;container_11006&quot;: [\r\n    \t\t\t\t&quot;mainContainer_11007&quot;,\r\n    \t\t\t\t&quot;subContainer_10016&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;mainContainer_11007&quot;: [\r\n    \t\t\t\t&quot;paymentMethodList_10001&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;orderWrap_10012&quot;: [\r\n    \t\t\t\t&quot;orderSummary_10005&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;paymentMethodList_10001&quot;: [\r\n    \t\t\t\t&quot;card_11001&quot;,\r\n    \t\t\t\t&quot;placeOrder_10013&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;root_10000&quot;: [\r\n    \t\t\t\t&quot;payNotice_11011&quot;,\r\n    \t\t\t\t&quot;payNotice_10020&quot;,\r\n    \t\t\t\t&quot;container_11006&quot;,\r\n    \t\t\t\t&quot;placeOrderResultAction_10004&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;subContainer_10016&quot;: [\r\n    \t\t\t\t&quot;orderWrap_10012&quot;,\r\n    \t\t\t\t&quot;footer_10014&quot;\r\n    \t\t\t]\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nAnd I want to insert\r\n\r\n    &quot;offline_11018&quot;: [\r\n    \t&quot;instruction_908&quot;,\r\n    \t&quot;checkboxList_11019&quot;\r\n    ]\r\nBetween `&quot;mainContainer_11007&quot;` and `&quot;orderWrap_10012&quot;` so the result I want should look like this:\r\n\r\n    {\r\n    \t&quot;hierarchy&quot;: {\r\n    \t\t&quot;structure&quot;: {\r\n    \t\t\t&quot;card_11001&quot;: [\r\n    \t\t\t\t&quot;addCard_4111&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;container_11006&quot;: [\r\n    \t\t\t\t&quot;mainContainer_11007&quot;,\r\n    \t\t\t\t&quot;subContainer_10016&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;mainContainer_11007&quot;: [\r\n    \t\t\t\t&quot;paymentMethodList_10001&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;offline_11018&quot;: [\r\n    \t\t\t\t&quot;instruction_908&quot;,\r\n    \t\t\t\t&quot;checkboxList_11019&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;orderWrap_10012&quot;: [\r\n    \t\t\t\t&quot;orderSummary_10005&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;paymentMethodList_10001&quot;: [\r\n    \t\t\t\t&quot;card_11001&quot;,\r\n    \t\t\t\t&quot;placeOrder_10013&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;root_10000&quot;: [\r\n    \t\t\t\t&quot;payNotice_11011&quot;,\r\n    \t\t\t\t&quot;payNotice_10020&quot;,\r\n    \t\t\t\t&quot;container_11006&quot;,\r\n    \t\t\t\t&quot;placeOrderResultAction_10004&quot;\r\n    \t\t\t],\r\n    \t\t\t&quot;subContainer_10016&quot;: [\r\n    \t\t\t\t&quot;orderWrap_10012&quot;,\r\n    \t\t\t\t&quot;footer_10014&quot;\r\n    \t\t\t]\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nAll I know is that I can only append it to the end of file with \r\n\r\n    jq --raw-output &#39;.hierarchy.structure + {&quot;offline_11018&quot;: [&quot;instruction_908&quot;,&quot;checkboxList_11019&quot;]}&#39;\r\n\r\nBut that&#39;s not what I want, I want to insert it between two other keys. How can I do it with the jq command?",
        "link": "https://stackoverflow.com/questions/49589613/how-to-insert-a-key-value-pair-after-a-specified-key-in-a-json-object-using-jq",
        "title": "How to insert a key-value pair after a specified key in a JSON object using jq?"
    },
    {
        "tags": [
            "shell",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1522759765,
                "post_id": 49629818,
                "comment_id": 86267819,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1522765828,
                "post_id": 49629818,
                "comment_id": 86272399,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522767969,
                "post_id": 49629818,
                "comment_id": 86274053,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4033237,
                    "reputation": 2139,
                    "user_id": 3331076,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/DibEn.jpg?s=256",
                    "display_name": "Jayesh Dhandha",
                    "link": "https://stackoverflow.com/users/3331076/jayesh-dhandha"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522820281,
                "post_id": 49629818,
                "comment_id": 86294601,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1522834195,
                "creation_date": 1522834195,
                "answer_id": 49647438,
                "question_id": 49629818,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The description of the task does not seem to match the given input and output, but the following should get you on your way, as it illustrates the piece you seem to be missing -- that is, to combine the two operations, simply combine them into a pipeline (i.e., using `|`).\r\n\r\nAnother key point is that it is advisable to pass in parameters (such as `$region` in the present case) as arguments to the jq program.\r\n\r\n### program.jq\r\n      .Statement += [ \r\n        {\r\n         &quot;Sid&quot;: &quot;AllowForSpecificLambda&quot;,\r\n         &quot;Effect&quot;: &quot;Allow&quot;,\r\n         &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: [\r\n                &quot;arn:aws:iam::XXXXXXXXXX:role/lambda_allow_pretoken_generation&quot;\r\n            ]\r\n           },\r\n         &quot;Action&quot;: &quot;s3:Get*&quot;,&quot;Resource&quot;: [\r\n                &quot;arn:aws:s3:::test-XXXX-cognito-settings-&quot; + $region\r\n        \r\n                ]}\r\n        \t]\r\n      | .Statement[0].Condition.StringNotLike.&quot;aws:userId&quot; += [&quot;Hello&quot;]\r\n\r\n### Invocation\r\nAssuming you want `$region` to have some value, say &quot;REGION&quot;:\r\n\r\n    jq --arg region REGION -f program.jq test.json",
                "title": "Add and modify JSON object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1522834195,
        "creation_date": 1522757528,
        "last_edit_date": 1522770085,
        "question_id": 49629818,
        "body_markdown": "Sample JSON Input: \r\n \r\n     {  \r\n    &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n      &quot;Statement&quot;: [\r\n        {\r\n          &quot;Sid&quot;: &quot;AllowFullAccess&quot;,\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: [\r\n              &quot;arn:aws:iam::XXXX:user/test&quot;,\r\n              &quot;arn:aws:iam::XXXX:root&quot;\r\n            ]\r\n          },\r\n          &quot;Action&quot;: &quot;s3:*&quot;,\r\n          &quot;Resource&quot;: [\r\n            &quot;arn:aws:s3:::test-dev-cognito-settings-us-west-2/*&quot;\r\n          ],\r\n          &quot;Condition&quot;: {\r\n            &quot;StringNotLike&quot;: {\r\n              &quot;aws:userId&quot;: [\r\n                &quot;AZASDASDSADA&quot;\r\n              ]\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nExpected JSON Output:\r\n\r\n   \r\n\r\n      {  \r\n    &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n      &quot;Statement&quot;: [\r\n        {\r\n          &quot;Sid&quot;: &quot;AllowFullAccess&quot;,\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: [\r\n              &quot;arn:aws:iam::XXXX:user/test&quot;,\r\n              &quot;arn:aws:iam::XXXX:root&quot;\r\n            ]\r\n          },\r\n          &quot;Action&quot;: &quot;s3:*&quot;,\r\n          &quot;Resource&quot;: [\r\n            &quot;arn:aws:s3:::test-dev-cognito-settings-us-west-2/*&quot;\r\n          ],\r\n          &quot;Condition&quot;: {\r\n            &quot;StringNotLike&quot;: {\r\n              &quot;aws:userId&quot;: [\r\n                &quot;AZALEA&quot;,\n                &quot;Hello&quot;\r\n              ]\r\n            }\r\n          }\r\n    },\r\n    {\r\n      &quot;Sid&quot;: &quot;AllowForSpecificLambda_jdtest&quot;,\r\n      &quot;Effect&quot;: &quot;Allow&quot;,\r\n      &quot;Principal&quot;: {\r\n        &quot;AWS&quot;: &quot;AROAIBA5TVJCIN3OCE2YI&quot;\r\n      },\r\n      &quot;Action&quot;: &quot;s3:Get*&quot;,\r\n      &quot;Resource&quot;: [\r\n        &quot;arn:aws:s3:::oppscience-dev-cognito-settings-us-west-2&quot;,\r\n        &quot;arn:aws:s3:::oppscience-dev-cognito-settings-us-west-2/*&quot;\r\n      ],\r\n      &quot;Condition&quot;: {\r\n        &quot;StringNotLike&quot;: {\r\n          &quot;aws:userId&quot;: [\r\n            &quot;AZA&quot;\r\n          ]\r\n        }\r\n      }\r\n     ]\r\n    }\r\n\r\nPardon me i have done some syntax mistake in the json tags. \r\nAll i want is inside my statement array object i want to add new object + modify existing object.\r\nI am adding new JSON object using [jq][1]. Below is my code snippet which is working fine.\r\n\r\n    jq &#39;.Statement[.Statement| length] |= . + {\r\n     &quot;Sid&quot;: &quot;AllowForSpecificLambda&quot;,\r\n     &quot;Effect&quot;: &quot;Allow&quot;,\r\n     &quot;Principal&quot;: {\r\n  \t\t&quot;AWS&quot;: [\r\n  \t\t\t&quot;arn:aws:iam::XXXXXXXXXX:role/lambda_allow_pretoken_generation&quot;\r\n  \t\t]\r\n\t   },\r\n     &quot;Action&quot;: &quot;s3:Get*&quot;,&quot;Resource&quot;: [\r\n     \t\t&quot;arn:aws:s3:::test-XXXX-cognito-settings-&#39;$region&#39;&quot;\r\n                \r\n            ]}&#39; test.json &gt; test-1.json\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/\r\n\r\nI am addin new value in my JSON array using below code snippet.\r\n\r\n    jq &#39;.Statement[] \r\n\r\n    | select(.Sid == &quot;Test&quot;) \r\n    .Condition.StringNotLike.&quot;aws:userId&quot;[.Condition.StringNotLike.&quot;aws:userId&quot;| length] \r\n    |= . + &quot;Hello&quot;&#39; test.json\r\n\r\nHow can i do this two things in single command? \r\n\r\nThanks\r\n",
        "link": "https://stackoverflow.com/questions/49629818/add-and-modify-json-object-using-jq",
        "title": "Add and modify JSON object using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 59,
                "is_accepted": true,
                "score": 59,
                "last_activity_date": 1522766706,
                "creation_date": 1522766706,
                "answer_id": 49632947,
                "question_id": 49632521,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This type of update is where the magic of `+=` comes into play.  With your input, the following invocation:\r\n\r\n    jq &#39;.module.data.item_i77f664a2.fields += {&quot;operation&quot;:&quot;delete&quot;}&#39;\r\n\r\nproduces the output you indicate you want:\r\n\r\n    {\r\n      &quot;success&quot;: true,\r\n      &quot;module&quot;: {\r\n        &quot;data&quot;: {\r\n          &quot;item_i77f664a2&quot;: {\r\n            &quot;id&quot;: &quot;i77f664a2&quot;,\r\n            &quot;tag&quot;: &quot;item&quot;,\r\n            &quot;fields&quot;: {\r\n              &quot;cartItemId&quot;: 2012636322,\r\n              &quot;operation&quot;: &quot;delete&quot;\r\n            },\r\n            &quot;type&quot;: &quot;biz&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nHowever, I am not sure that this will produce what you want in similar circumstances, as you have referenced &quot;item_i77f61ee2&quot;.",
                "title": "How to add a field to a JSON object with the jq command?"
            },
            {
                "up_vote_count": 18,
                "is_accepted": false,
                "score": 18,
                "last_activity_date": 1630321106,
                "creation_date": 1630321106,
                "answer_id": 68982969,
                "question_id": 49632521,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks to @peak for his answer!\r\n\r\nJust want to add,\r\n\r\nCreating a blank json file:\r\n\r\n    echo &quot;{}&quot; &gt; config.json\r\n\r\nFile Content:\r\n\r\n    {}\r\n\r\nThen add properties to the file:\r\n\r\n    echo &quot;$(jq &#39;. += {&quot;url&quot;: &quot;https://url.com&quot;}&#39; config.json)&quot; &gt; config.json\r\n\r\nFile Content:\r\n\r\n    {\r\n        &quot;url&quot;: &quot;https://url.com&quot;\r\n    }\r\n\r\nOne  more property:\r\n\r\n    echo &quot;$(jq &#39;. += {&quot;name&quot;: &quot;a Name&quot;}&#39; config.json)&quot; &gt; config.json\r\n\r\nFile Content:\r\n\r\n    {\r\n        &quot;url&quot;: &quot;https://url.com&quot;,\r\n        &quot;name&quot;: &quot;a Name&quot;\r\n    }\r\n\r\nIf you have variables set and want to use that value (ie. Azure Build Pipelines) you can pass in that value as an argument (`urlarg` in this case):\r\n\r\n    URL=&quot;https://url.com&quot;\r\n    echo &quot;$(jq --arg urlarg &quot;$URL&quot; &#39;. += {&quot;url&quot;: $urlarg}&#39; config.json)&quot; &gt; config.json",
                "title": "How to add a field to a JSON object with the jq command?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 43,
        "last_activity_date": 1630321106,
        "creation_date": 1522765490,
        "last_edit_date": 1522768539,
        "question_id": 49632521,
        "body_markdown": "I have this JSON data:\r\n\r\n    {\r\n    \t&quot;success&quot;: true,\r\n    \t&quot;module&quot;: {\r\n    \t\t&quot;data&quot;: {\r\n    \t\t\t&quot;item_i77f664a2&quot;: {\r\n    \t\t\t\t&quot;id&quot;: &quot;i77f664a2&quot;,\r\n    \t\t\t\t&quot;tag&quot;: &quot;item&quot;,\r\n    \t\t\t\t&quot;fields&quot;: {\r\n    \t\t\t\t\t&quot;cartItemId&quot;: 2012636322\r\n    \t\t\t\t},\r\n    \t\t\t\t&quot;type&quot;: &quot;biz&quot;\r\n    \t\t\t}\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nAnd I want to add `{&quot;operation&quot;:&quot;delete&quot;}` right below `cartItemId` and then save the JSON data to a file. The result that I want is like this:\r\n\r\n    {\r\n    \t&quot;success&quot;: true,\r\n    \t&quot;module&quot;: {\r\n    \t\t&quot;data&quot;: {\r\n    \t\t\t&quot;item_i77f664a2&quot;: {\r\n    \t\t\t\t&quot;id&quot;: &quot;i77f664a2&quot;,\r\n    \t\t\t\t&quot;tag&quot;: &quot;item&quot;,\r\n    \t\t\t\t&quot;fields&quot;: {\r\n    \t\t\t\t\t&quot;cartItemId&quot;: 2012636322,\r\n    \t\t\t\t\t&quot;operation&quot;: &quot;delete&quot;\r\n    \t\t\t\t},\r\n    \t\t\t\t&quot;type&quot;: &quot;biz&quot;\r\n    \t\t\t}\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nThis is what I have tried:\r\n\r\n    jq &#39;.module.data.item_i77f664a2.fields + {&quot;operation&quot;:&quot;delete&quot;}&#39; &gt; data.json\r\n\r\nBut it doesn&#39;t save the JSON data with the output that I want like above. How do I fix it ?",
        "link": "https://stackoverflow.com/questions/49632521/how-to-add-a-field-to-a-json-object-with-the-jq-command",
        "title": "How to add a field to a JSON object with the jq command?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522783818,
                "post_id": 49637299,
                "comment_id": 86283259,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522783870,
                "post_id": 49637299,
                "comment_id": 86283285,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1522783604,
                "creation_date": 1522783604,
                "answer_id": 49637746,
                "question_id": 49637299,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With the &quot;-r&quot; command-line option, the following filter:\r\n\r\n     [.executions[] | select(.job.name != null)]\r\n     | sort_by(.id)\r\n     | reverse \r\n     | .[0]\r\n     | [.status, .job.name, .&quot;date-ended&quot;.date]\r\n     | @csv\r\n\r\nproduces:\r\n\r\n    &quot;failed&quot;,&quot;aa&quot;,&quot;2018-04-03T17:43:38Z&quot;\r\n     \r\nAn important point that you might have missed is that &quot;-&quot; is a &quot;special&quot; character in that it can signify negation or subtraction.  \r\n\r\nIf your jq does not support the syntax `.&quot;date-ended&quot;.date`, then you could fall back to the basic syntax: `(.[&quot;date-ended&quot;] | .date)`\r\n\r\n",
                "title": "Parsing JSON file-jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1522783959,
                "creation_date": 1522783959,
                "answer_id": 49637831,
                "question_id": 49637299,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I guess you have troubles extracting `.date-ended.date` because the name contains a dash that is interpreted by `jq` as subtraction.\r\n\r\nThe solution is listed in the [documentation](https://stedolan.github.io/jq/manual/#ObjectIdentifier-Index:.foo,.foo.bar):\r\n\r\n&gt; If the key contains special characters, you need to surround it with double quotes like this: `.&quot;foo$&quot;`, or else `.[&quot;foo$&quot;]`.\r\n\r\nThis means the last filter of your `jq` program should be:\r\n\r\n    &quot;\\(.status), \\(.job.name), \\(.&quot;date-ended&quot;.date)&quot;\r\n\r\n",
                "title": "Parsing JSON file-jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1522783959,
        "creation_date": 1522781836,
        "last_edit_date": 1522782890,
        "question_id": 49637299,
        "body_markdown": "Whole file:https://1drv.ms/u/s!AizscpxS0QM4hJpEkp12VPHiKO_gBg\r\n\r\nUsing this command i get part bellow (get latest job)\r\n\r\n    jq &#39;.|[ .executions[] | select(.job.name != null) | select(.job.name) ]\r\n         | sort_by(.id)\r\n         | reverse\r\n         | .[0] &#39; 1.json\r\n\r\n \r\n\r\n    {\r\n      &quot;argstring&quot;: null,\r\n      &quot;date-ended&quot;: {\r\n        &quot;date&quot;: &quot;2018-04-03T17:43:38Z&quot;,\r\n        &quot;unixtime&quot;: 1522777418397\r\n      },\r\n      &quot;date-started&quot;: {\r\n        &quot;date&quot;: &quot;2018-04-03T17:43:34Z&quot;,\r\n        &quot;unixtime&quot;: 1522777414646\r\n      },\r\n      &quot;description&quot;: &quot;&quot;,\r\n      &quot;executionType&quot;: &quot;user&quot;,\r\n      &quot;failedNodes&quot;: [\r\n        &quot;172.30.61.88&quot;\r\n      ],\r\n      &quot;href&quot;: &quot;http://172.30.61.88:4440/api/21/execution/126&quot;,\r\n      &quot;id&quot;: 126,\r\n      &quot;job&quot;: {\r\n        &quot;averageDuration&quot;: 4197,\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;group&quot;: &quot;&quot;,\r\n        &quot;href&quot;: &quot;http://172.30.61.88:4440/api/21/job/271cbcec-5042-4d52-b794-ede2056b2ab8&quot;,\r\n        &quot;id&quot;: &quot;271cbcec-5042-4d52-b794-ede2056b2ab8&quot;,\r\n        &quot;name&quot;: &quot;aa&quot;,\r\n        &quot;permalink&quot;: &quot;http://172.30.61.88:4440/project/demo/job/show/271cbcec-5042-4d52-b794-ede2056b2ab8&quot;,\r\n        &quot;project&quot;: &quot;demo&quot;\r\n      },\r\n      &quot;permalink&quot;: &quot;http://172.30.61.88:4440/project/demo/execution/show/126&quot;,\r\n      &quot;project&quot;: &quot;demo&quot;,\r\n      &quot;status&quot;: &quot;failed&quot;,\r\n      &quot;user&quot;: &quot;administrator&quot;\r\n\r\n\r\nI managed to extract job name and status, now want to get date-ended.date ?\r\n     \r\n \r\n\r\n    jq &#39;.|[ .executions[] |select(.job.name != null) | select(.job.name) ]\r\n         | sort_by(.id)\r\n         | reverse \r\n         | .[0]\r\n         | &quot;\\(.status), \\(.job.name)&quot;&#39; 1.json\r\n\r\n \r\n\r\n",
        "link": "https://stackoverflow.com/questions/49637299/parsing-json-file-jq",
        "title": "Parsing JSON file-jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1522783770,
                "creation_date": 1522783770,
                "answer_id": 49637787,
                "question_id": 49637556,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&quot;name&quot; is not a top-level key.  Consider instead:\r\n\r\n\r\n    $ jq &#39;.items[] | .name&#39; good.json\r\n    &quot;t1&quot;\r\n    &quot;t2&quot;\r\n    &quot;t3&quot;\r\n\r\n",
                "title": "jq always gives null with the json file instead of value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1522783770,
        "creation_date": 1522782816,
        "question_id": 49637556,
        "body_markdown": "folks,\r\nI am trying to use jq to get the json values from the json file, It should give me t1, t2 and t3 but it gives me null value. I have included the json file below, I tried doing jq various options. I want to get the t1, t2, t3 values from the field &#39;name&#39;&#160;and then assign the values to a array which is variable so that I can refer to the array and do a POST.\r\n\r\n     jq &#39;.name&#39; good.json\r\n    null\r\n \r\n    $ cat good.json \r\n\r\n        {\r\n       &quot;kind&quot;: &quot;tm:ltm:virtual:virtualcollectionstate&quot;,\r\n       &quot;selfLink&quot;: &quot;https://localhost/mgmt/tm/ltm/virtual?ver=12.0.0&quot;,\r\n       &quot;items&quot;: [\r\n       {\r\n      &quot;kind&quot;: &quot;tm:ltm:virtual:virtualstate&quot;,\r\n      &quot;name&quot;: &quot;t1&quot;,\r\n      &quot;partition&quot;: &quot;Common&quot;,\r\n      &quot;fullPath&quot;: &quot;/Common/t1&quot;,\r\n      &quot;generation&quot;: 124,\r\n      &quot;selfLink&quot;: &quot;https://localhost/mgmt/tm/ltm/virtual/~Common~t1?ver=12.0.0&quot;,\r\n      &quot;addressStatus&quot;: &quot;yes&quot;,\r\n      &quot;autoLasthop&quot;: &quot;default&quot;,\r\n      &quot;cmpEnabled&quot;: &quot;yes&quot;,\r\n      &quot;connectionLimit&quot;: 0,\r\n      &quot;destination&quot;: &quot;/Common/3.3.3.3:80&quot;,\r\n      &quot;enabled&quot;: true,\r\n      &quot;gtmScore&quot;: 0,\r\n      &quot;ipProtocol&quot;: &quot;tcp&quot;,\r\n      &quot;mask&quot;: &quot;255.255.255.255&quot;,\r\n      &quot;mirror&quot;: &quot;disabled&quot;,\r\n      &quot;mobileAppTunnel&quot;: &quot;disabled&quot;,\r\n      &quot;nat64&quot;: &quot;disabled&quot;,\r\n      &quot;rateLimit&quot;: &quot;disabled&quot;,\r\n      &quot;rateLimitDstMask&quot;: 0,\r\n      &quot;rateLimitMode&quot;: &quot;object&quot;,\r\n      &quot;rateLimitSrcMask&quot;: 0,\r\n      &quot;serviceDownImmediateAction&quot;: &quot;none&quot;,\r\n      &quot;source&quot;: &quot;0.0.0.0/0&quot;,\r\n      &quot;sourceAddressTranslation&quot;: {\r\n        &quot;type&quot;: &quot;none&quot;\r\n      },\r\n      &quot;sourcePort&quot;: &quot;preserve&quot;,\r\n      &quot;synCookieStatus&quot;: &quot;not-activated&quot;,\r\n      &quot;translateAddress&quot;: &quot;enabled&quot;,\r\n      &quot;translatePort&quot;: &quot;enabled&quot;,\r\n      &quot;vlansDisabled&quot;: true,\r\n      &quot;vsIndex&quot;: 21,\r\n      &quot;policiesReference&quot;: {\r\n        &quot;link&quot;: &quot;https://localhost/mgmt/tm/ltm/virtual/~Common~t1/policies?ver=12.0.0&quot;,\r\n        &quot;isSubcollection&quot;: true\r\n      },\r\n      &quot;profilesReference&quot;: {\r\n        &quot;link&quot;: &quot;https://localhost/mgmt/tm/ltm/virtual/~Common~t1/profiles?ver=12.0.0&quot;,\r\n        &quot;isSubcollection&quot;: true\r\n        }\r\n        },\r\n       {\r\n      &quot;kind&quot;: &quot;tm:ltm:virtual:virtualstate&quot;,\r\n      &quot;name&quot;: &quot;t2&quot;,\r\n      &quot;partition&quot;: &quot;Common&quot;,\r\n      &quot;fullPath&quot;: &quot;/Common/t2&quot;,\r\n      &quot;generation&quot;: 178,\r\n      &quot;selfLink&quot;: &quot;https://localhost/mgmt/tm/ltm/virtual/~Common~t2?ver=12.0.0&quot;,\r\n      &quot;addressStatus&quot;: &quot;yes&quot;,\r\n      &quot;autoLasthop&quot;: &quot;default&quot;,\r\n      &quot;cmpEnabled&quot;: &quot;yes&quot;,\r\n      &quot;connectionLimit&quot;: 0,\r\n      &quot;destination&quot;: &quot;/Common/4.4.4.4:80&quot;,\r\n      &quot;enabled&quot;: true,\r\n      &quot;gtmScore&quot;: 0,\r\n      &quot;ipProtocol&quot;: &quot;tcp&quot;,\r\n      &quot;mask&quot;: &quot;255.255.255.255&quot;,\r\n      &quot;mirror&quot;: &quot;disabled&quot;,\r\n      &quot;mobileAppTunnel&quot;: &quot;disabled&quot;,\r\n      &quot;nat64&quot;: &quot;disabled&quot;,\r\n      &quot;rateLimit&quot;: &quot;disabled&quot;,\r\n      &quot;rateLimitDstMask&quot;: 0,\r\n      &quot;rateLimitMode&quot;: &quot;object&quot;,\r\n      &quot;rateLimitSrcMask&quot;: 0,\r\n      &quot;serviceDownImmediateAction&quot;: &quot;none&quot;,\r\n      &quot;source&quot;: &quot;0.0.0.0/0&quot;,\r\n      &quot;sourceAddressTranslation&quot;: {\r\n        &quot;type&quot;: &quot;none&quot;\r\n      },\r\n      &quot;sourcePort&quot;: &quot;preserve&quot;,\r\n      &quot;synCookieStatus&quot;: &quot;not-activated&quot;,\r\n      &quot;translateAddress&quot;: &quot;enabled&quot;,\r\n      &quot;translatePort&quot;: &quot;enabled&quot;,\r\n      &quot;vlansDisabled&quot;: true,\r\n      &quot;vsIndex&quot;: 22,\r\n      &quot;policiesReference&quot;: {\r\n        &quot;link&quot;: &quot;https://localhost/mgmt/tm/ltm/virtual/~Common~t2/policies?ver=12.0.0&quot;,\r\n        &quot;isSubcollection&quot;: true\r\n      },\r\n      &quot;profilesReference&quot;: {\r\n        &quot;link&quot;: &quot;https://localhost/mgmt/tm/ltm/virtual/~Common~t2/profiles?ver=12.0.0&quot;,\r\n        &quot;isSubcollection&quot;: true\r\n        }\r\n       },\r\n       {\r\n      &quot;kind&quot;: &quot;tm:ltm:virtual:virtualstate&quot;,\r\n      &quot;name&quot;: &quot;t3&quot;,\r\n      &quot;partition&quot;: &quot;Common&quot;,\r\n      &quot;fullPath&quot;: &quot;/Common/t3&quot;,\r\n      &quot;generation&quot;: 179,\r\n      &quot;selfLink&quot;: &quot;https://localhost/mgmt/tm/ltm/virtual/~Common~t3?ver=12.0.0&quot;,\r\n      &quot;addressStatus&quot;: &quot;yes&quot;,\r\n      &quot;autoLasthop&quot;: &quot;default&quot;,\r\n      &quot;cmpEnabled&quot;: &quot;yes&quot;,\r\n      &quot;connectionLimit&quot;: 0,\r\n      &quot;destination&quot;: &quot;/Common/5.5.5.5:80&quot;,\r\n      &quot;enabled&quot;: true,\r\n      &quot;gtmScore&quot;: 0,\r\n      &quot;ipProtocol&quot;: &quot;tcp&quot;,\r\n      &quot;mask&quot;: &quot;255.255.255.255&quot;,\r\n      &quot;mirror&quot;: &quot;disabled&quot;,\r\n      &quot;mobileAppTunnel&quot;: &quot;disabled&quot;,\r\n      &quot;nat64&quot;: &quot;disabled&quot;,\r\n      &quot;rateLimit&quot;: &quot;disabled&quot;,\r\n      &quot;rateLimitDstMask&quot;: 0,\r\n      &quot;rateLimitMode&quot;: &quot;object&quot;,\r\n      &quot;rateLimitSrcMask&quot;: 0,\r\n      &quot;serviceDownImmediateAction&quot;: &quot;none&quot;,\r\n      &quot;source&quot;: &quot;0.0.0.0/0&quot;,\r\n      &quot;sourceAddressTranslation&quot;: {\r\n        &quot;type&quot;: &quot;none&quot;\r\n      },\r\n      &quot;sourcePort&quot;: &quot;preserve&quot;,\r\n      &quot;synCookieStatus&quot;: &quot;not-activated&quot;,\r\n      &quot;translateAddress&quot;: &quot;enabled&quot;,\r\n      &quot;translatePort&quot;: &quot;enabled&quot;,\r\n      &quot;vlansDisabled&quot;: true,\r\n      &quot;vsIndex&quot;: 23,\r\n      &quot;policiesReference&quot;: {\r\n        &quot;link&quot;: &quot;https://localhost/mgmt/tm/ltm/virtual/~Common~t3/policies?ver=12.0.0&quot;,\r\n        &quot;isSubcollection&quot;: true\r\n      },\r\n      &quot;profilesReference&quot;: {\r\n        &quot;link&quot;: &quot;https://localhost/mgmt/tm/ltm/virtual/~Common~t3/profiles?ver=12.0.0&quot;,\r\n        &quot;isSubcollection&quot;: true\r\n        }\r\n       }\r\n      ]\r\n     }\r\n\r\n\r\n        ",
        "link": "https://stackoverflow.com/questions/49637556/jq-always-gives-null-with-the-json-file-instead-of-value",
        "title": "jq always gives null with the json file instead of value"
    },
    {
        "tags": [
            "json",
            "object",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6244985,
                    "reputation": 1612,
                    "user_id": 4857270,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1eb0da3084e49471a49d261e19e43556?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gerard van Helden",
                    "link": "https://stackoverflow.com/users/4857270/gerard-van-helden"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1522827697,
                "post_id": 49645325,
                "comment_id": 86298797,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 9555532,
                    "reputation": 373,
                    "user_id": 7098141,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c9bc9276167317a7d6eccfb1862eb006?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "mike",
                    "link": "https://stackoverflow.com/users/7098141/mike"
                },
                "reply_to_user": {
                    "account_id": 6244985,
                    "reputation": 1612,
                    "user_id": 4857270,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1eb0da3084e49471a49d261e19e43556?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gerard van Helden",
                    "link": "https://stackoverflow.com/users/4857270/gerard-van-helden"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522828446,
                "post_id": 49645325,
                "comment_id": 86299269,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523275180,
                "post_id": 49645325,
                "comment_id": 86478438,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1522830891,
                "last_edit_date": 1522830891,
                "creation_date": 1522830244,
                "answer_id": 49646119,
                "question_id": 49645325,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You are on the right track, you just need to map `fromjson` to the array, e.g.:\r\n\r\n    jq -Rc &#39;split(&quot;,&quot;) | map(fromjson)&#39; myfile.json\r\n\r\nOutput:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [{&quot;a&quot;:1},{&quot;b&quot;:2},{&quot;c&quot;:3},{&quot;d&quot;:2},{&quot;e&quot;:1},{&quot;f&quot;:2}]\r\n\r\nHowever, if you are dealing with huge inputs, perhaps use a more streamable command to split the input into chunks, e.g. with `tr`:\r\n\r\n    &lt;myfile.json tr &#39;,&#39; &#39;\\n&#39; | jq -c .\r\n\r\nOutput:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    {&quot;a&quot;:1}\r\n    {&quot;b&quot;:2}\r\n    {&quot;c&quot;:3}\r\n    {&quot;d&quot;:2}\r\n    {&quot;e&quot;:1}\r\n    {&quot;f&quot;:2}\r\n\r\n",
                "title": "jq convert comma separated JSON objects into array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1522834926,
                "last_edit_date": 1522834926,
                "creation_date": 1522830256,
                "answer_id": 49646128,
                "question_id": 49645325,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since you have millions of these JSON objects, let me first suggest an efficient way to produce a stream of them in the JSON-Lines format (i.e., with &quot;newline&quot; as the delimiter).\r\n\r\nWARNING: THE FOLLOWING ASSUMES THAT THE OBJECTS DO NOT CONTAIN JSON STRINGS WITH COMMAS.\r\n\r\nLet&#39;s assume the comma-separated objects are in a file named objects.txt.\r\nFirst, create a file, program.jq, with the following jq program:\r\n\r\n    def one:\r\n      (try input catch null)\r\n      | if . == 0 then empty elif . == null then one else (., one) end;\r\n    \r\n    one\r\n\r\nThen assuming your shell allows it, the invocation:\r\n\r\n     (cat objects.txt; echo 0) |\r\n       sed $&#39;s/,/,\\\\\\n/g&#39; | \r\n       jq -n -c -f program.jq objects.txt\r\n\r\nwill produce the stream, one JSON object per line. This is a very manageable format. For example, to produce an array, you could pipe the above-mentioned stream into `jq -s .`\r\n\r\nHowever, if the goal is solely to produce a JSON array, then as pointed out elsewhere, the most efficient approach would be to enclose the comma-separated objects in square brackets, along the lines of:\r\n\r\n    (echo &quot;[&quot;; cat objects.txt; echo &quot;]&quot;)\r\n\r\nSo the relevant question here, perhaps, is: what&#39;s the real goal?  It seems doubtful that having an unmanageably large array of small JSON objects is likely to more useful than either the original comma-separated sequence, or a simple stream.\r\n\r\n\r\n\r\n    ",
                "title": "jq convert comma separated JSON objects into array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1522834926,
        "creation_date": 1522827494,
        "last_edit_date": 1522834665,
        "question_id": 49645325,
        "body_markdown": "I have files which have N JSON objects and they are separated by comma (,) \r\n\r\n    {&quot;a&quot;:1},{&quot;b&quot;:2},{&quot;c&quot;:3},{&quot;d&quot;:2},{&quot;e&quot;:1},{&quot;f&quot;:2} ...\r\n\r\n\r\nI would like to convert them into one JSON array with N objects using `jq`\r\n\r\n    [{&quot;a&quot;:1},{&quot;b&quot;:2},{&quot;c&quot;:3},{&quot;d&quot;:2},{&quot;e&quot;:1},{&quot;f&quot;:2} ...]\r\n\r\nI tried `jq -R &#39;split(&quot;,&quot;)&#39; myfile.json` but it gives me an array of N strings\r\n\r\n    [\r\n      &quot;{\\&quot;a\\&quot;:1}&quot;,\r\n      &quot;{\\&quot;b\\&quot;:2}&quot;,\r\n      &quot;{\\&quot;a\\&quot;:1}&quot;,\r\n      &quot;{\\&quot;b\\&quot;:2}&quot;,\r\n      &quot;{\\&quot;a\\&quot;:1}&quot;,\r\n      &quot;{\\&quot;b\\&quot;:2}&quot;,\r\n      &quot;{\\&quot;a\\&quot;:1}&quot;,\r\n      &quot;{\\&quot;b\\&quot;:2}&quot; ....\r\n    ]\r\n\r\nAny idea?",
        "link": "https://stackoverflow.com/questions/49645325/jq-convert-comma-separated-json-objects-into-array",
        "title": "jq convert comma separated JSON objects into array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1522831015,
                "creation_date": 1522831015,
                "answer_id": 49646374,
                "question_id": 49646049,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You should add double-quotation-marks around the problematic property key like `&#39;.module.data.&quot;deliverySummary_200648721592191#address&quot;&#39;` for your case.\r\n\r\nSee the playground result [here](https://jqplay.org/s/agSDbgpIdZ).",
                "title": "How to parse a JSON key that has a hash sign # in it with the jq command?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1522831015,
        "creation_date": 1522830009,
        "question_id": 49646049,
        "body_markdown": "I have a JSON data:\r\n\r\n    {\r\n    \t&quot;module&quot;: {\r\n    \t\t&quot;data&quot;: {\r\n    \t\t\t&quot;deliverySummary_200648721592191#address&quot;: {\r\n    \t\t\t\t&quot;fields&quot;: {\r\n    \t\t\t\t\t&quot;address&quot;: &quot;MyAddress&quot;,\r\n    \t\t\t\t\t&quot;consignee&quot;: &quot;MyName&quot;,\r\n    \t\t\t\t\t&quot;phone&quot;: &quot;MyPhone&quot;,\r\n    \t\t\t\t\t&quot;postCode&quot;: &quot;&quot;,\r\n    \t\t\t\t\t&quot;title&quot;: &quot;Alamat Pengiriman \\\\r\\\\n&quot;\r\n    \t\t\t\t},\r\n    \t\t\t\t&quot;id&quot;: &quot;200648721592191#address&quot;,\r\n    \t\t\t\t&quot;tag&quot;: &quot;deliverySummary&quot;,\r\n    \t\t\t\t&quot;type&quot;: &quot;biz&quot;\r\n    \t\t\t}\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nAnd I want to extract this part:\r\n\r\n    {\r\n    \t&quot;fields&quot;: {\r\n    \t\t&quot;address&quot;: &quot;MyAddress&quot;,\r\n    \t\t&quot;consignee&quot;: &quot;MyName&quot;,\r\n    \t\t&quot;phone&quot;: &quot;MyPhone&quot;,\r\n    \t\t&quot;postCode&quot;: &quot;&quot;,\r\n    \t\t&quot;title&quot;: &quot;Alamat Pengiriman \\\\r\\\\n&quot;\r\n    \t},\r\n    \t&quot;id&quot;: &quot;200648721592191#address&quot;,\r\n    \t&quot;tag&quot;: &quot;deliverySummary&quot;,\r\n    \t&quot;type&quot;: &quot;biz&quot;\r\n    }\r\n\r\nI have tried `jq &#39;.module.data.deliverySummary_200648721592191#address&#39;` but it just returns `null` instead of the part that I want above, how do I fix it ?",
        "link": "https://stackoverflow.com/questions/49646049/how-to-parse-a-json-key-that-has-a-hash-sign-in-it-with-the-jq-command",
        "title": "How to parse a JSON key that has a hash sign # in it with the jq command?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1522868627,
                "last_edit_date": 1522868627,
                "creation_date": 1522852262,
                "answer_id": 49653720,
                "question_id": 49647599,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to quote the key names of keys that begin with a numeral, e.g.\r\n\r\n    &quot;90line&quot;: .[&quot;90line&quot;]\r\n\r\nNote also that the jq expression `{&quot;90line&quot;: .[&quot;90line&quot;]}` can be abbreviated to just `{&quot;90line&quot;}`.\r\n\r\n### Example\r\n\r\nWith your input:\r\n\r\n    $ jq &#39;[.result[] | {labelName, &quot;90line&quot;: .[&quot;90line&quot;] } ]&#39; input.json\r\n    [\r\n      {\r\n        &quot;labelName&quot;: &quot;ALL&quot;,\r\n        &quot;90line&quot;: 8\r\n      },\r\n      {\r\n        &quot;labelName&quot;: &quot;100b 3600s Cache&quot;,\r\n        &quot;90line&quot;: 7\r\n      },\r\n      {\r\n        &quot;labelName&quot;: &quot;100b NonCache&quot;,\r\n        &quot;90line&quot;: 7\r\n      }\r\n    ]\r\n        ",
                "title": "Cannot select fields beginning with numerics in jq (with references to other examples)"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1663605967,
                "creation_date": 1663605967,
                "answer_id": 73776739,
                "question_id": 49647599,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your JSON looks like this (in a file named `your.json`):\r\n\r\n```json\r\n{\r\n  &quot;banana&quot;: {\r\n    &quot;9zz&quot;: true\r\n  }\r\n}\r\n```\r\n\r\nAnd you want to grab `9zz` with `jq`, do\r\n\r\n```bash\r\njq &#39;.banana[&quot;9zz&quot;]&#39; your.json\r\n```\r\n\r\nIn other words, the two following lines are identical, but the bottom one works with values beginning with a number:\r\n\r\n```bash\r\njq &#39;.one.two&#39; your.json\r\njq &#39;.one[&quot;two&quot;]&#39; your.json\r\n```\r\n",
                "title": "Cannot select fields beginning with numerics in jq (with references to other examples)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1663605967,
        "creation_date": 1522834634,
        "last_edit_date": 1522869161,
        "question_id": 49647599,
        "body_markdown": "I have seen proposed solutions that worked for others in the following pages but I can&#39;t get it to work for me using the jqplay browser shell:\r\n\r\nhttps://github.com/stedolan/jq/issues/344\r\n\r\nhttps://github.com/stedolan/jq/issues/345\r\n\r\nhttps://github.com/stedolan/jq/issues/1304\r\n\r\n\r\nGiven this data:\r\n\r\n\r\n    {\r\n        &quot;api_version&quot;: 4,\r\n        &quot;error&quot;: null,\r\n        &quot;result&quot;: [\r\n            {\r\n                &quot;labelId&quot;: &quot;ALL&quot;,\r\n                &quot;labelName&quot;: &quot;ALL&quot;,\r\n                &quot;samples&quot;: 30104,\r\n                &quot;avgResponseTime&quot;: 6.849,\r\n                &quot;90line&quot;: 8,\r\n                &quot;95line&quot;: 9,\r\n                &quot;99line&quot;: 36,\r\n                &quot;minResponseTime&quot;: 2,\r\n                &quot;maxResponseTime&quot;: 1951,\r\n                &quot;avgLatency&quot;: 5.287,\r\n                &quot;geoMeanResponseTime&quot;: 5.484,\r\n                &quot;stDev&quot;: 23.765,\r\n                &quot;duration&quot;: 302,\r\n                &quot;avgBytes&quot;: 110.224,\r\n                &quot;avgThroughput&quot;: 99.682,\r\n                &quot;medianResponseTime&quot;: 5,\r\n                &quot;errorsCount&quot;: 0,\r\n                &quot;errorsRate&quot;: 0,\r\n                &quot;hasLabelPassedThresholds&quot;: null\r\n            },\r\n            {\r\n                &quot;labelId&quot;: &quot;3687c89fac2385d28d53b356d4785418&quot;,\r\n                &quot;labelName&quot;: &quot;100b 3600s Cache&quot;,\r\n                &quot;samples&quot;: 7300,\r\n                &quot;avgResponseTime&quot;: 6.028,\r\n                &quot;90line&quot;: 7,\r\n                &quot;95line&quot;: 8,\r\n                &quot;99line&quot;: 11,\r\n                &quot;minResponseTime&quot;: 2,\r\n                &quot;maxResponseTime&quot;: 680,\r\n                &quot;avgLatency&quot;: 6.021,\r\n                &quot;geoMeanResponseTime&quot;: 5.203,\r\n                &quot;stDev&quot;: 16.233,\r\n                &quot;duration&quot;: 300,\r\n                &quot;avgBytes&quot;: 16.581,\r\n                &quot;avgThroughput&quot;: 24.333,\r\n                &quot;medianResponseTime&quot;: 5,\r\n                &quot;errorsCount&quot;: 0,\r\n                &quot;errorsRate&quot;: 0,\r\n                &quot;hasLabelPassedThresholds&quot;: null\r\n            },\r\n            {\r\n                &quot;labelId&quot;: &quot;f88f8ff81bf9b521134637639a0277be&quot;,\r\n                &quot;labelName&quot;: &quot;100b NonCache&quot;,\r\n                &quot;samples&quot;: 729,\r\n                &quot;avgResponseTime&quot;: 6.143,\r\n                &quot;90line&quot;: 7,\r\n                &quot;95line&quot;: 7,\r\n                &quot;99line&quot;: 9,\r\n                &quot;minResponseTime&quot;: 3,\r\n                &quot;maxResponseTime&quot;: 877,\r\n                &quot;avgLatency&quot;: 6.136,\r\n                &quot;geoMeanResponseTime&quot;: 4.627,\r\n                &quot;stDev&quot;: 32.817,\r\n                &quot;duration&quot;: 295,\r\n                &quot;avgBytes&quot;: 1.64,\r\n                &quot;avgThroughput&quot;: 2.471,\r\n                &quot;medianResponseTime&quot;: 4,\r\n                &quot;errorsCount&quot;: 0,\r\n                &quot;errorsRate&quot;: 0,\r\n                &quot;hasLabelPassedThresholds&quot;: null\r\n            }\r\n        ]\r\n    }\r\n\r\nI originally attempted:\r\n\r\n\r\n    [.result[] | {labelName: .labelName, samples: .samples, avgResponseTime: .avgResponseTime, 90line: .90line, 95line: .95line, 99line: .99line, minResponseTime: .minResponseTime, maxResponseTime: .maxResponseTime, avgLatency: .avgLatency, geoMeanResponseTime: .geoMeanResponseTime, stDev: .stDev, durationSeconds: .durationSeconds, avgBytes: .avgBytes, avgThroughput: .avgThroughput, medianResponseTime: .medianResponseTime, errorCount: .errorsCount, errorRate: .errorsRate, hasLabelPassedThresholds: .hasLabelPassedThresholds}]\r\n\r\n\r\nand got \r\n\r\n\r\n    jq: error: syntax error, unexpected LITERAL (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    [.result[] | {labelName: .labelName, samples: .samples, avgResponseTime: .avgResponseTime, 90line: .90line, 95line: .95line, 99line: .99line, minResponseTime: .minResponseTime, maxResponseTime: .maxResponseTime, avgLatency: .avgLatency, geoMeanResponseTime: .geoMeanResponseTime, stDev: .stDev, durationSeconds: .durationSeconds, avgBytes: .avgBytes, avgThroughput: .avgThroughput, medianResponseTime: .medianResponseTime, errorCount: .errorsCount, errorRate: .errorsRate, hasLabelPassedThresholds: .hasLabelPassedThresholds}]                                                                                           \r\n    jq: 1 compile error\r\n    exit status 3\r\n\r\nLooking at the similar questions asked in the prior links, I attempted to fix with queries like this:\r\n\r\n    [.result[] | {labelName: .labelName, samples: .samples, avgResponseTime: .avgResponseTime, 90line: .[“90line”], 95line: .[“95line”], 99line: .[“99line”], minResponseTime: .minResponseTime, maxResponseTime: .maxResponseTime, avgLatency: .avgLatency, geoMeanResponseTime: .geoMeanResponseTime, stDev: .stDev, durationSeconds: .durationSeconds, avgBytes: .avgBytes, avgThroughput: .avgThroughput, medianResponseTime: .medianResponseTime, errorCount: .errorsCount, errorRate: .errorsRate, hasLabelPassedThresholds: .hasLabelPassedThresholds}]\r\n\r\nto deal with the fields beginning with numeric characters. I still get the same syntax errors, however, so I&#39;m unable to line up my expectations with what I&#39;m seeing in those other solutions. I just can&#39;t figure out what I&#39;m doing wrong, I&#39;ve tried all kinds of other quoting or trying stuff like | tostring to no avail.\r\n\r\n\r\nEDIT: in response to a proposed answer below:\r\n\r\nHmm, I just can&#39;t get it. To recap:\r\n\r\n    {\r\n        &quot;api_version&quot;: 4,\r\n        &quot;error&quot;: null,\r\n        &quot;result&quot;: [\r\n            {\r\n                &quot;labelId&quot;: &quot;ALL&quot;,\r\n                &quot;labelName&quot;: &quot;ALL&quot;,\r\n                &quot;samples&quot;: 30104,\r\n                &quot;avgResponseTime&quot;: 6.849,\r\n                &quot;90line&quot;: 8,\r\n                &quot;95line&quot;: 9,\r\n                &quot;99line&quot;: 36,\r\n                &quot;minResponseTime&quot;: 2,\r\n                &quot;maxResponseTime&quot;: 1951,\r\n                &quot;avgLatency&quot;: 5.287,\r\n                &quot;geoMeanResponseTime&quot;: 5.484,\r\n                &quot;stDev&quot;: 23.765,\r\n                &quot;duration&quot;: 302,\r\n                &quot;avgBytes&quot;: 110.224,\r\n                &quot;avgThroughput&quot;: 99.682,\r\n                &quot;medianResponseTime&quot;: 5,\r\n                &quot;errorsCount&quot;: 0,\r\n                &quot;errorsRate&quot;: 0,\r\n                &quot;hasLabelPassedThresholds&quot;: null\r\n            }\r\n        ]\r\n    }\r\n\r\n\r\njq bit:\r\n\r\n    jq &#39;[.result[] | {labelName: .labelName, samples: .samples, avgResponseTime: .avgResponseTime, minResponseTime: .minResponseTime, maxResponseTime: .maxResponseTime, avgLatency: .avgLatency, geoMeanResponseTime: .geoMeanResponseTime, stDev: .stDev, durationSeconds: .durationSeconds, avgBytes: .avgBytes, avgThroughput: .avgThroughput, medianResponseTime: .medianResponseTime, errorCount: .errorsCount, errorRate: .errorsRate, hasLabelPassedThresholds: .hasLabelPassedThresholds, “90line”: .[“90line”], “95line”: .[“95line”], “99line”: .[“99line”]}]&#39;\r\n\r\n\r\nReturns:\r\n\r\njq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n",
        "link": "https://stackoverflow.com/questions/49647599/cannot-select-fields-beginning-with-numerics-in-jq-with-references-to-other-exa",
        "title": "Cannot select fields beginning with numerics in jq (with references to other examples)"
    },
    {
        "tags": [
            "arrays",
            "json",
            "grouping",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 52839,
                    "reputation": 99133,
                    "user_id": 157957,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MBRE7.jpg?s=256",
                    "display_name": "IMSoP",
                    "link": "https://stackoverflow.com/users/157957/imsop"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522835247,
                "post_id": 49647815,
                "comment_id": 86303617,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7095226,
                    "reputation": 529,
                    "user_id": 5429075,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/902e93ce18895308c55265b2384da860?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Naveen K Reddy",
                    "link": "https://stackoverflow.com/users/5429075/naveen-k-reddy"
                },
                "reply_to_user": {
                    "account_id": 52839,
                    "reputation": 99133,
                    "user_id": 157957,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MBRE7.jpg?s=256",
                    "display_name": "IMSoP",
                    "link": "https://stackoverflow.com/users/157957/imsop"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522835580,
                "post_id": 49647815,
                "comment_id": 86303841,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1522854961,
                "last_edit_date": 1522854961,
                "creation_date": 1522841291,
                "answer_id": 49649820,
                "question_id": 49647815,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq &#39;group_by(.organizationId) \r\n        | map(reduce .[] as $o ({&quot;Down_Count&quot; : 0};\r\n                  if $o[&quot;status&quot;] == &quot;DOWN&quot; then .Down_Count += 1 else . end\r\n                  | . + { ($o[&quot;server&quot;]) : $o[&quot;status&quot;],\r\n                              &quot;organizationId&quot; : $o[&quot;organizationId&quot;] }\r\n              ))&#39; input.json\r\n\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;Down_Count&quot;: 2,\r\n        &quot;server1&quot;: &quot;UP&quot;,\r\n        &quot;organizationId&quot;: &quot;org1&quot;,\r\n        &quot;server2&quot;: &quot;DOWN&quot;,\r\n        &quot;server3&quot;: &quot;DOWN&quot;\r\n      },\r\n      {\r\n        &quot;Down_Count&quot;: 0,\r\n        &quot;server1&quot;: &quot;UP&quot;,\r\n        &quot;organizationId&quot;: &quot;org2&quot;,\r\n        &quot;server2&quot;: &quot;UP&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "jq group by and Increment at same time"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1522860495,
                "creation_date": 1522860495,
                "answer_id": 49656344,
                "question_id": 49647815,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s another approach you could take:\r\n\r\n    group_by(.organizationId) | map(\r\n        reduce ([., [range(length)]] | transpose[]) as [$o,$i] (\r\n            {\r\n                organizationId: .[0].organizationId,\r\n                Down_Count: (map(select(.status==&quot;DOWN&quot;)) | length)\r\n            };\r\n            reduce $keys[] as $k (\r\n                .[&quot;server\\($i+1)&quot;] = $o.status;\r\n                if $o | has($k) then .[$k] = $o[$k] else . end\r\n            )\r\n        )\r\n    )\r\n\r\nJust pass in an array of keys named `$keys` you want to be copied over. If it exists in one of the objects, it will be copied to the result object.\r\n\r\n    $ cat input.json\r\n    [{\r\n        &quot;organizationId&quot;: &quot;org1&quot;,\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;server&quot;: &quot;server1&quot;,\r\n        &quot;somekey1&quot; : &quot;somevalue1&quot;\r\n    }, \r\n    {\r\n        &quot;organizationId&quot;: &quot;org1&quot;,\r\n        &quot;status&quot;: &quot;DOWN&quot;,\r\n        &quot;server&quot;: &quot;server2&quot;,\r\n        &quot;somekey2&quot; : &quot;somevalue2&quot;\r\n    },\r\n    {\r\n        &quot;organizationId&quot;: &quot;org1&quot;,\r\n        &quot;status&quot;: &quot;DOWN&quot;,\r\n        &quot;server&quot;: &quot;server3&quot;\r\n    },\r\n    {\r\n        &quot;organizationId&quot;: &quot;org2&quot;,\r\n        &quot;server&quot;: &quot;server1&quot;,\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;somekey2&quot; : &quot;somevalue2&quot;\r\n    },\r\n    {\r\n        &quot;organizationId&quot;: &quot;org2&quot;,\r\n        &quot;server&quot;: &quot;server2&quot;,\r\n        &quot;status&quot;: &quot;UP&quot;,\r\n        &quot;somekey4&quot; : &quot;somevalue4&quot;\r\n    }]\r\n\r\n&lt;!-- --&gt;\r\n\r\n    $ cat program.jq\r\n    group_by(.organizationId) | map(\r\n        reduce ([., [range(length)]] | transpose[]) as [$o,$i] (\r\n            {\r\n                organizationId: .[0].organizationId,\r\n                Down_Count: (map(select(.status==&quot;DOWN&quot;)) | length)\r\n            };\r\n            reduce $keys[] as $k (\r\n                .[&quot;server\\($i+1)&quot;] = $o.status;\r\n                if $o | has($k) then .[$k] = $o[$k] else . end\r\n            )\r\n        )\r\n    )\r\n\r\n&lt;!-- --&gt;\r\n\r\n    $ jq --argjson keys &#39;[&quot;somekey2&quot;]&#39; -f program.jq input.json\r\n    [\r\n      {\r\n        &quot;organizationId&quot;: &quot;org1&quot;,\r\n        &quot;Down_Count&quot;: 2,\r\n        &quot;server1&quot;: &quot;UP&quot;,\r\n        &quot;server2&quot;: &quot;DOWN&quot;,\r\n        &quot;somekey2&quot;: &quot;somevalue2&quot;,\r\n        &quot;server3&quot;: &quot;DOWN&quot;\r\n      },\r\n      {\r\n        &quot;organizationId&quot;: &quot;org2&quot;,\r\n        &quot;Down_Count&quot;: 0,\r\n        &quot;server1&quot;: &quot;UP&quot;,\r\n        &quot;somekey2&quot;: &quot;somevalue2&quot;,\r\n        &quot;server2&quot;: &quot;UP&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "jq group by and Increment at same time"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1522860495,
        "creation_date": 1522835136,
        "last_edit_date": 1522847511,
        "question_id": 49647815,
        "body_markdown": "&gt; Sample **input1.json**\r\n\r\n&lt;pre&gt;&lt;code&gt;\r\n[{\r\n\t&quot;organizationId&quot;: &quot;org1&quot;,\r\n\t&quot;status&quot;: &quot;UP&quot;,\r\n    &quot;server&quot;: &quot;server1&quot;,\r\n    &quot;somekey1&quot; : &quot;somevalue1&quot;\r\n}, \r\n{\r\n\t&quot;organizationId&quot;: &quot;org1&quot;,\r\n\t&quot;status&quot;: &quot;DOWN&quot;,\r\n    &quot;server&quot;: &quot;server2&quot;,\r\n    &quot;somekey2&quot; : &quot;somevalue2&quot;\r\n},\r\n{\r\n\t&quot;organizationId&quot;: &quot;org1&quot;,\r\n\t&quot;status&quot;: &quot;DOWN&quot;,\r\n    &quot;server&quot;: &quot;server3&quot;\r\n},\r\n{\r\n\t&quot;organizationId&quot;: &quot;org2&quot;,\r\n\t&quot;server&quot;: &quot;server1&quot;,\r\n    &quot;status&quot;: &quot;UP&quot;,\r\n    &quot;somekey2&quot; : &quot;somevalue2&quot;\r\n},\r\n{\r\n\t&quot;organizationId&quot;: &quot;org2&quot;,\r\n\t&quot;server&quot;: &quot;server2&quot;,\r\n    &quot;status&quot;: &quot;UP&quot;,\r\n    &quot;somekey4&quot; : &quot;somevalue4&quot;\r\n}]\r\n&lt;/pre&gt;&lt;/code&gt;\r\n\r\n&gt; Expected **output.json**\r\n\r\n&lt;pre&gt;&lt;code&gt;\r\n[{\r\n\t\t&quot;organizationId&quot;: &quot;org1&quot;,\r\n\t\t&quot;server1&quot;: &quot;UP&quot;,\r\n        &quot;server2&quot;: &quot;DOWN&quot;,\r\n\t\t&quot;server3&quot;: &quot;DOWN&quot;,\r\n        &quot;Down_Count&quot;: 2,\r\n        &quot;somekey2&quot; : &quot;somevalue2&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;organizationId&quot;: &quot;org2&quot;,\r\n\t\t&quot;server1&quot;: &quot;UP&quot;,\r\n        &quot;server2&quot;: &quot;UP&quot;,\r\n        &quot;Down_Count&quot;: 0,\r\n       &quot;somekey2&quot; : &quot;somevalue2&quot;\r\n\t}]\r\n&lt;/pre&gt;&lt;/code&gt;\r\n\r\nThe input is an array object of two files. My objective is \r\n\r\n 1. to increment and populate the new field `Down_Count` by grouping by `organizationId`. I can have multiple records with same `organizationId`. Hence, the count should be incremented that number of times subject to status `DOWN`. \r\n 2. Merge `server` and `status` fields. For example `&quot;server&quot;:&quot;server1&quot;, &quot;status&quot;:&quot;down&quot;` should come as `server1:down` directly in final output. I can try this one independently using `jq &#39;.[] |= . + {(.server):.status}&#39;`\r\n 3. all the keys are not available in all the objects. Hence, I should be able to add the keys I want to the final output. Lets assume I know the key name I want to add. In the final output,  I have added only `&quot;somekey2&quot; : &quot;somevalue2&quot;`\r\n\r\nI&#39;m finding some difficulties to achieve all these together using `jq` cmd line processor. Any suggestions please?",
        "link": "https://stackoverflow.com/questions/49647815/jq-group-by-and-increment-at-same-time",
        "title": "jq group by and Increment at same time"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7528450,
                    "reputation": 7646,
                    "user_id": 5717640,
                    "user_type": "registered",
                    "accept_rate": 98,
                    "profile_image": "https://www.gravatar.com/avatar/5c02affcf45c0788440245f361c08ec6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Nerdy Bunz",
                    "link": "https://stackoverflow.com/users/5717640/nerdy-bunz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522909279,
                "post_id": 49665137,
                "comment_id": 86340554,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6887896,
                    "reputation": 1031,
                    "user_id": 5292423,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/c7f9d01d792f43aa663d6b7603d9cf89?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Joe",
                    "link": "https://stackoverflow.com/users/5292423/joe"
                },
                "reply_to_user": {
                    "account_id": 7528450,
                    "reputation": 7646,
                    "user_id": 5717640,
                    "user_type": "registered",
                    "accept_rate": 98,
                    "profile_image": "https://www.gravatar.com/avatar/5c02affcf45c0788440245f361c08ec6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Nerdy Bunz",
                    "link": "https://stackoverflow.com/users/5717640/nerdy-bunz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522910199,
                "post_id": 49665137,
                "comment_id": 86340990,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1522914057,
                "last_edit_date": 1522914057,
                "creation_date": 1522911901,
                "answer_id": 49666109,
                "question_id": 49665137,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "## Direct approaches\r\n\r\nThere are many direct approaches, e.g.:\r\n\r\n### Using `paths`\r\n\r\n    paths as $p\r\n    | select( $p|length == 5 and\r\n             ($p[0] | startswith(&quot;shippingInfo_&quot;)) and\r\n             $p[1:3] == [&quot;fields&quot;, &quot;trackingList&quot;] and\r\n    \t     $p[4] == &quot;info&quot;)\r\n    | getpath($p)\r\n\r\n### Using `to_entries`\r\n\r\n    to_entries[]\r\n    | select(.key |  startswith(&quot;shippingInfo_&quot;))\r\n    | .value\r\n    | .fields.trackingList[]\r\n    | .info\r\n\r\n## Indirect approaches\r\n\r\nThere are also some indirect approaches that are worth mentioning, e.g.\r\n\r\n### Using a helper function\r\n\r\n    def dot(s):\r\n      to_entries[] | select(.key|test(s)) | .value ;\r\n    \r\n    dot(&quot;^shippingInfo_&quot;)\r\n    | .fields.trackingList[]\r\n    | .info\r\n\r\nThe last-mentioned filter can be abbreviated to:\r\n\r\n    dot(&quot;^shippingInfo_&quot;).fields.trackingList[].info\r\n\r\n## Relaxed requirements\r\nIf it is acceptable to ignore the &quot;^shippingInfo_&quot; requirement, the following may be worth considering as well:\r\n\r\n    .[].fields.trackingList[]?.info\r\n\r\nor even:\r\n\r\n    .. | objects.fields.trackingList[]?.info",
                "title": "How to extract a JSON field that has a random string with the jq command?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1522914057,
        "creation_date": 1522907995,
        "question_id": 49665137,
        "body_markdown": "Please bear with me I&#39;m still learning about JSON and programming in general. So I have this JSON file:\r\n\r\n    {\r\n    \t&quot;root_200888546292191&quot;: {\r\n    \t\t&quot;fields&quot;: {\r\n    \t\t\t&quot;buyerId&quot;: &quot;31392191&quot;\r\n    \t\t},\r\n    \t\t&quot;id&quot;: &quot;200718546292191&quot;,\r\n    \t\t&quot;tag&quot;: &quot;root&quot;,\r\n    \t\t&quot;type&quot;: &quot;biz&quot;\r\n    \t},\r\n    \t&quot;shippingInfo_#package#OF04472002179150#WAREHOUSE_ACCEPTED&quot;: {\r\n    \t\t&quot;fields&quot;: {\r\n    \t\t\t&quot;delivery&quot;: {\r\n    \t\t\t\t&quot;createdAt&quot;: &quot;Sen 09 Apr - Rab 11 Apr&quot;,\r\n    \t\t\t\t&quot;desc&quot;: &quot;Standar&quot;,\r\n    \t\t\t\t&quot;email&quot;: null,\r\n    \t\t\t\t&quot;method&quot;: &quot;Standard&quot;,\r\n    \t\t\t\t&quot;status&quot;: &quot;info&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;statusMap&quot;: {\r\n    \t\t\t\t&quot;active&quot;: &quot;Dalam proses&quot;,\r\n    \t\t\t\t&quot;all&quot;: [&quot;Dalam proses&quot;, &quot;Dalam pengiriman&quot;, &quot;Telah diterima&quot;]\r\n    \t\t\t},\r\n    \t\t\t&quot;trackingList&quot;: [{\r\n    \t\t\t\t&quot;info&quot;: &quot;Status One&quot;,\r\n    \t\t\t\t&quot;updatedAt&quot;: &quot;05 Apr 2018 - 11:00&quot;\r\n    \t\t\t}, {\r\n    \t\t\t\t&quot;info&quot;: &quot;Status Two&quot;,\r\n    \t\t\t\t&quot;updatedAt&quot;: &quot;05 Apr 2018 - 11:00&quot;\r\n    \t\t\t}]\r\n    \t\t},\r\n    \t\t&quot;id&quot;: &quot;#package#OF04472002179150#WAREHOUSE_ACCEPTED&quot;,\r\n    \t\t&quot;tag&quot;: &quot;shippingInfo&quot;,\r\n    \t\t&quot;type&quot;: &quot;biz&quot;\r\n    \t},\r\n    \t&quot;shippingInfo_#package#AAAAAAAAAAAAA#NOT_WAREHOUSE_ACCEPTED&quot;: {\r\n    \t\t&quot;fields&quot;: {\r\n    \t\t\t&quot;delivery&quot;: {\r\n    \t\t\t\t&quot;createdAt&quot;: &quot;Sen 09 Apr - Rab 11 Apr&quot;,\r\n    \t\t\t\t&quot;desc&quot;: &quot;Standar&quot;,\r\n    \t\t\t\t&quot;email&quot;: null,\r\n    \t\t\t\t&quot;method&quot;: &quot;Standard&quot;,\r\n    \t\t\t\t&quot;status&quot;: &quot;info&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;statusMap&quot;: {\r\n    \t\t\t\t&quot;active&quot;: &quot;Dalam proses&quot;,\r\n    \t\t\t\t&quot;all&quot;: [&quot;Dalam proses&quot;, &quot;Dalam pengiriman&quot;, &quot;Telah diterima&quot;]\r\n    \t\t\t},\r\n    \t\t\t&quot;trackingList&quot;: [{\r\n    \t\t\t\t&quot;info&quot;: &quot;Status Three&quot;,\r\n    \t\t\t\t&quot;updatedAt&quot;: &quot;05 Apr 2018 - 11:00&quot;\r\n    \t\t\t}, {\r\n    \t\t\t\t&quot;info&quot;: &quot;Status Four&quot;,\r\n    \t\t\t\t&quot;updatedAt&quot;: &quot;05 Apr 2018 - 11:00&quot;\r\n    \t\t\t}]\r\n    \t\t},\r\n    \t\t&quot;id&quot;: &quot;#package#AAAAAAAAAAAAA#NOT_WAREHOUSE_ACCEPTED&quot;,\r\n    \t\t&quot;tag&quot;: &quot;shippingInfo&quot;,\r\n    \t\t&quot;type&quot;: &quot;biz&quot;\r\n    \t},\r\n    \t&quot;login_200718577292191&quot;: {\r\n    \t\t&quot;fields&quot;: {\r\n    \t\t\t&quot;buyerEmail&quot;: &quot;myemail@gmail.com&quot;,\r\n    \t\t\t&quot;buyerName&quot;: &quot;myname&quot;\r\n    \t\t},\r\n    \t\t&quot;id&quot;: &quot;200718522292191&quot;,\r\n    \t\t&quot;tag&quot;: &quot;login&quot;,\r\n    \t\t&quot;type&quot;: &quot;biz&quot;\r\n    \t}\r\n    }\r\n\r\nAnd I want to extract `Info` in `shippingInfo_` &gt; `fields` &gt; `trackingList` So the output that I want is like this:\r\n\r\n    Status One\r\n    Status Two\r\n    Status Three\r\n    Status Four\r\n\r\nThe string after `shippingInfo_` is always random, how do I extract it with jq?\r\n\r\nThis is as far as I&#39;ve got `jq &#39;.shippingInfo_*.fields.trackingList.info&#39;`",
        "link": "https://stackoverflow.com/questions/49665137/how-to-extract-a-json-field-that-has-a-random-string-with-the-jq-command",
        "title": "How to extract a JSON field that has a random string with the jq command?"
    },
    {
        "tags": [
            "json",
            "bash",
            "sed",
            "jq",
            "auto-generate"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11468218,
                    "reputation": 5601,
                    "user_id": 8405835,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sN3eq.png?s=256",
                    "display_name": "Abhijit Pritam Dutta",
                    "link": "https://stackoverflow.com/users/8405835/abhijit-pritam-dutta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522943277,
                "post_id": 49675733,
                "comment_id": 86364163,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8165858,
                    "reputation": 33,
                    "user_id": 6148179,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/63927dfcfebd5554fdb5c250feb08a09?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ltqbx",
                    "link": "https://stackoverflow.com/users/6148179/ltqbx"
                },
                "reply_to_user": {
                    "account_id": 11468218,
                    "reputation": 5601,
                    "user_id": 8405835,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sN3eq.png?s=256",
                    "display_name": "Abhijit Pritam Dutta",
                    "link": "https://stackoverflow.com/users/8405835/abhijit-pritam-dutta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522943738,
                "post_id": 49675733,
                "comment_id": 86364456,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11468218,
                    "reputation": 5601,
                    "user_id": 8405835,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sN3eq.png?s=256",
                    "display_name": "Abhijit Pritam Dutta",
                    "link": "https://stackoverflow.com/users/8405835/abhijit-pritam-dutta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522947812,
                "post_id": 49675733,
                "comment_id": 86366925,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522947912,
                "post_id": 49675733,
                "comment_id": 86366989,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1522941282,
                "creation_date": 1522941282,
                "answer_id": 49675911,
                "question_id": 49675733,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using `jq` and leaving the generation of appropriate random values as an exercise for the reader:\r\n\r\n    $ jq --arg cid &quot;foo&quot; --arg cdt &quot;bar&quot; &#39;\r\n        .header.correlationContext.array[0]={\r\n            correlationId: $cid,\r\n            correlationDateTime: {string: $cdt}\r\n         }&#39; tmp.json\r\n\r\n\r\n\r\n",
                "title": "Generate file and replace strings in template file in the generated files"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1522946566,
                "last_edit_date": 1522946566,
                "creation_date": 1522945910,
                "answer_id": 49677307,
                "question_id": 49675733,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here you go:-\r\n\r\n    #!/bin/bash\r\n\talias uid=&quot;python -c &#39;import sys,uuid; sys.stdout.write(uuid.uuid4().hex)&#39; | pbcopy &amp;&amp; pbpaste &amp;&amp; echo&quot;\r\n\tdt=$(date &quot;+%Y%m%d-%H%M%S&quot;)\r\n    # For above two values I am leaving with you. If you have best option please go for it\r\n\ti=0\r\n\twhile [ $i -le 20 ]\r\n\tdo\r\n\t  sed  &quot;/correlationId/s/98440498-3104-479e-9c99-f4449ba8f4b6/&quot;$uid&quot;/;s/2018-04-05T14:30:39.000+00:00/&quot;$dt&quot;/&quot; yourJsonFile.json &gt; testcase$i.json\r\n\t  i=$((i+1))\r\n\tdone",
                "title": "Generate file and replace strings in template file in the generated files"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1522947546,
        "creation_date": 1522940841,
        "last_edit_date": 1522947546,
        "question_id": 49675733,
        "body_markdown": "I have a JSON file:\r\n\r\n    {\r\n\t\t&quot;header&quot;: {\r\n\t\t\t&quot;uuid&quot;: &quot;c578592a-a751-4993-9060-53f488597e59&quot;,\r\n\t\t\t&quot;timestamp&quot;: 1522938800,\r\n\t\t\t&quot;productionDateTime&quot;: &quot;2018-04-05T14:33:20.000+00:00&quot;,\r\n\t\t\t&quot;producers&quot;: {\r\n\t\t\t\t&quot;operator&quot;: null,\r\n\t\t\t\t&quot;application&quot;: {\r\n\t\t\t\t\t&quot;com.example&quot;: {\r\n\t\t\t\t\t\t&quot;id&quot;: {\r\n\t\t\t\t\t\t\t&quot;string&quot;: &quot;1&quot;\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t&quot;name&quot;: {\r\n\t\t\t\t\t\t\t&quot;string&quot;: &quot;Test&quot;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t},\r\n\t\t\t\t&quot;station&quot;: null,\r\n\t\t\t\t&quot;equipment&quot;: null,\r\n\t\t\t\t&quot;partner&quot;: null,\r\n\t\t\t\t&quot;flow&quot;: null\r\n\t\t\t},\r\n\t\t\t&quot;correlationContext&quot;: {\r\n\t\t\t\t&quot;array&quot;: [{\r\n\t\t\t\t\t&quot;correlationId&quot;: &quot;98440498-3104-479e-9c99-f4449ba8f4b6&quot;,\r\n\t\t\t\t\t&quot;correlationDateTime&quot;: {\r\n\t\t\t\t\t\t&quot;string&quot;: &quot;2018-04-05T14:30:39.000+00:00&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}]\r\n\t\t\t}\r\n\t\t},\r\n\t}\r\n\r\nI would like to create n files that copy the JSON file but with a random correlationId and correlationDateTime.\r\n\r\nDo you have any tips or suggestions? Many thanks in advance!",
        "link": "https://stackoverflow.com/questions/49675733/generate-file-and-replace-strings-in-template-file-in-the-generated-files",
        "title": "Generate file and replace strings in template file in the generated files"
    },
    {
        "tags": [
            "json",
            "key",
            "transform",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522962259,
                "post_id": 49680434,
                "comment_id": 86374771,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4817039,
                    "reputation": 485,
                    "user_id": 3888850,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-m35UM_ocR5Y/AAAAAAAAAAI/AAAAAAAAGg0/ZPRcq62OefQ/s256-rj/photo.jpg",
                    "display_name": "Levi",
                    "link": "https://stackoverflow.com/users/3888850/levi"
                },
                "reply_to_user": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1522964049,
                "post_id": 49680434,
                "comment_id": 86375535,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1522960624,
                "creation_date": 1522960624,
                "answer_id": 49681105,
                "question_id": 49680434,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I ended up finding a solution but it took way longer than it should have (hours). Basically if at any time you lose the `,` in your lists than you messed up somewhere. \r\n\r\nThis is what I used `.modules | map(.outputs | to_entries[] | {(.key): .value.value}) | add` \r\n\r\nIt works, but maybe a better way.",
                "title": "How combine multiple output objects into a single object with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1522965172,
                "creation_date": 1522965172,
                "answer_id": 49682110,
                "question_id": 49680434,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using `map_values` produces a simpler (or at least shorter) filter, and might be more efficient:\r\n\r\n    .modules | map(.outputs | map_values(.value) ) | add\r\n  \r\n",
                "title": "How combine multiple output objects into a single object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1523453622,
        "creation_date": 1522957867,
        "last_edit_date": 1523453622,
        "question_id": 49680434,
        "body_markdown": "I&#39;m trying to parse the output of a terraform state file.\r\n\r\n    {\r\n        &quot;version&quot;: 3,\r\n        &quot;terraform_version&quot;: &quot;0.9.3&quot;,\r\n        &quot;serial&quot;: 0,\r\n        &quot;lineage&quot;: &quot;ae1f2572-8fa6-4977-be73-3deac7529eff&quot;,\r\n        &quot;modules&quot;: [\r\n            {\r\n                &quot;path&quot;: [\r\n                    &quot;root&quot;\r\n                ],\r\n                &quot;outputs&quot;: {\r\n                    &quot;elb_dns_name&quot;: {\r\n                        &quot;sensitive&quot;: false,\r\n                        &quot;type&quot;: &quot;string&quot;,\r\n                        &quot;value&quot;: &quot;web-elb-1019323532.us-east-1.elb.amazonaws.com&quot;\r\n                    }\r\n                },\r\n                &quot;resources&quot;: {},\r\n                &quot;depends_on&quot;: []\r\n            },\r\n            {\r\n                &quot;path&quot;: [\r\n                    &quot;root&quot;,\r\n                    &quot;elb&quot;\r\n                ],\r\n                &quot;outputs&quot;: {\r\n                    &quot;dns_name&quot;: {\r\n                        &quot;sensitive&quot;: false,\r\n                        &quot;type&quot;: &quot;string&quot;,\r\n                        &quot;value&quot;: &quot;web-elb-1019323532.us-east-1.elb.amazonaws.com&quot;\r\n                    }\r\n                },\r\n                &quot;depends_on&quot;: []\r\n            },\r\n            {\r\n                &quot;path&quot;: [\r\n                    &quot;root&quot;,\r\n                    &quot;sg&quot;\r\n                ],\r\n                &quot;outputs&quot;: {\r\n                    &quot;security_group_id&quot;: {\r\n                        &quot;sensitive&quot;: false,\r\n                        &quot;type&quot;: &quot;string&quot;,\r\n                        &quot;value&quot;: &quot;sg-5a677425&quot;\r\n                    }\r\n                },\r\n                &quot;depends_on&quot;: []\r\n            },\r\n            {\r\n                &quot;path&quot;: [\r\n                    &quot;root&quot;,\r\n                    &quot;web&quot;\r\n                ],\r\n                &quot;outputs&quot;: {\r\n                    &quot;web_instance_ids&quot;: {\r\n                        &quot;sensitive&quot;: false,\r\n                        &quot;type&quot;: &quot;string&quot;,\r\n                        &quot;value&quot;: &quot;i-03676fa6ba43fbb9f,i-09f51a313146856cd&quot;\r\n                    },\r\n                    &quot;web_public_ips&quot;: {\r\n                        &quot;sensitive&quot;: false,\r\n                        &quot;type&quot;: &quot;string&quot;,\r\n                        &quot;value&quot;: &quot;34.207.194.186,34.203.236.205&quot;\r\n                    }\r\n                },\r\n                &quot;depends_on&quot;: []\r\n            }\r\n        ]\r\n    }\r\n\r\nI would like to get back a single json object where the output names are the keys and the values are the output values. Like in this example...\r\n\r\n    {\r\n      &quot;elb_dns_name&quot;: &quot;web-elb-1019323532.us-east-1.elb.amazonaws.com&quot;,\r\n      &quot;dns_name&quot;: &quot;web-elb-1019323532.us-east-1.elb.amazonaws.com&quot;,\r\n      &quot;security_group_id&quot;: &quot;sg-5a677425&quot;,\r\n      &quot;web_instance_ids&quot;: &quot;i-03676fa6ba43fbb9f,i-09f51a313146856cd&quot;,\r\n      &quot;web_public_ips&quot;: &quot;34.207.194.186,34.203.236.205&quot;\r\n    }\r\n\r\nI have only be able to get back single objects using this `.modules[] | .outputs | to_entries | map({(.key) : .value.value }) | add`\r\n\r\n    {\r\n      &quot;elb_dns_name&quot;: &quot;web-elb-1019323532.us-east-1.elb.amazonaws.com&quot;\r\n    }\r\n    {\r\n      &quot;dns_name&quot;: &quot;web-elb-1019323532.us-east-1.elb.amazonaws.com&quot;\r\n    }\r\n    {\r\n      &quot;security_group_id&quot;: &quot;sg-5a677425&quot;\r\n    }\r\n    {\r\n      &quot;web_instance_ids&quot;: &quot;i-03676fa6ba43fbb9f,i-09f51a313146856cd&quot;,\r\n      &quot;web_public_ips&quot;: &quot;34.207.194.186,34.203.236.205&quot;\r\n    }\r\n\r\nSo for some reason I can&#39;t post, because stackoverflow says I have too much code and not enough details... so now I&#39;m doing a diary entry in order to type enough that I can hit the submit button... any minute... any ammount of characters now... \r\n\r\nOkay so when I&#39;m not building Code Pipelines at work I really like to play dota2. Only I think I&#39;m pretty crappy at it. I mean I got 1200 hours in the gam and I&#39;m still like 1.5k MMR trash. \r\n",
        "link": "https://stackoverflow.com/questions/49680434/how-combine-multiple-output-objects-into-a-single-object-with-jq",
        "title": "How combine multiple output objects into a single object with jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523288063,
                "post_id": 49736418,
                "comment_id": 86487401,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523288173,
                "post_id": 49736418,
                "comment_id": 86487464,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523288316,
                "post_id": 49736418,
                "comment_id": 86487578,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523288396,
                "post_id": 49736418,
                "comment_id": 86487625,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523288584,
                "post_id": 49736418,
                "comment_id": 86487741,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1523288387,
                "creation_date": 1523288387,
                "answer_id": 49736739,
                "question_id": 49736418,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq -R &#39;\r\n    split(&quot;[[:space:]]+&quot;; &quot;g&quot;)\r\n    | select(length &gt; 2) | select(.[0] != &quot;&quot;)\r\n    | { &quot;name&quot;:    (.[0]),\r\n        &quot;console&quot;: (.[1]),\r\n        &quot;ip&quot;:      (.[2]),\r\n        &quot;day&quot;:     (.[3])\r\n      }\r\n    &#39; &lt; &lt;(last)",
                "title": "convert shell command &quot;last&quot; output to json"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1523346574,
                "last_edit_date": 1523346574,
                "creation_date": 1523344306,
                "answer_id": 49747513,
                "question_id": 49736418,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Another option to consider is using regex capture variables.  Consider for example:\r\n\r\n    capture(&quot;(?&lt;name&gt;^[^ ]+) +(?&lt;token&gt;[^ ]+) +(?&lt;numeric&gt;[0-9.]+) +(?&lt;range&gt;[^(]+)  +(?&lt;time&gt;.*)&quot;)\r\n\r\nWith the given input, i.e.:\r\n\r\n    test   pts/0        1.1.1.1     Wed Jun 21 14:28 - 20:19  (05:51)\r\n\r\nthe output would be:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;test&quot;,\r\n      &quot;token&quot;: &quot;pts/0&quot;,\r\n      &quot;numeric&quot;: &quot;1.1.1.1&quot;,\r\n      &quot;range&quot;: &quot;Wed Jun 21 14:28 - 20:19&quot;,\r\n      &quot;time&quot;: &quot;(05:51)&quot;\r\n    }\r\n\r\n",
                "title": "convert shell command &quot;last&quot; output to json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1523346574,
        "creation_date": 1523287238,
        "question_id": 49736418,
        "body_markdown": "Is any option that i can convert shell `last` output to json \r\n\r\neg: last output\r\n\r\n    test   pts/0        1.1.1.1     Wed Jun 21 14:28 - 20:19  (05:51)\r\n\r\nto\r\n\r\n    {\r\n     name: &quot;test&quot;,\r\n     x1: &quot;pts/0&quot;,\r\n    .\r\n    .\r\n    .\r\n    time: &quot;(05:51)&quot;\r\n    }\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49736418/convert-shell-command-last-output-to-json",
        "title": "convert shell command &quot;last&quot; output to json"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1523349226,
                "last_edit_date": 1523349226,
                "creation_date": 1523348086,
                "answer_id": 49748617,
                "question_id": 49748060,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq &#39;map(.Variables \r\n            |= (group_by(.Parameter.Id) \r\n                | map((&quot;p&quot; + (.[0].Parameter.Id | tostring)) as $pid \r\n                      | { ($pid) : map(.Id) }\r\n                  )\r\n               )\r\n        )&#39; input.json\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;Id&quot;: 78,\r\n        &quot;PromotionType&quot;: 2,\r\n        &quot;Amount&quot;: &quot;100&quot;,\r\n        &quot;UpperLimit&quot;: null,\r\n        &quot;Variables&quot;: [\r\n          {\r\n            &quot;p30&quot;: [\r\n              100\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Id&quot;: 84,\r\n        &quot;PromotionType&quot;: 2,\r\n        &quot;Amount&quot;: null,\r\n        &quot;UpperLimit&quot;: null,\r\n        &quot;Variables&quot;: [\r\n          {\r\n            &quot;p17&quot;: [\r\n              48,\r\n              196\r\n            ]\r\n          },\r\n          {\r\n            &quot;p21&quot;: [\r\n              59,\r\n              60,\r\n              62\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Id&quot;: 59,\r\n        &quot;PromotionType&quot;: 2,\r\n        &quot;Amount&quot;: &quot;666.6&quot;,\r\n        &quot;UpperLimit&quot;: null,\r\n        &quot;Variables&quot;: [\r\n          {\r\n            &quot;p8&quot;: [\r\n              96\r\n            ]\r\n          },\r\n          {\r\n            &quot;p17&quot;: [\r\n              47\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\n",
                "title": "Modify array elements while grouping by a specific key using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1523351104,
        "creation_date": 1523346207,
        "last_edit_date": 1523351104,
        "question_id": 49748060,
        "body_markdown": "Is it possible to modify/replace array elements while grouping by a specific key (`.[].Parameter.Id`) such that this array:\r\n\r\n    [{\r\n    \t&quot;Id&quot;: 48,\r\n    \t&quot;Parameter&quot;: {\r\n    \t\t&quot;Id&quot;: 17\r\n    \t}\r\n    }, {\r\n    \t&quot;Id&quot;: 196,\r\n    \t&quot;Parameter&quot;: {\r\n    \t\t&quot;Id&quot;: 17\r\n    \t}\r\n    }]\r\n\r\nbecomes this:\r\n\r\n    [\r\n       {\r\n        &quot;p17&quot;: [48, 196]\r\n       }\r\n    ]\r\n\r\nHere is the source JSON file for a complete example:\r\n\r\n    [{\r\n    \t&quot;Id&quot;: 78,\r\n    \t&quot;PromotionType&quot;: 2,\r\n    \t&quot;Amount&quot;: &quot;100&quot;,\r\n    \t&quot;UpperLimit&quot;: null,\r\n    \t&quot;Variables&quot;: [{\r\n    \t\t&quot;Id&quot;: 100,\r\n    \t\t&quot;Parameter&quot;: {\r\n    \t\t\t&quot;Id&quot;: 30\r\n    \t\t}\r\n    \t}]\r\n    }, {\r\n    \t&quot;Id&quot;: 84,\r\n    \t&quot;PromotionType&quot;: 2,\r\n    \t&quot;Amount&quot;: null,\r\n    \t&quot;UpperLimit&quot;: null,\r\n    \t&quot;Variables&quot;: [{\r\n    \t\t&quot;Id&quot;: 48,\r\n    \t\t&quot;Parameter&quot;: {\r\n    \t\t\t&quot;Id&quot;: 17\r\n    \t\t}\r\n    \t}, {\r\n    \t\t&quot;Id&quot;: 196,\r\n    \t\t&quot;Parameter&quot;: {\r\n    \t\t\t&quot;Id&quot;: 17\r\n    \t\t}\r\n    \t}, {\r\n    \t\t&quot;Id&quot;: 59,\r\n    \t\t&quot;Parameter&quot;: {\r\n    \t\t\t&quot;Id&quot;: 21\r\n    \t\t}\r\n    \t}, {\r\n    \t\t&quot;Id&quot;: 60,\r\n    \t\t&quot;Parameter&quot;: {\r\n    \t\t\t&quot;Id&quot;: 21\r\n    \t\t}\r\n    \t}, {\r\n    \t\t&quot;Id&quot;: 62,\r\n    \t\t&quot;Parameter&quot;: {\r\n    \t\t\t&quot;Id&quot;: 21\r\n    \t\t}\r\n    \t}]\r\n    }, {\r\n    \t&quot;Id&quot;: 59,\r\n    \t&quot;PromotionType&quot;: 2,\r\n    \t&quot;Amount&quot;: &quot;666.6&quot;,\r\n    \t&quot;UpperLimit&quot;: null,\r\n    \t&quot;Variables&quot;: [{\r\n    \t\t&quot;Id&quot;: 96,\r\n    \t\t&quot;Parameter&quot;: {\r\n    \t\t\t&quot;Id&quot;: 8\r\n    \t\t}\r\n    \t}, {\r\n    \t\t&quot;Id&quot;: 47,\r\n    \t\t&quot;Parameter&quot;: {\r\n    \t\t\t&quot;Id&quot;: 17\r\n    \t\t}\r\n    \t}]\r\n    }]\r\n\r\n\r\nWhat I want to achieve is this:\r\n\r\n    [{\r\n    \t&quot;Id&quot;: 78,\r\n    \t&quot;PromotionType&quot;: 2,\r\n    \t&quot;Amount&quot;: &quot;100&quot;,\r\n    \t&quot;UpperLimit&quot;: null,\r\n    \t&quot;Variables&quot;: [{\r\n    \t\t&quot;p30&quot;: [100]\r\n    \t}]\r\n    }, {\r\n    \t&quot;Id&quot;: 84,\r\n    \t&quot;PromotionType&quot;: 2,\r\n    \t&quot;Amount&quot;: null,\r\n    \t&quot;UpperLimit&quot;: null,\r\n    \t&quot;Variables&quot;: [{\r\n    \t\t&quot;p17&quot;: [48, 196]\r\n    \t}, {\r\n    \t\t&quot;p21&quot;: [59, 60, 62]\r\n    \t}]\r\n    }, {\r\n    \t&quot;Id&quot;: 59,\r\n    \t&quot;PromotionType&quot;: 2,\r\n    \t&quot;Amount&quot;: &quot;666.6&quot;,\r\n    \t&quot;UpperLimit&quot;: null,\r\n    \t&quot;Variables&quot;: [{\r\n    \t\t&quot;p8&quot;: [96]\r\n    \t}, {\r\n    \t\t&quot;p17&quot;: [47]\r\n    \t}]\r\n    }]\r\n\r\n\r\nI am reading through jq manual, [jq cookbook](https://github.com/stedolan/jq/wiki/Cookbook) and found some functions (e.g. `with_entries`, `unique_by`, `inputs`) that might help but could not figure out how to make it work.\r\n\r\nNumber of objects/inner objects are also not fixed. So I cannot simply replace using array indexes.\r\n\r\nAny help would be appreciated.\r\n\r\nThanks,\r\nEmre",
        "link": "https://stackoverflow.com/questions/49748060/modify-array-elements-while-grouping-by-a-specific-key-using-jq",
        "title": "Modify array elements while grouping by a specific key using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523513439,
                "post_id": 49752871,
                "comment_id": 86593194,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1523517068,
                "last_edit_date": 1523517068,
                "creation_date": 1523361177,
                "answer_id": 49752956,
                "question_id": 49752871,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just revert the logic:\r\n\r\n    jq &#39;select(.value!=&quot;&quot;)&#39;\r\n",
                "title": "jq filter- unexpected &quot;null&quot;s"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1523517068,
        "creation_date": 1523360952,
        "last_edit_date": 1523362393,
        "question_id": 49752871,
        "body_markdown": "input json:\r\n\r\n    {\r\n      &quot;id&quot;: 381,\r\n      &quot;name&quot;: &quot;Module&quot;,\r\n      &quot;value&quot;: &quot;C-A&quot;,\r\n      &quot;locked&quot;: false\r\n    }\r\n    {\r\n      &quot;id&quot;: 381,\r\n      &quot;name&quot;: &quot;Module&quot;,\r\n      &quot;value&quot;: &quot;&quot;,\r\n      &quot;locked&quot;: false\r\n    }\r\n    {\r\n      &quot;id&quot;: 381,\r\n      &quot;name&quot;: &quot;Module&quot;,\r\n      &quot;value&quot;: &quot;&quot;,\r\n      &quot;locked&quot;: false\r\n    }\r\n\r\nAnd I want to remove all objects with value unset ```&quot;&quot;```\r\nI have such filter but it prints also ```null``` - how to rid it of?\r\n\r\n    $ jq &#39;del(select(.value == &quot;&quot;))&#39; /tmp/intest\r\n    {\r\n      &quot;id&quot;: 381,\r\n      &quot;name&quot;: &quot;Module&quot;,\r\n      &quot;value&quot;: &quot;C-A&quot;,\r\n      &quot;locked&quot;: false\r\n    }\r\n    null\r\n    null\r\n\r\n\r\nupdate:\r\nI want also to join non-empty values but get error:\r\n\r\n    $ jq &#39;select(.value!=&quot;&quot;)|.value|join(&quot;,&quot;)&#39; /tmp/intest\r\n    jq: error (at /tmp/intest:6): Cannot iterate over string (&quot;C-A&quot;)\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49752871/jq-filter-unexpected-nulls",
        "title": "jq filter- unexpected &quot;null&quot;s"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523375926,
                "post_id": 49756994,
                "comment_id": 86531199,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523398955,
                "post_id": 49756994,
                "comment_id": 86543016,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1523375425,
                "creation_date": 1523375425,
                "answer_id": 49757982,
                "question_id": 49756994,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -r &#39;&quot;id:&quot; + (.id|tostring) + &quot; mname:&quot; + .mname \r\n           + &quot; target:&quot; + (.attrib[] | select(.name == &quot;target&quot;).value) \r\n           + &quot; pname:&quot; + (.xstart[] | select(.pname | startswith(&quot;#&quot;) | not) as $x | $x.pname \r\n           + &quot; xnode:&quot; + ($x.attrib[] | select(.name==&quot;xnode&quot;).value))&#39; input.json\r\n\r\nThe output:\r\n\r\n    id:1022 mname:P1 target:host.domain.com pname:P1A xnode:1",
                "title": "json filtering with ignoring some objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1523398853,
                "creation_date": 1523398853,
                "answer_id": 49763685,
                "question_id": 49756994,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since the requirements have mostly been specified implicitly, it&#39;s difficult to infer them, but the following probably comes close and in any case illustrates some useful techniques, such as the abstraction of the functionality embodied in the following definition of `kv`: \r\n\r\n    def kv: [to_entries[] | &quot;\\(.key):\\(.value)&quot; ] | join(&quot; &quot;);\r\n\r\n    .attrib |= map(select(.name == &quot;target&quot;))\r\n    | .xstart |= map( select(has(&quot;pname&quot;) and (.pname | startswith(&quot;#&quot;) | not)))\r\n    | {id, mname, target: &quot;host.domain.com&quot;}\r\n      + (.xstart[]\r\n         | .pname as $pname\r\n         | .attrib[]\r\n         | {pname: $pname} + {(.name): .value})\r\n    | kv\r\n\r\n## Output\r\n\r\nWith the given input and the use of the `-r` command-line option, the output would be:\r\n\r\n    id:1022 mname:P1 target:host.domain.com pname:P1A xnode:1\r\n    id:1022 mname:P1 target:host.domain.com pname:P1A remote:1\r\n\r\n",
                "title": "json filtering with ignoring some objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1523398853,
        "creation_date": 1523372508,
        "question_id": 49756994,
        "body_markdown": "I need to extract with jq filter following output:\r\n\r\n```id:1022 mname:P1 target:host.domain.com pname:P1A xnode:1```\r\n\r\nAll objects having pname beginning with ```#``` in ```xstart``` sections should be ignored from processig.\r\n\r\nthe input json is:\r\n\r\n    {\r\n      &quot;id&quot;: 1022,\r\n      &quot;mname&quot;: &quot;P1&quot;,\r\n      &quot;attrib&quot;: [\r\n        {\r\n          &quot;id&quot;: 1,\r\n          &quot;name&quot;: &quot;log&quot;,\r\n          &quot;value&quot;: &quot;1&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 622,\r\n          &quot;name&quot;: &quot;target&quot;,\r\n          &quot;value&quot;: &quot;host.domain.com&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 623,\r\n          &quot;name&quot;: &quot;iddle&quot;,\r\n          &quot;value&quot;: &quot;30&quot;\r\n        }\r\n      ],\r\n      &quot;xstart&quot;: [\r\n        {\r\n          &quot;id&quot;: 1021,\r\n          &quot;pname&quot;: &quot;P1A&quot;,\r\n          &quot;attrib&quot;: [\r\n            {\r\n              &quot;id&quot;: 530,\r\n              &quot;name&quot;: &quot;xnode&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: 498,\r\n              &quot;name&quot;: &quot;remote&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: 1022,\r\n          &quot;pname&quot;: &quot;#P1C&quot;,\r\n          &quot;attrib&quot;: [\r\n            {\r\n              &quot;id&quot;: 530,\r\n              &quot;name&quot;: &quot;xnode&quot;,\r\n              &quot;value&quot;: &quot;2&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: 498,\r\n              &quot;name&quot;: &quot;remote&quot;,\r\n              &quot;value&quot;: &quot;1&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49756994/json-filtering-with-ignoring-some-objects",
        "title": "json filtering with ignoring some objects"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1523413789,
                "last_edit_date": 1523413789,
                "creation_date": 1523383506,
                "answer_id": 49760294,
                "question_id": 49759823,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The grouping can be achieved by `group_by/1` using [.name,.height] as the grouping criterion:\r\n\r\n    def sum(f): map(f) | add;\r\n\r\n    def average(f): sum(f) / length;\r\n    \r\n    def consolidate:\r\n      .[0]\r\n      + {wifes: average(.wifes)}\r\n      + {sons:  sum(.sons) } ;\r\n    \r\n    .people\r\n    | group_by([.name,.height])\r\n    | map(consolidate)\r\n\r\n## Output\r\n\r\nThe output is as per the given descriptive requirements:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;carl&quot;,\r\n        &quot;height&quot;: &quot;180cm&quot;,\r\n        &quot;wifes&quot;: 1,\r\n        &quot;sons&quot;: 1\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;carl&quot;,\r\n        &quot;height&quot;: &quot;195cm&quot;,\r\n        &quot;wifes&quot;: 1.95,\r\n        &quot;sons&quot;: 12\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;charlie&quot;,\r\n        &quot;height&quot;: &quot;166cm&quot;,\r\n        &quot;wifes&quot;: 0,\r\n        &quot;sons&quot;: 2\r\n      }\r\n    ]\r\n\r\n\r\n\r\n",
                "title": "How to merge (average/sum) duplicated objects in .json via jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1523413789,
        "creation_date": 1523381736,
        "question_id": 49759823,
        "body_markdown": "I&#39;m trying to get rid of duplicates that sometimes appear in my input.  \r\nHere is sample of data:\r\n\r\n    {\r\n      &quot;some&quot;: &quot;very&quot;,\r\n      &quot;random&quot;: 0.228,\r\n      &quot;stuff&quot;: 31337,\r\n      &quot;people&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;carl&quot;,\r\n          &quot;height&quot;: &quot;180cm&quot;,\r\n          &quot;wifes&quot;: 1,\r\n          &quot;sons&quot;: 0\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;charlie&quot;,\r\n          &quot;height&quot;: &quot;166cm&quot;,\r\n          &quot;wifes&quot;: 0,\r\n          &quot;sons&quot;: 2\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;carl&quot;,\r\n          &quot;height&quot;: &quot;180cm&quot;,\r\n          &quot;wifes&quot;: 1,\r\n          &quot;sons&quot;: 1\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;carl&quot;,\r\n          &quot;height&quot;: &quot;195cm&quot;,\r\n          &quot;wifes&quot;: 1.95,\r\n          &quot;sons&quot;: 12\r\n        }\r\n      ]\r\n    }\r\nThere is bunch of carl&#39;s, but only 2 of them are duplicates - name:carl &amp; height:180cm.  \r\nFor example I need to average amount of his wifes and sum his sons.  \r\nHere is expected result:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;carl&quot;,\r\n        &quot;height&quot;: &quot;180cm&quot;,\r\n        &quot;wifes&quot;: 1,\r\n        &quot;sons&quot;: 3\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;charlie&quot;,\r\n        &quot;height&quot;: &quot;166cm&quot;,\r\n        &quot;wifes&quot;: 0,\r\n        &quot;sons&quot;: 2\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;carl&quot;,\r\n        &quot;height&quot;: &quot;195cm&quot;,\r\n        &quot;wifes&quot;: 1.95,\r\n        &quot;sons&quot;: 12\r\n      }\r\n    ]\r\nI tried using &#39;add&#39; and &#39;reduce&#39; but I&#39;m pretty newb in jq &gt;&lt;\r\n",
        "link": "https://stackoverflow.com/questions/49759823/how-to-merge-average-sum-duplicated-objects-in-json-via-jq",
        "title": "How to merge (average/sum) duplicated objects in .json via jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523472721,
                "post_id": 49779617,
                "comment_id": 86580263,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1523464922,
                "creation_date": 1523464922,
                "answer_id": 49780429,
                "question_id": 49779617,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -r &#39;.apps[] | [.routes[].host, .state, .package_updated_at] | join(&quot; &quot;)&#39; test.json\r\nThe output:\r\n\r\n    nodered-test STARTED 2018-04-10T17:32:06Z\r\n    NodeRedTestApp STARTED 2018-04-09T21:23:27Z\r\n\r\n",
                "title": "How to produce a single line output of a record with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1523464922,
        "creation_date": 1523462202,
        "question_id": 49779617,
        "body_markdown": "I have the following JSON \r\n\r\n&lt;pre&gt;\r\n\r\n{\r\n   &quot;guid&quot;: &quot;dce38b4b-9989-42d2-b6bd-702645e344cf&quot;,\r\n   &quot;name&quot;: &quot;dev&quot;,\r\n   &quot;apps&quot;: [\r\n      {\r\n         &quot;guid&quot;: &quot;5d5498cb-a885-4242-a55a-d7d286a1cf48&quot;,\r\n         &quot;urls&quot;: [\r\n            &quot;nodered.cloudfoundry.org&quot;\r\n         ],\r\n         &quot;routes&quot;: [\r\n            {\r\n               &quot;guid&quot;: &quot;aca4d04b-f99d-4b43-afaa-82ab41afa07c&quot;,\r\n               &quot;host&quot;: &quot;nodered-test&quot;,\r\n               &quot;port&quot;: null,\r\n               &quot;path&quot;: &quot;&quot;,\r\n               &quot;domain&quot;: {\r\n                  &quot;guid&quot;: &quot;f4b90d7e-2cd3-4d30-b200-f28bbaf6be20&quot;,\r\n                  &quot;name&quot;: &quot;cloudfoundry.org&quot;\r\n               }\r\n            }\r\n         ],\r\n         &quot;service_count&quot;: 1,\r\n         &quot;service_names&quot;: [\r\n            &quot;nodered-test-cloudantNoSQLDB&quot;\r\n         ],\r\n         &quot;running_instances&quot;: 1,\r\n         &quot;name&quot;: &quot;perik-nodered-test&quot;,\r\n         &quot;production&quot;: false,\r\n         &quot;space_guid&quot;: &quot;dce38b4b-9989-42d2-b6bd-702645e344cf&quot;,\r\n         &quot;stack_guid&quot;: &quot;ac91d31a-86a3-453b-babf-8d49c9d763fc&quot;,\r\n         &quot;buildpack&quot;: null,\r\n         &quot;detected_buildpack&quot;: &quot;SDK for Node.js(TM) (ibm-node.js-6.13.0, buildpack-v3.20-20180403-1426)&quot;,\r\n         &quot;detected_buildpack_guid&quot;: &quot;33e9e82f-8846-4362-a60a-92964285a31e&quot;,\r\n         &quot;environment_json&quot;: {},\r\n         &quot;memory&quot;: 256,\r\n         &quot;instances&quot;: 1,\r\n         &quot;disk_quota&quot;: 1024,\r\n         &quot;state&quot;: &quot;STARTED&quot;,\r\n         &quot;version&quot;: &quot;8c8c97a0-bc2e-424c-a0a3-d64704feb634&quot;,\r\n         &quot;command&quot;: null,\r\n         &quot;console&quot;: false,\r\n         &quot;debug&quot;: null,\r\n         &quot;staging_task_id&quot;: &quot;539f460c-e4d2-49f9-b5e5-9f4fd31a8370&quot;,\r\n         &quot;package_state&quot;: &quot;STAGED&quot;,\r\n         &quot;health_check_type&quot;: &quot;port&quot;,\r\n         &quot;health_check_timeout&quot;: null,\r\n         &quot;health_check_http_endpoint&quot;: null,\r\n         &quot;staging_failed_reason&quot;: null,\r\n         &quot;staging_failed_description&quot;: null,\r\n         &quot;diego&quot;: true,\r\n         &quot;docker_image&quot;: null,\r\n         &quot;package_updated_at&quot;: &quot;2018-04-10T17:32:06Z&quot;,\r\n         &quot;detected_start_command&quot;: &quot;./vendor/initial_startup.rb&quot;,\r\n         &quot;enable_ssh&quot;: true,\r\n         &quot;ports&quot;: null\r\n      },\r\n      {\r\n         &quot;guid&quot;: &quot;4089ce19-19fb-467b-8876-3635819d5d91&quot;,\r\n         &quot;urls&quot;: [\r\n            &quot;nodered.cloudfoundry.org&quot;\r\n         ],\r\n         &quot;routes&quot;: [\r\n            {\r\n               &quot;guid&quot;: &quot;b79988d8-5ac5-455d-8fdd-00bc208dd2bc&quot;,\r\n               &quot;host&quot;: &quot;NodeRedTestApp&quot;,\r\n               &quot;port&quot;: null,\r\n               &quot;path&quot;: &quot;&quot;,\r\n               &quot;domain&quot;: {\r\n                  &quot;guid&quot;: &quot;f4b90d7e-2cd3-4d30-b200-f28bbaf6be20&quot;,\r\n                  &quot;name&quot;: &quot;cloudfoundry.org&quot;\r\n               }\r\n            }\r\n         ],\r\n         &quot;service_count&quot;: 1,\r\n         &quot;service_names&quot;: [\r\n            &quot;NodeRedTestApp-cloudantNoSQLDB&quot;\r\n         ],\r\n         &quot;running_instances&quot;: 1,\r\n         &quot;name&quot;: &quot;perik-NodeRedTestApp&quot;,\r\n         &quot;production&quot;: false,\r\n         &quot;space_guid&quot;: &quot;dce38b4b-9989-42d2-b6bd-702645e344cf&quot;,\r\n         &quot;stack_guid&quot;: &quot;ac91d31a-86a3-453b-babf-8d49c9d763fc&quot;,\r\n         &quot;buildpack&quot;: null,\r\n         &quot;detected_buildpack&quot;: &quot;SDK for Node.js(TM) (ibm-node.js-6.13.0, buildpack-v3.20-20180403-1426)&quot;,\r\n         &quot;detected_buildpack_guid&quot;: &quot;33e9e82f-8846-4362-a60a-92964285a31e&quot;,\r\n         &quot;environment_json&quot;: {},\r\n         &quot;memory&quot;: 256,\r\n         &quot;instances&quot;: 1,\r\n         &quot;disk_quota&quot;: 1024,\r\n         &quot;state&quot;: &quot;STARTED&quot;,\r\n         &quot;version&quot;: &quot;17175bdb-df93-4745-9a17-cf214fe05976&quot;,\r\n         &quot;command&quot;: null,\r\n         &quot;console&quot;: false,\r\n         &quot;debug&quot;: null,\r\n         &quot;staging_task_id&quot;: &quot;5c74633a-25db-4adf-9eb8-09454a70be52&quot;,\r\n         &quot;package_state&quot;: &quot;STAGED&quot;,\r\n         &quot;health_check_type&quot;: &quot;port&quot;,\r\n         &quot;health_check_timeout&quot;: null,\r\n         &quot;health_check_http_endpoint&quot;: null,\r\n         &quot;staging_failed_reason&quot;: null,\r\n         &quot;staging_failed_description&quot;: null,\r\n         &quot;diego&quot;: true,\r\n         &quot;docker_image&quot;: null,\r\n         &quot;package_updated_at&quot;: &quot;2018-04-09T21:23:27Z&quot;,\r\n         &quot;detected_start_command&quot;: &quot;./vendor/initial_startup.rb&quot;,\r\n         &quot;enable_ssh&quot;: true,\r\n         &quot;ports&quot;: null\r\n      }\r\n   ]\r\n  \r\n}\r\n&lt;/pre&gt;\r\n\r\nand getting the following values using \r\n\r\ncat test.json | jq -r &#39;.apps[].routes[].host, .apps[].state, .apps[].package_updated_at&#39; which produces the following output\r\n\r\nnodered-test&lt;br&gt;\r\nNodeRedTestApp&lt;br&gt;\r\nSTARTED&lt;br&gt;\r\nSTARTED&lt;br&gt;\r\n2018-04-10T17:32:06Z&lt;br&gt;\r\n2018-04-09T21:23:27Z&lt;br&gt;\r\n\r\nHow can I get the output as\r\n\r\nnodered-test STARTED 2018-04-10T17:32:06Z&lt;br&gt;\r\nNodeRedTestApp STARTED 2018-04-09T21:23:27Z&lt;br&gt;\r\n\r\nSo that I can assign it to a bash script array. ",
        "link": "https://stackoverflow.com/questions/49779617/how-to-produce-a-single-line-output-of-a-record-with-jq",
        "title": "How to produce a single line output of a record with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1569594657,
                "post_id": 49780588,
                "comment_id": 102659703,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1523474389,
                "last_edit_date": 1523474389,
                "creation_date": 1523466339,
                "answer_id": 49780832,
                "question_id": 49780588,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With straightforward **`jq`** expression:\r\n\r\n    jq &#39;{target: &quot;Systolic&quot;, datapoints: .}&#39; example.json\r\n\r\nThe output:\r\n\r\n    {\r\n      &quot;target&quot;: &quot;Systolic&quot;,\r\n      &quot;datapoints&quot;: [\r\n        [\r\n          &quot;126&quot;,\r\n          1522767000\r\n        ],\r\n        [\r\n          &quot;122&quot;,\r\n          1522859400\r\n        ],\r\n        [\r\n          &quot;126&quot;,\r\n          1523348520\r\n        ]\r\n      ]\r\n    }\r\n\r\n",
                "title": "Add multiple parent keys to json array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1523474389,
        "creation_date": 1523465528,
        "question_id": 49780588,
        "body_markdown": "I have a json file, example.json:\r\n\r\n    [\r\n      [\r\n        &quot;126&quot;,\r\n        1522767000\r\n      ],\r\n      [\r\n        &quot;122&quot;,\r\n        1522859400\r\n      ],\r\n      [\r\n        &quot;126&quot;,\r\n        1523348520\r\n      ]\r\n    ]\r\n\r\n...and would like to add multiple parent items with the desired output:\r\n\r\n    {\r\n      &quot;target&quot;: &quot;Systolic&quot;,\r\n      &quot;datapoints&quot;: [\r\n        [\r\n          &quot;126&quot;,\r\n          1522767000\r\n        ],\r\n        [\r\n          &quot;122&quot;,\r\n          1522859400\r\n        ],\r\n        [\r\n          &quot;126&quot;,\r\n          1523348520\r\n        ]\r\n      ]\r\n    }\r\n\r\nI&#39;m having trouble, attempting things like:\r\n\r\n`cat example.json | jq -s &#39;{target:.[]}&#39;`, which adds the one key but not understanding how to add a value to the `target` and another key `datapoints`. ",
        "link": "https://stackoverflow.com/questions/49780588/add-multiple-parent-keys-to-json-array",
        "title": "Add multiple parent keys to json array"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523543098,
                "post_id": 49795109,
                "comment_id": 86612733,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1523531938,
                "creation_date": 1523531938,
                "answer_id": 49795174,
                "question_id": 49795109,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Like this:\r\n\r\n    jq &#39;.[]|select(.path|startswith(&quot;a/b/&quot;)|not)&#39; file.json",
                "title": "Remove objects from array that match a test against a property"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1523532268,
        "creation_date": 1523531742,
        "question_id": 49795109,
        "body_markdown": "I&#39;d like to remove from an array objects that pass a test against a property&#39;\r\n\r\nAssume we have the following array:\r\n\r\n    [\r\n      {\r\n         &quot;path&quot;: &quot;a/b/v1-another&quot;\r\n      },\r\n      {\r\n         &quot;path&quot;: &quot;a/b/v1&quot;\r\n      }\r\n    ]\r\n\r\nI&#39;d like to remove from the array the object that match the test `a/b/*` against `path` property",
        "link": "https://stackoverflow.com/questions/49795109/remove-objects-from-array-that-match-a-test-against-a-property",
        "title": "Remove objects from array that match a test against a property"
    },
    {
        "tags": [
            "if-statement",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1523548927,
                "creation_date": 1523548927,
                "answer_id": 49801162,
                "question_id": 49800086,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq &#39;{domain: &quot;-&quot;, apiname: &quot;-&quot;} as $o \r\n        | map([.tags[] | .value | split(&quot;:&quot;) | {(.[0]) : .[1]}] | add | $o + .)&#39; input.json\r\n\r\n- `{domain: &quot;-&quot;, apiname: &quot;-&quot;} as $o` - used as a *template* object\r\n\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;domain&quot;: &quot;sourcing&quot;,\r\n        &quot;apiname&quot;: &quot;src1&quot;\r\n      },\r\n      {\r\n        &quot;domain&quot;: &quot;-&quot;,\r\n        &quot;apiname&quot;: &quot;fin1&quot;\r\n      },\r\n      {\r\n        &quot;domain&quot;: &quot;fin1&quot;,\r\n        &quot;apiname&quot;: &quot;-&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "jq retain missing array objects from capturing group and update array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1523566615,
                "creation_date": 1523566615,
                "answer_id": 49805736,
                "question_id": 49800086,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s another approach. This assumes your `tags` array will only contain the names you expect.\r\n\r\n    map(\r\n        reduce (.tags[].value | split(&quot;:&quot;)) as [$k,$v] (\r\n            {domain:&quot;-&quot;,apiname:&quot;-&quot;};\r\n            .[$k] = $v\r\n        )\r\n    )\r\n\r\n&lt;hr&gt;\r\n\r\nFor a more general solution that doesn&#39;t assume fixed names and just flattens the tags, I&#39;d do this:\r\n\r\n    map(\r\n        reduce (.tags[].value | split(&quot;:&quot;)) as [$k,$v] (\r\n            del(.tags);\r\n            .[$k] = $v\r\n        )\r\n    )\r\n\r\nThen as you access the fields, just use the alternative operator to set the default value.\r\n\r\n    (.domain // &quot;-&quot;) as $domain",
                "title": "jq retain missing array objects from capturing group and update array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1523570920,
                "creation_date": 1523570920,
                "answer_id": 49806607,
                "question_id": 49800086,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the &quot;value&quot; part of the &quot;tag:value&quot; strings might contain a colon (&quot;:&quot;), then using `split` becomes unnecessarily tricky (and maybe even inefficient), so it might be easier to use `capture`, perhaps along the lines suggested by @RomanPerekhrest:\r\n\r\n    {domain:&quot;-&quot;, apiname:&quot;-&quot;} as $default\r\n    | map([.tags[].value\r\n           | capture(&quot;(?&lt;k&gt;[^:]*):(?&lt;v&gt;.*)&quot;)\r\n           | {(.k): .v} ]\r\n          | add\r\n          | $default + .)",
                "title": "jq retain missing array objects from capturing group and update array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1523570920,
        "creation_date": 1523545846,
        "question_id": 49800086,
        "body_markdown": "&gt; **Input**\r\n\r\n    [{\r\n    \t\t&quot;tags&quot;: [{\r\n    \t\t\t\t&quot;value&quot;: &quot;domain:sourcing&quot;\r\n    \t\t\t},\r\n    \t\t\t{\r\n    \t\t\t\t&quot;value&quot;: &quot;apiname:src1&quot;\r\n    \t\t\t}\r\n    \t\t]\r\n    \t},\r\n    \t{\r\n    \t\t&quot;tags&quot;: [{\r\n    \t\t\t&quot;value&quot;: &quot;apiname:fin1&quot;\r\n    \t\t}]\r\n    \t},\r\n    \t{\r\n    \t\t&quot;tags&quot;: [{\r\n    \t\t\t&quot;value&quot;: &quot;domain:fin1&quot;\r\n    \t\t}]\r\n    \t}\r\n    ]\r\n\r\n&gt; **Expected output**\r\n\r\n    [{\r\n    \t\t&quot;domain&quot;: &quot;sourcing&quot;,\r\n    \t\t&quot;apiname&quot;: &quot;src1&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;domain&quot;: &quot;-&quot;,\r\n    \t\t&quot;apiname&quot;: &quot;fin1&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;domain&quot;: &quot;fin1&quot;,\r\n    \t\t&quot;apiname&quot;: &quot;-&quot;\r\n    \t}\r\n    ]\r\n\r\nSo far I have tried below.\r\n\r\n`jq &#39;map(. + (.tags[].value | capture(&quot;domain:(?&lt;domain&gt;.+)&quot;))) | map(. + (.tags[].value | capture(&quot;apiname:(?&lt;apiname&gt;.+)&quot;))) | map(del(.tags))&#39;`\r\n\r\n&gt; **partial output from above cmd**\r\n\r\n    [\r\n      {\r\n        &quot;apiDomain&quot;: &quot;sourcing&quot;,\r\n        &quot;apiName&quot;: &quot;src1&quot;\r\n      }\r\n    ]\r\n\r\nAs you have seen, the problem here is I&#39;m completely loosing the other objects if any one capturing group filed is absent. Second object in input has **apiname** but missing **&quot;domain&quot;** and third object has **&quot;domain&quot;** but missing **&quot;apiname&quot;**. As stated in the sample output, if any object doesn&#39;t present, then they should come as **&quot;-&quot;**.\r\n\r\nCan the jq command be updated to achieve this please?\r\n",
        "link": "https://stackoverflow.com/questions/49800086/jq-retain-missing-array-objects-from-capturing-group-and-update-array",
        "title": "jq retain missing array objects from capturing group and update array"
    },
    {
        "tags": [
            "json",
            "linux",
            "file",
            "unix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1523589996,
                "last_edit_date": 1523589996,
                "creation_date": 1523587470,
                "answer_id": 49808530,
                "question_id": 49808009,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I edited your question in several ways. You provided a schema, not an example. also I think you mean the command `jq`, not `jd`.\r\n\r\nAlso I assume you have to parse a file containing a list of such persons, not just a single person.\r\n\r\nWith jq, you can run this\r\n\r\n    echo &#39;\r\n    [{\r\n      &quot;firstName&quot;: &quot;sin&quot;,\r\n      &quot;lastName&quot;: &quot;minim sint labore&quot;\r\n    },\r\n    {\r\n      &quot;firstName&quot;: &quot;mun&quot;,\r\n      &quot;lastName&quot;: &quot;minim sint labore&quot;\r\n    }]&#39; &gt;&gt; x.json\r\n\r\n    cat x.json | jq &#39;.[].firstName&#39;\r\n    &quot;sin&quot;\r\n    &quot;mun&quot;\r\n\r\njq has more options that you can find in [their documentation][1], such as:\r\n\r\n    $ jq -c &#39;.[] | [.firstName, .lastName]&#39; x.json\r\n    [&quot;sin&quot;,&quot;minim sint labore&quot;]\r\n    [&quot;mun&quot;,&quot;minim sint labore&quot;]\r\n\r\nFor transforming such or other JSON output to CSV, look at the documentation, or use google or Stackoverflow.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "Parse JSON file in linux using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1523625460,
        "creation_date": 1523582904,
        "last_edit_date": 1523625460,
        "question_id": 49808009,
        "body_markdown": "I have a json file, call it x.json satisfying this schema:\r\n\r\n     }\r\n          },\r\n          &quot;type&quot;: &quot;persons&quot;\r\n        },\r\n        &quot;person&#39;s in a group&quot;: {\r\n          &quot;primary&quot;: {\r\n            &quot;attributes&quot;: {\r\n              &quot;firstname&quot;: &quot;sara&quot;,\r\n              &quot;lastname&quot;: &quot;jones&quot;,\r\n              &quot;age&quot;: &quot;32&quot;,\r\n              &quot;weight&quot;: &quot;130&quot;,\r\n           \r\n\r\n\r\nto get the list of first name, I have to write:\r\n\r\n    cat x.json | jq &#39;.title[].type[].properties.firstname&#39;\r\n\r\nis there a shorter way to get the first name? Instead of having to write the whole line of objects? \r\nAlso is there a way to list more than just the first name, for example first and last name? \r\nlastly, any idea how I can import this out into a CVS file or any other flat file system? ",
        "link": "https://stackoverflow.com/questions/49808009/parse-json-file-in-linux-using-jq",
        "title": "Parse JSON file in linux using jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "data-partitioning"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523593550,
                "post_id": 49808581,
                "comment_id": 86633325,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2394255,
                    "reputation": 827,
                    "user_id": 2174959,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://i.sstatic.net/0hFWQ.jpg?s=256",
                    "display_name": "Chaz",
                    "link": "https://stackoverflow.com/users/2174959/chaz"
                },
                "reply_to_user": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523628778,
                "post_id": 49808581,
                "comment_id": 86652789,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 26,
                "is_accepted": true,
                "score": 26,
                "last_activity_date": 1668236370,
                "last_edit_date": 1668236370,
                "creation_date": 1523593216,
                "answer_id": 49809249,
                "question_id": 49808581,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[EDIT: This answer has been revised in accordance with the revision to the question.]\r\n\r\nThe key to using jq to solve the problem is the `-c` command-line option, which produces output in JSON-Lines format (i.e., in the present case, one object per line).  You can then use a tool such as `awk` or `split` to distribute those lines amongst several files.\r\n\r\nIf the file is not too big, then the simplest would be to start the pipeline with:\r\n\r\n    jq -c &#39;.[]&#39; INPUTFILE\r\n\r\n\r\n\r\nIf the file is too big to fit comfortably in memory, then you could use jq&#39;s streaming parser, like so:\r\n\r\n    jq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39;\r\n\r\nOr you could use a command-line tool such as [jstream][1] or [jm][2], which would be faster but which would of course have to be installed.\r\n\r\nFor further discussion about jq&#39;s streaming parser, see e.g. the relevant section in the jq FAQ: https://github.com/stedolan/jq/wiki/FAQ#streaming-json-parser\r\n \r\n## Partitioning\r\nFor different approaches to partitioning the output produced in the first step, see for example https://stackoverflow.com/questions/2016894/how-to-split-a-large-text-file-into-smaller-files-with-equal-number-of-lines\r\n\r\nIf it is required that each of the output files be an array of objects, then I&#39;d probably use `awk` to perform both the partitioning and the re-constitution in one step, but there are many other reasonable approaches.\r\n\r\n## If the input is a sequence of JSON objects\r\n\r\nFor reference, if the original file consists of a stream or sequence of JSON objects, then the appropriate invocation would be:\r\n\r\n    jq -n -c inputs INPUTFILE\r\n\r\nUsing `inputs` in this manner allows arbitrarily many objects to be processed efficiently.\r\n \r\n\r\n\r\n  [1]: https://github.com/bcicen/jstream\r\n  [2]: https://github.com/pkoppstein/jm",
                "title": "Using jq how can I split a very large JSON file into multiple files, each a specific quantity of objects?"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1625154964,
                "creation_date": 1625154964,
                "answer_id": 68213394,
                "question_id": 49808581,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nIt is possible to slice a json file or stream with `jq`.\r\nSee the script below.\r\nThe `sliceSize` parameter sets the size of the slices and determines how many inputs are kept in memory at the same time.\r\nThis allows the memory usage to be controlled.\r\n\r\n## Input to be sliced\r\nThe input does not have to be formatted.\r\n\r\nAs input is possible:\r\n - an array of Json inputs\r\n - a stream of Json inputs\r\n\r\n## Sliced output\r\nThe files can be created with formatted or compact Json\r\n\r\nThe sliced output files can contain:\r\n - an array of Json inputs with size=$sliceSize\r\n - a stream of Json inputs with $sliceSize items\r\n\r\n## Performance\r\nA quick benchmark shows the time and memory consumption during slicing (measured on my laptop)\r\n\r\n### file with 100.000 json objects, 46MB\r\n- sliceSize=5.000  : time=35 sec\r\n- sliceSize=10.000 : time=40 sec\r\n- sliceSize=25.000 : time=1 min\r\n- sliceSize=50.000 : time=1 min 52 sec\r\n\r\n### file with 1.000.000 json objects, 450MB\r\n- sliceSize=5000    : time=5 min 45 sec\r\n- sliceSize=10.000  : time=6 min 51 sec\r\n- sliceSize=25.000  : time=10 min 5 sec\r\n- sliceSize=50.000  : time=18 min 46 sec, max memory consumption: ~150 MB\r\n- sliceSize=100.000 : time=46 min 25 sec, max memory consumption: ~300 MB\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\nSLICE_SIZE=2\r\n\r\nJQ_SLICE_INPUTS=&#39;\r\n   2376123525 as $EOF |            # random number that does not occur in the input stream to mark the end of the stream\r\n   foreach (inputs, $EOF) as $input\r\n   (\r\n      # init state\r\n      [[], []];                    # .[0]: array to collect inputs\r\n                                   # .[1]: array that has collected $sliceSize inputs and is ready to be extracted\r\n      # update state\r\n      if .[0] | length == $sliceSize   # enough inputs collected\r\n         or $input == $EOF             # or end of stream reached\r\n      then [[$input], .[0]]        # create new array to collect next inputs. Save array .[0] with $sliceSize inputs for extraction\r\n      else [.[0] + [$input], []]   # collect input, nothing to extract after this state update\r\n      end;\r\n\r\n      # extract from state\r\n      if .[1] | length != 0\r\n      then .[1]                    # extract array that has collected $sliceSize inputs\r\n      else empty                   # nothing to extract right now (because still collecting inputs into .[0])\r\n      end\r\n   )\r\n&#39;\r\n\r\nwrite_files() {\r\n  local FILE_NAME_PREFIX=$1\r\n  local FILE_COUNTER=0\r\n  while read line; do\r\n    FILE_COUNTER=$((FILE_COUNTER + 1))\r\n    FILE_NAME=&quot;${FILE_NAME_PREFIX}_$FILE_COUNTER.json&quot;\r\n    echo &quot;writing $FILE_NAME&quot;\r\n    jq &#39;.&#39;      &gt; $FILE_NAME &lt;&lt;&lt; &quot;$line&quot;   # array of formatted json inputs\r\n#   jq -c &#39;.&#39;   &gt; $FILE_NAME &lt;&lt;&lt; &quot;$line&quot;   # compact array of json inputs\r\n#   jq &#39;.[]&#39;    &gt; $FILE_NAME &lt;&lt;&lt; &quot;$line&quot;   # stream of formatted json inputs\r\n#   jq -c &#39;.[]&#39; &gt; $FILE_NAME &lt;&lt;&lt; &quot;$line&quot;   # stream of compact json inputs\r\n  done\r\n}\r\n\r\n\r\necho &quot;how to slice a stream of json inputs&quot;\r\njq -n &#39;{id: (range(5) + 1), a:[1,2]}&#39; |   # create a stream of json inputs\r\njq -n -c --argjson sliceSize $SLICE_SIZE &quot;$JQ_SLICE_INPUTS&quot; |\r\nwrite_files &quot;stream_of_json_inputs_sliced&quot;\r\n\r\necho -e &quot;\\nhow to slice an array of json inputs&quot;\r\njq -n &#39;[{id: (range(5) + 1), a:[1,2]}]&#39; |                  # create an array of json inputs\r\njq -n --stream &#39;fromstream(1|truncate_stream(inputs))&#39; |   # remove outer array to create stream of json inputs\r\njq -n -c --argjson sliceSize $SLICE_SIZE &quot;$JQ_SLICE_INPUTS&quot; |\r\nwrite_files &quot;array_of_json_inputs_sliced&quot;\r\n```\r\n\r\n## output of script\r\n```text\r\nhow to slice a stream of json inputs\r\nwriting stream_of_json_inputs_sliced_1.json\r\nwriting stream_of_json_inputs_sliced_2.json\r\nwriting stream_of_json_inputs_sliced_3.json\r\n\r\nhow to slice an array of json inputs\r\nwriting array_of_json_inputs_sliced_1.json\r\nwriting array_of_json_inputs_sliced_2.json\r\nwriting array_of_json_inputs_sliced_3.json\r\n```\r\n\r\n## generated files\r\n\r\n### `array_of_json_inputs_sliced_1.json`\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;a&quot;: [1,2]\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;a&quot;: [1,2]\r\n  }\r\n]\r\n```\r\n\r\n### `array_of_json_inputs_sliced_2.json`\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 3,\r\n    &quot;a&quot;: [1,2]\r\n  },\r\n  {\r\n    &quot;id&quot;: 4,\r\n    &quot;a&quot;: [1,2]\r\n  }\r\n]\r\n```\r\n\r\n### `array_of_json_inputs_sliced_3.json`\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 5,\r\n    &quot;a&quot;: [1,2]\r\n  }\r\n]\r\n```",
                "title": "Using jq how can I split a very large JSON file into multiple files, each a specific quantity of objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 25,
        "last_activity_date": 1668236370,
        "creation_date": 1523587941,
        "last_edit_date": 1526401168,
        "question_id": 49808581,
        "body_markdown": "I have a large JSON file with I&#39;m guessing 4 million objects.  Each top level has a few levels nested inside.  I want to split that into multiple files of 10000 top level objects each (retaining the structure inside each).  jq should be able to do that right?  I&#39;m not sure how.\r\n\r\nSo data like this:\r\n\r\n    [{\r\n      &quot;id&quot;: 1,\r\n      &quot;user&quot;: {\r\n        &quot;name&quot;: &quot;Nichols Cockle&quot;,\r\n        &quot;email&quot;: &quot;ncockle0@tmall.com&quot;,\r\n        &quot;address&quot;: {\r\n          &quot;city&quot;: &quot;Turt&quot;,\r\n          &quot;state&quot;: &quot;Thị Trấn Y&#234;n Ph&#250;&quot;\r\n        }\r\n      },\r\n      &quot;product&quot;: {\r\n        &quot;name&quot;: &quot;Lychee - Canned&quot;,\r\n        &quot;code&quot;: &quot;36987-1526&quot;\r\n      }\r\n    }, {\r\n      &quot;id&quot;: 2,\r\n      &quot;user&quot;: {\r\n        &quot;name&quot;: &quot;Isacco Scrancher&quot;,\r\n        &quot;email&quot;: &quot;iscrancher1@aol.com&quot;,\r\n        &quot;address&quot;: {\r\n          &quot;city&quot;: &quot;Likwatang Timur&quot;,\r\n          &quot;state&quot;: &quot;Biharamulo&quot;\r\n        }\r\n      },\r\n      &quot;product&quot;: {\r\n        &quot;name&quot;: &quot;Beer - Original Organic Lager&quot;,\r\n        &quot;code&quot;: &quot;47993-200&quot;\r\n      }\r\n    }, {\r\n      &quot;id&quot;: 3,\r\n      &quot;user&quot;: {\r\n        &quot;name&quot;: &quot;Elga Sikora&quot;,\r\n        &quot;email&quot;: &quot;esikora2@statcounter.com&quot;,\r\n        &quot;address&quot;: {\r\n          &quot;city&quot;: &quot;Wenheng&quot;,\r\n          &quot;state&quot;: &quot;Piedra del &#193;guila&quot;\r\n        }\r\n      },\r\n      &quot;product&quot;: {\r\n        &quot;name&quot;: &quot;Parsley - Dried&quot;,\r\n        &quot;code&quot;: &quot;36987-1632&quot;\r\n      }\r\n    }, {\r\n      &quot;id&quot;: 4,\r\n      &quot;user&quot;: {\r\n        &quot;name&quot;: &quot;Andria Keatch&quot;,\r\n        &quot;email&quot;: &quot;akeatch3@salon.com&quot;,\r\n        &quot;address&quot;: {\r\n          &quot;city&quot;: &quot;Arras&quot;,\r\n          &quot;state&quot;: &quot;Iracem&#225;polis&quot;\r\n        }\r\n      },\r\n      &quot;product&quot;: {\r\n        &quot;name&quot;: &quot;Wine - Segura Viudas Aria Brut&quot;,\r\n        &quot;code&quot;: &quot;51079-385&quot;\r\n      }\r\n    }, {\r\n      &quot;id&quot;: 5,\r\n      &quot;user&quot;: {\r\n        &quot;name&quot;: &quot;Dara Sprowle&quot;,\r\n        &quot;email&quot;: &quot;dsprowle4@slate.com&quot;,\r\n        &quot;address&quot;: {\r\n          &quot;city&quot;: &quot;Huatai&quot;,\r\n          &quot;state&quot;: &quot;Kaduna&quot;\r\n        }\r\n      },\r\n      &quot;product&quot;: {\r\n        &quot;name&quot;: &quot;Pork - Hock And Feet Attached&quot;,\r\n        &quot;code&quot;: &quot;0054-8648&quot;\r\n      }\r\n    }]\r\n\r\nWhere this is a single complete object:\r\n\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;user&quot;: {\r\n        &quot;name&quot;: &quot;Nichols Cockle&quot;,\r\n        &quot;email&quot;: &quot;ncockle0@tmall.com&quot;,\r\n        &quot;address&quot;: {\r\n          &quot;city&quot;: &quot;Turt&quot;,\r\n          &quot;state&quot;: &quot;Thị Trấn Y&#234;n Ph&#250;&quot;\r\n        }\r\n      },\r\n      &quot;product&quot;: {\r\n        &quot;name&quot;: &quot;Lychee - Canned&quot;,\r\n        &quot;code&quot;: &quot;36987-1526&quot;\r\n      }\r\n    }\r\n\r\nAnd each file would be a specified number of objects like that.",
        "link": "https://stackoverflow.com/questions/49808581/using-jq-how-can-i-split-a-very-large-json-file-into-multiple-files-each-a-spec",
        "title": "Using jq how can I split a very large JSON file into multiple files, each a specific quantity of objects?"
    },
    {
        "tags": [
            "arrays",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8680838,
                    "reputation": 78,
                    "user_id": 6496760,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/881da83beb92d858554ace23394e6982?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dkalintsev",
                    "link": "https://stackoverflow.com/users/6496760/dkalintsev"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523669112,
                "post_id": 49810143,
                "comment_id": 86669587,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1523602985,
                "last_edit_date": 1523602985,
                "creation_date": 1523602054,
                "answer_id": 49810881,
                "question_id": 49810143,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One way to accomplish what you want in the manner of your attempt would be as follows:\r\n\r\n    jq -n --arg value_a0 1.1.1.1 --arg value_b0 81 --arg value_a1 2.2.2.2 --arg value_b1 82 --arg value_a2 3.3.3.3 --arg value_b2 83 &#39;\r\n      .nodes=[ {ip: $value_a0, port: $value_b0},\r\n               {ip: $value_a1, port: $value_b1},\r\n               {ip: $value_a2, port: $value_b2} ]&#39;\r\n\r\nNotice that -n can be used instead of &#39;&lt;&lt;&lt; {}&#39;.  \r\n\r\nUsing &#39;=&#39;, one could similarly use the filter:\r\n\r\n\r\n    .nodes=[ (.ip=$value_a0 |.port=$value_b0),\r\n             (.ip=$value_a1 |.port=$value_b1), \r\n             (.ip=$value_a2 |.port=$value_b2) ]\r\n\r\nUsing --arg in this manner, however, does seem very painful. There are probably many better or at least more flexible alternatives.  Consider, for example:\r\n\r\n    echo &#39;&quot;1.1.1.1&quot; &quot;81&quot; &quot;2.2.2.2&quot; &quot;82&quot; &quot;3.3.3.3&quot; &quot;83&quot;&#39; | jq -n &#39;\r\n      [{ip:inputs, port:input}]\r\n    &#39;\r\n\r\nOr if you don&#39;t want to have to quote the input strings:\r\n\r\n    cat &lt;&lt; EOF | jq -R -n &#39;[{ip: inputs, port: input}]&#39;\r\n    1.1.1.1\r\n    81\r\n    2.2.2.2\r\n    82\r\n    3.3.3.3\r\n    83\r\n    EOF\r\n\r\n",
                "title": "Generating a JSON array of dicts using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1523602985,
        "creation_date": 1523598714,
        "last_edit_date": 1523601361,
        "question_id": 49810143,
        "body_markdown": "I&#39;m trying to generate a JSON file from a bunch of values that I pass to jq through --arg parameters. The resulting format is correct, but the contents are tunring out unexpected:\r\n\r\n    $ jq --arg value_a0 1.1.1.1 --arg value_b0 81 --arg value_a1 2.2.2.2 --arg value_b1 82 --arg value_a2 3.3.3.3 --arg value_b2 83 &#39;. | .nodes=[ .ip=$value_a0 | .port=$value_b0, .ip=$value_a1 | .port=$value_b1, .ip=$value_a2 | .port=$value_b2 ]&#39; &lt;&lt;&lt;&#39;{}&#39;\r\n    {\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;ip&quot;: &quot;1.1.1.1&quot;,\r\n          &quot;port&quot;: &quot;83&quot;\r\n        },\r\n        {\r\n          &quot;ip&quot;: &quot;3.3.3.3&quot;,\r\n          &quot;port&quot;: &quot;83&quot;\r\n        },\r\n        {\r\n          &quot;ip&quot;: &quot;2.2.2.2&quot;,\r\n          &quot;port&quot;: &quot;83&quot;\r\n        },\r\n        {\r\n          &quot;ip&quot;: &quot;3.3.3.3&quot;,\r\n          &quot;port&quot;: &quot;83&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI was hoping to get:\r\n\r\n    {\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;ip&quot;: &quot;1.1.1.1&quot;,\r\n          &quot;port&quot;: &quot;81&quot;\r\n        },\r\n        {\r\n          &quot;ip&quot;: &quot;2.2.2.2&quot;,\r\n          &quot;port&quot;: &quot;82&quot;\r\n        },\r\n        {\r\n          &quot;ip&quot;: &quot;3.3.3.3&quot;,\r\n          &quot;port&quot;: &quot;83&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nI was hoping that the .nodes=[] would just summarise the results of operations separated by commas, but I&#39;m obviously missing something. :(",
        "link": "https://stackoverflow.com/questions/49810143/generating-a-json-array-of-dicts-using-jq",
        "title": "Generating a JSON array of dicts using jq"
    },
    {
        "tags": [
            "arrays",
            "functional-programming",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523605354,
                "post_id": 49811280,
                "comment_id": 86637978,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1523607214,
                "creation_date": 1523607214,
                "answer_id": 49812269,
                "question_id": 49811280,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "By starting the pipeline with `.[]`, you are converting the array into a stream.  You could &quot;reconstitute&quot; the array by wrapping the entire jq expression in square brackets (i.e. `[ .... ]`); or you could avoid using `.[]` in the first place by using `map( select(...) )`.  \r\n\r\n(Since `map(f)` is implemented as `[.[] | f]` it doesn&#39;t make much difference which method you choose except perhaps on stylistic grounds.  One could argue that `map` is more appropriate for a functional style, whereas `[.[] ... ]` is less biased towards English.)\r\n",
                "title": "Rebuild array from output of select command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1523608787,
        "creation_date": 1523603486,
        "last_edit_date": 1523608787,
        "question_id": 49811280,
        "body_markdown": "I have to select objects in an array according a test pattern\r\n\r\nI apply the following command:\r\n\r\n    jq &#39;.[] | select(.path | test(&quot;a/b&quot;) | not)&#39;\r\n\r\nto the following object\r\n\r\n    [\r\n       {\r\n          path: &quot;a/b&quot;\r\n       },\r\n       {\r\n          path: &quot;a/b/c&quot;\r\n       },\r\n       {\r\n          path: &quot;a/c&quot;\r\n       },\r\n       {\r\n          path: &quot;a/d&quot;\r\n       }\r\n    ]\r\n\r\n\r\n\r\nMy problem is that the result is not anymore an array but a list of objects. I have tried to do the most obvious thing which is to pipe the command to `map(.)` but I get the following result:\r\n\r\n    [\r\n      &quot;a/c&quot;\r\n    ]\r\n    [\r\n      &quot;a/d&quot;\r\n    ]",
        "link": "https://stackoverflow.com/questions/49811280/rebuild-array-from-output-of-select-command",
        "title": "Rebuild array from output of select command"
    },
    {
        "tags": [
            "json",
            "schema",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1523641616,
                "creation_date": 1523641616,
                "answer_id": 49822577,
                "question_id": 49817756,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Yes, it&#39;s valid JSON, but the jq query does not match at all.\r\n\r\nFirst, the input JSON is an array, so presumably you want to use `map(...)` rather than `[...]`.  (Debugging hint: start small.]\r\n\r\nSecond, the schema of the JSON does not match the query. For example, the query supposes there is a key named `sails`, which does not exist anywhere in the JSON. (Debugging hint: use `schema.jq` to view the schema of a JSON document -- see below.)\r\n\r\n## schema.jq\r\n\r\nUsing https://gist.github.com/pkoppstein/a5abb4ebef3b0f72a6ed with the last line uncommented:\r\n\r\n    $ jq -f schema.jq input.json\r\n    {\r\n      &quot;nid&quot;: &quot;number&quot;,\r\n      &quot;includesservices&quot;: &quot;string&quot;,\r\n      &quot;title&quot;: &quot;string&quot;,\r\n      &quot;nights&quot;: &quot;number&quot;,\r\n      &quot;company&quot;: &quot;string&quot;,\r\n      &quot;zone&quot;: &quot;string&quot;,\r\n      &quot;schiffsbeschreibung&quot;: &quot;string&quot;,\r\n      &quot;sails_nid&quot;: &quot;number&quot;,\r\n      &quot;arrival&quot;: &quot;number&quot;,\r\n      &quot;departure&quot;: &quot;number&quot;,\r\n      &quot;cabinname&quot;: &quot;string&quot;,\r\n      &quot;cabintype&quot;: &quot;string&quot;,\r\n      &quot;cabinnid&quot;: &quot;number&quot;,\r\n      &quot;catalogPrice&quot;: &quot;number&quot;,\r\n      &quot;discountPrice&quot;: &quot;number&quot;,\r\n      &quot;discountPercentage&quot;: &quot;number&quot;,\r\n      &quot;currency&quot;: &quot;string&quot;\r\n    }\r\n\r\n\r\n",
                "title": "JQ: Invalid numeric literal at line 1, column 3"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1526105721,
                "creation_date": 1526105721,
                "answer_id": 50303423,
                "question_id": 49817756,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Problem not fixed, but i designed a work around (i merged both operations into one). I createe an issue @github vor that.\r\nThanks vor the help.\r\n\r\nRegards\r\nTimo \r\n",
                "title": "JQ: Invalid numeric literal at line 1, column 3"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1526105721,
        "creation_date": 1523624682,
        "last_edit_date": 1523866669,
        "question_id": 49817756,
        "body_markdown": "I actually move some of my equipment and changed the OS for some VMs. I use jq 1.5 under Windows 10 and got now an error with a json Transformation. I use following jq command: \r\n\r\n    C:\\import\\Dreamlines\\jq.exe &quot;[{nid, includesservices: .includedServices, title, nights, company: .operator.shortTitle, zone: .zones[0].title, schiffsbeschreibung: .ship.factsAndFigures} + (.sails[] | ({ sails_nid: .nid, arrival, departure } + (.cabins[] | { cabinname: .cabinType.title, cabintype: .cabinType.kindName, cabinnid: .cabinType.nid, catalogPrice, discountPrice, discountPercentage, currency } )))   ]&quot; C:\\import\\Dreamlines\\dreamlines_details.json | out-file -encoding Unicode -filepath C:\\import\\Dreamlines\\import_sails.json\r\n\r\n\r\nTo generate following json:\r\n\r\n\r\n    [{\r\n\t\t&quot;nid&quot;: 509660,\r\n\t\t&quot;includesservices&quot;: &quot;&lt;ul&gt;\\r\\n\\r\\n&lt;li&gt;Kreuzfahrt ab/bis Dubai auf der MSC Splendida&lt;/li&gt;\\r\\n&lt;li&gt;Unterkunft in der gebuchten Kabinenkategorie&lt;/li&gt;\\r\\n&lt;li&gt;Vollpension, d.h. Fr&#252;hst&#252;ck, Mittagessen, Nachmittagstee, Snacks, Abendessen&lt;/li&gt;\\r\\n&lt;li&gt;Vielf&#228;ltiges Sportangebot, inkl. Nutzung Fitnesscenter und Open-Air- Sportanlagen&lt;/li&gt;\\r\\n&lt;li&gt;Entertainment&lt;/li&gt;\\r\\n&lt;li&gt;Qualifizierte Kinderbetreuung&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n\\r\\n\\r\\n\\r\\n&quot;,\r\n\t\t&quot;title&quot;: &quot;Von Dubai &#252;ber Manama in 15 Tagen&quot;,\r\n\t\t&quot;nights&quot;: 14,\r\n\t\t&quot;company&quot;: &quot;MSC&quot;,\r\n\t\t&quot;zone&quot;: &quot;Emirate und Orient&quot;,\r\n\t\t&quot;schiffsbeschreibung&quot;: &quot;&lt;p&gt;&lt;strong&gt;Schiffsdaten&lt;/strong&gt;&lt;/p&gt;\\r\\n&lt;ul&gt;\\r\\n&lt;li&gt;Inbetriebnahme: 2009&lt;/li&gt;\\r\\n&lt;li&gt;L&#228;nge: 333 m&lt;/li&gt;\\r\\n&lt;li&gt;H&#246;he: 67 m&lt;/li&gt;\\r\\n&lt;li&gt;Breite: 38 m&lt;/li&gt;\\r\\n&lt;li&gt;Tiefgang: 8,45 m&lt;/li&gt;\\r\\n&lt;li&gt;Tonnage: 137.936 BRT&lt;/li&gt;\\r\\n&lt;li&gt;Geschwindigkeit: 23 Knoten&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Decks: 18&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Kabine: 1.637&lt;/li&gt;\\r\\n&lt;li&gt;Passagiere: 3.247&lt;/li&gt;\\r\\n&lt;li&gt;Besatzung: 1.370&lt;/li&gt;\\r\\n&lt;li&gt;Sprachen an Bord: Italienisch, Deutsch, Franz&#246;sisch, Englisch&lt;/li&gt;\\r\\n&lt;li&gt;Bordw&#228;hrung: US-Dollar, Euro&lt;/li&gt;\\r\\n&lt;li&gt;Internet an Bord: Es gibt ein Internetcaf&#233; und in allen Kabinen kann eine Internetverbindung gegen einen Geb&#252;hr dazu gebucht werden.&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n&quot;,\r\n\t\t&quot;sails_nid&quot;: 509662,\r\n\t\t&quot;arrival&quot;: 1552694400,\r\n\t\t&quot;departure&quot;: 1551484800,\r\n\t\t&quot;cabinname&quot;: &quot;Innenkabine Fantastica (Kat. I2):&quot;,\r\n\t\t&quot;cabintype&quot;: &quot;Innenkabine&quot;,\r\n\t\t&quot;cabinnid&quot;: 2919,\r\n\t\t&quot;catalogPrice&quot;: 0,\r\n\t\t&quot;discountPrice&quot;: 0,\r\n\t\t&quot;discountPercentage&quot;: 0,\r\n\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;nid&quot;: 509660,\r\n\t\t&quot;includesservices&quot;: &quot;&lt;ul&gt;\\r\\n\\r\\n&lt;li&gt;Kreuzfahrt ab/bis Dubai auf der MSC Splendida&lt;/li&gt;\\r\\n&lt;li&gt;Unterkunft in der gebuchten Kabinenkategorie&lt;/li&gt;\\r\\n&lt;li&gt;Vollpension, d.h. Fr&#252;hst&#252;ck, Mittagessen, Nachmittagstee, Snacks, Abendessen&lt;/li&gt;\\r\\n&lt;li&gt;Vielf&#228;ltiges Sportangebot, inkl. Nutzung Fitnesscenter und Open-Air- Sportanlagen&lt;/li&gt;\\r\\n&lt;li&gt;Entertainment&lt;/li&gt;\\r\\n&lt;li&gt;Qualifizierte Kinderbetreuung&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n\\r\\n\\r\\n\\r\\n&quot;,\r\n\t\t&quot;title&quot;: &quot;Von Dubai &#252;ber Manama in 15 Tagen&quot;,\r\n\t\t&quot;nights&quot;: 14,\r\n\t\t&quot;company&quot;: &quot;MSC&quot;,\r\n\t\t&quot;zone&quot;: &quot;Emirate und Orient&quot;,\r\n\t\t&quot;schiffsbeschreibung&quot;: &quot;&lt;p&gt;&lt;strong&gt;Schiffsdaten&lt;/strong&gt;&lt;/p&gt;\\r\\n&lt;ul&gt;\\r\\n&lt;li&gt;Inbetriebnahme: 2009&lt;/li&gt;\\r\\n&lt;li&gt;L&#228;nge: 333 m&lt;/li&gt;\\r\\n&lt;li&gt;H&#246;he: 67 m&lt;/li&gt;\\r\\n&lt;li&gt;Breite: 38 m&lt;/li&gt;\\r\\n&lt;li&gt;Tiefgang: 8,45 m&lt;/li&gt;\\r\\n&lt;li&gt;Tonnage: 137.936 BRT&lt;/li&gt;\\r\\n&lt;li&gt;Geschwindigkeit: 23 Knoten&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Decks: 18&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Kabine: 1.637&lt;/li&gt;\\r\\n&lt;li&gt;Passagiere: 3.247&lt;/li&gt;\\r\\n&lt;li&gt;Besatzung: 1.370&lt;/li&gt;\\r\\n&lt;li&gt;Sprachen an Bord: Italienisch, Deutsch, Franz&#246;sisch, Englisch&lt;/li&gt;\\r\\n&lt;li&gt;Bordw&#228;hrung: US-Dollar, Euro&lt;/li&gt;\\r\\n&lt;li&gt;Internet an Bord: Es gibt ein Internetcaf&#233; und in allen Kabinen kann eine Internetverbindung gegen einen Geb&#252;hr dazu gebucht werden.&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n&quot;,\r\n\t\t&quot;sails_nid&quot;: 509662,\r\n\t\t&quot;arrival&quot;: 1552694400,\r\n\t\t&quot;departure&quot;: 1551484800,\r\n\t\t&quot;cabinname&quot;: &quot;Innenkabine Bella (Kat. I1):&quot;,\r\n\t\t&quot;cabintype&quot;: &quot;Innenkabine&quot;,\r\n\t\t&quot;cabinnid&quot;: 232847,\r\n\t\t&quot;catalogPrice&quot;: 0,\r\n\t\t&quot;discountPrice&quot;: 0,\r\n\t\t&quot;discountPercentage&quot;: 0,\r\n\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;nid&quot;: 509660,\r\n\t\t&quot;includesservices&quot;: &quot;&lt;ul&gt;\\r\\n\\r\\n&lt;li&gt;Kreuzfahrt ab/bis Dubai auf der MSC Splendida&lt;/li&gt;\\r\\n&lt;li&gt;Unterkunft in der gebuchten Kabinenkategorie&lt;/li&gt;\\r\\n&lt;li&gt;Vollpension, d.h. Fr&#252;hst&#252;ck, Mittagessen, Nachmittagstee, Snacks, Abendessen&lt;/li&gt;\\r\\n&lt;li&gt;Vielf&#228;ltiges Sportangebot, inkl. Nutzung Fitnesscenter und Open-Air- Sportanlagen&lt;/li&gt;\\r\\n&lt;li&gt;Entertainment&lt;/li&gt;\\r\\n&lt;li&gt;Qualifizierte Kinderbetreuung&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n\\r\\n\\r\\n\\r\\n&quot;,\r\n\t\t&quot;title&quot;: &quot;Von Dubai &#252;ber Manama in 15 Tagen&quot;,\r\n\t\t&quot;nights&quot;: 14,\r\n\t\t&quot;company&quot;: &quot;MSC&quot;,\r\n\t\t&quot;zone&quot;: &quot;Emirate und Orient&quot;,\r\n\t\t&quot;schiffsbeschreibung&quot;: &quot;&lt;p&gt;&lt;strong&gt;Schiffsdaten&lt;/strong&gt;&lt;/p&gt;\\r\\n&lt;ul&gt;\\r\\n&lt;li&gt;Inbetriebnahme: 2009&lt;/li&gt;\\r\\n&lt;li&gt;L&#228;nge: 333 m&lt;/li&gt;\\r\\n&lt;li&gt;H&#246;he: 67 m&lt;/li&gt;\\r\\n&lt;li&gt;Breite: 38 m&lt;/li&gt;\\r\\n&lt;li&gt;Tiefgang: 8,45 m&lt;/li&gt;\\r\\n&lt;li&gt;Tonnage: 137.936 BRT&lt;/li&gt;\\r\\n&lt;li&gt;Geschwindigkeit: 23 Knoten&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Decks: 18&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Kabine: 1.637&lt;/li&gt;\\r\\n&lt;li&gt;Passagiere: 3.247&lt;/li&gt;\\r\\n&lt;li&gt;Besatzung: 1.370&lt;/li&gt;\\r\\n&lt;li&gt;Sprachen an Bord: Italienisch, Deutsch, Franz&#246;sisch, Englisch&lt;/li&gt;\\r\\n&lt;li&gt;Bordw&#228;hrung: US-Dollar, Euro&lt;/li&gt;\\r\\n&lt;li&gt;Internet an Bord: Es gibt ein Internetcaf&#233; und in allen Kabinen kann eine Internetverbindung gegen einen Geb&#252;hr dazu gebucht werden.&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n&quot;,\r\n\t\t&quot;sails_nid&quot;: 509662,\r\n\t\t&quot;arrival&quot;: 1552694400,\r\n\t\t&quot;departure&quot;: 1551484800,\r\n\t\t&quot;cabinname&quot;: &quot;Au&#223;enkabine Bella (Kat. O1): &quot;,\r\n\t\t&quot;cabintype&quot;: &quot;Au&#223;enkabine&quot;,\r\n\t\t&quot;cabinnid&quot;: 232848,\r\n\t\t&quot;catalogPrice&quot;: 0,\r\n\t\t&quot;discountPrice&quot;: 0,\r\n\t\t&quot;discountPercentage&quot;: 0,\r\n\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;nid&quot;: 509660,\r\n\t\t&quot;includesservices&quot;: &quot;&lt;ul&gt;\\r\\n\\r\\n&lt;li&gt;Kreuzfahrt ab/bis Dubai auf der MSC Splendida&lt;/li&gt;\\r\\n&lt;li&gt;Unterkunft in der gebuchten Kabinenkategorie&lt;/li&gt;\\r\\n&lt;li&gt;Vollpension, d.h. Fr&#252;hst&#252;ck, Mittagessen, Nachmittagstee, Snacks, Abendessen&lt;/li&gt;\\r\\n&lt;li&gt;Vielf&#228;ltiges Sportangebot, inkl. Nutzung Fitnesscenter und Open-Air- Sportanlagen&lt;/li&gt;\\r\\n&lt;li&gt;Entertainment&lt;/li&gt;\\r\\n&lt;li&gt;Qualifizierte Kinderbetreuung&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n\\r\\n\\r\\n\\r\\n&quot;,\r\n\t\t&quot;title&quot;: &quot;Von Dubai &#252;ber Manama in 15 Tagen&quot;,\r\n\t\t&quot;nights&quot;: 14,\r\n\t\t&quot;company&quot;: &quot;MSC&quot;,\r\n\t\t&quot;zone&quot;: &quot;Emirate und Orient&quot;,\r\n\t\t&quot;schiffsbeschreibung&quot;: &quot;&lt;p&gt;&lt;strong&gt;Schiffsdaten&lt;/strong&gt;&lt;/p&gt;\\r\\n&lt;ul&gt;\\r\\n&lt;li&gt;Inbetriebnahme: 2009&lt;/li&gt;\\r\\n&lt;li&gt;L&#228;nge: 333 m&lt;/li&gt;\\r\\n&lt;li&gt;H&#246;he: 67 m&lt;/li&gt;\\r\\n&lt;li&gt;Breite: 38 m&lt;/li&gt;\\r\\n&lt;li&gt;Tiefgang: 8,45 m&lt;/li&gt;\\r\\n&lt;li&gt;Tonnage: 137.936 BRT&lt;/li&gt;\\r\\n&lt;li&gt;Geschwindigkeit: 23 Knoten&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Decks: 18&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Kabine: 1.637&lt;/li&gt;\\r\\n&lt;li&gt;Passagiere: 3.247&lt;/li&gt;\\r\\n&lt;li&gt;Besatzung: 1.370&lt;/li&gt;\\r\\n&lt;li&gt;Sprachen an Bord: Italienisch, Deutsch, Franz&#246;sisch, Englisch&lt;/li&gt;\\r\\n&lt;li&gt;Bordw&#228;hrung: US-Dollar, Euro&lt;/li&gt;\\r\\n&lt;li&gt;Internet an Bord: Es gibt ein Internetcaf&#233; und in allen Kabinen kann eine Internetverbindung gegen einen Geb&#252;hr dazu gebucht werden.&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n&quot;,\r\n\t\t&quot;sails_nid&quot;: 509662,\r\n\t\t&quot;arrival&quot;: 1552694400,\r\n\t\t&quot;departure&quot;: 1551484800,\r\n\t\t&quot;cabinname&quot;: &quot;Au&#223;enkabine Fantastica (Kat. O2): &quot;,\r\n\t\t&quot;cabintype&quot;: &quot;Au&#223;enkabine&quot;,\r\n\t\t&quot;cabinnid&quot;: 232849,\r\n\t\t&quot;catalogPrice&quot;: 0,\r\n\t\t&quot;discountPrice&quot;: 0,\r\n\t\t&quot;discountPercentage&quot;: 0,\r\n\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;nid&quot;: 509660,\r\n\t\t&quot;includesservices&quot;: &quot;&lt;ul&gt;\\r\\n\\r\\n&lt;li&gt;Kreuzfahrt ab/bis Dubai auf der MSC Splendida&lt;/li&gt;\\r\\n&lt;li&gt;Unterkunft in der gebuchten Kabinenkategorie&lt;/li&gt;\\r\\n&lt;li&gt;Vollpension, d.h. Fr&#252;hst&#252;ck, Mittagessen, Nachmittagstee, Snacks, Abendessen&lt;/li&gt;\\r\\n&lt;li&gt;Vielf&#228;ltiges Sportangebot, inkl. Nutzung Fitnesscenter und Open-Air- Sportanlagen&lt;/li&gt;\\r\\n&lt;li&gt;Entertainment&lt;/li&gt;\\r\\n&lt;li&gt;Qualifizierte Kinderbetreuung&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n\\r\\n\\r\\n\\r\\n&quot;,\r\n\t\t&quot;title&quot;: &quot;Von Dubai &#252;ber Manama in 15 Tagen&quot;,\r\n\t\t&quot;nights&quot;: 14,\r\n\t\t&quot;company&quot;: &quot;MSC&quot;,\r\n\t\t&quot;zone&quot;: &quot;Emirate und Orient&quot;,\r\n\t\t&quot;schiffsbeschreibung&quot;: &quot;&lt;p&gt;&lt;strong&gt;Schiffsdaten&lt;/strong&gt;&lt;/p&gt;\\r\\n&lt;ul&gt;\\r\\n&lt;li&gt;Inbetriebnahme: 2009&lt;/li&gt;\\r\\n&lt;li&gt;L&#228;nge: 333 m&lt;/li&gt;\\r\\n&lt;li&gt;H&#246;he: 67 m&lt;/li&gt;\\r\\n&lt;li&gt;Breite: 38 m&lt;/li&gt;\\r\\n&lt;li&gt;Tiefgang: 8,45 m&lt;/li&gt;\\r\\n&lt;li&gt;Tonnage: 137.936 BRT&lt;/li&gt;\\r\\n&lt;li&gt;Geschwindigkeit: 23 Knoten&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Decks: 18&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Kabine: 1.637&lt;/li&gt;\\r\\n&lt;li&gt;Passagiere: 3.247&lt;/li&gt;\\r\\n&lt;li&gt;Besatzung: 1.370&lt;/li&gt;\\r\\n&lt;li&gt;Sprachen an Bord: Italienisch, Deutsch, Franz&#246;sisch, Englisch&lt;/li&gt;\\r\\n&lt;li&gt;Bordw&#228;hrung: US-Dollar, Euro&lt;/li&gt;\\r\\n&lt;li&gt;Internet an Bord: Es gibt ein Internetcaf&#233; und in allen Kabinen kann eine Internetverbindung gegen einen Geb&#252;hr dazu gebucht werden.&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n&quot;,\r\n\t\t&quot;sails_nid&quot;: 509662,\r\n\t\t&quot;arrival&quot;: 1552694400,\r\n\t\t&quot;departure&quot;: 1551484800,\r\n\t\t&quot;cabinname&quot;: &quot;Balkonkabine Bella (Kat. B1): &quot;,\r\n\t\t&quot;cabintype&quot;: &quot;Balkonkabine&quot;,\r\n\t\t&quot;cabinnid&quot;: 232850,\r\n\t\t&quot;catalogPrice&quot;: 0,\r\n\t\t&quot;discountPrice&quot;: 0,\r\n\t\t&quot;discountPercentage&quot;: 0,\r\n\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;nid&quot;: 509660,\r\n\t\t&quot;includesservices&quot;: &quot;&lt;ul&gt;\\r\\n\\r\\n&lt;li&gt;Kreuzfahrt ab/bis Dubai auf der MSC Splendida&lt;/li&gt;\\r\\n&lt;li&gt;Unterkunft in der gebuchten Kabinenkategorie&lt;/li&gt;\\r\\n&lt;li&gt;Vollpension, d.h. Fr&#252;hst&#252;ck, Mittagessen, Nachmittagstee, Snacks, Abendessen&lt;/li&gt;\\r\\n&lt;li&gt;Vielf&#228;ltiges Sportangebot, inkl. Nutzung Fitnesscenter und Open-Air- Sportanlagen&lt;/li&gt;\\r\\n&lt;li&gt;Entertainment&lt;/li&gt;\\r\\n&lt;li&gt;Qualifizierte Kinderbetreuung&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n\\r\\n\\r\\n\\r\\n&quot;,\r\n\t\t&quot;title&quot;: &quot;Von Dubai &#252;ber Manama in 15 Tagen&quot;,\r\n\t\t&quot;nights&quot;: 14,\r\n\t\t&quot;company&quot;: &quot;MSC&quot;,\r\n\t\t&quot;zone&quot;: &quot;Emirate und Orient&quot;,\r\n\t\t&quot;schiffsbeschreibung&quot;: &quot;&lt;p&gt;&lt;strong&gt;Schiffsdaten&lt;/strong&gt;&lt;/p&gt;\\r\\n&lt;ul&gt;\\r\\n&lt;li&gt;Inbetriebnahme: 2009&lt;/li&gt;\\r\\n&lt;li&gt;L&#228;nge: 333 m&lt;/li&gt;\\r\\n&lt;li&gt;H&#246;he: 67 m&lt;/li&gt;\\r\\n&lt;li&gt;Breite: 38 m&lt;/li&gt;\\r\\n&lt;li&gt;Tiefgang: 8,45 m&lt;/li&gt;\\r\\n&lt;li&gt;Tonnage: 137.936 BRT&lt;/li&gt;\\r\\n&lt;li&gt;Geschwindigkeit: 23 Knoten&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Decks: 18&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Kabine: 1.637&lt;/li&gt;\\r\\n&lt;li&gt;Passagiere: 3.247&lt;/li&gt;\\r\\n&lt;li&gt;Besatzung: 1.370&lt;/li&gt;\\r\\n&lt;li&gt;Sprachen an Bord: Italienisch, Deutsch, Franz&#246;sisch, Englisch&lt;/li&gt;\\r\\n&lt;li&gt;Bordw&#228;hrung: US-Dollar, Euro&lt;/li&gt;\\r\\n&lt;li&gt;Internet an Bord: Es gibt ein Internetcaf&#233; und in allen Kabinen kann eine Internetverbindung gegen einen Geb&#252;hr dazu gebucht werden.&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n&quot;,\r\n\t\t&quot;sails_nid&quot;: 509662,\r\n\t\t&quot;arrival&quot;: 1552694400,\r\n\t\t&quot;departure&quot;: 1551484800,\r\n\t\t&quot;cabinname&quot;: &quot;Balkonkabine Fantastica (Kat. B2): &quot;,\r\n\t\t&quot;cabintype&quot;: &quot;Balkonkabine&quot;,\r\n\t\t&quot;cabinnid&quot;: 232851,\r\n\t\t&quot;catalogPrice&quot;: 0,\r\n\t\t&quot;discountPrice&quot;: 0,\r\n\t\t&quot;discountPercentage&quot;: 0,\r\n\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;nid&quot;: 509660,\r\n\t\t&quot;includesservices&quot;: &quot;&lt;ul&gt;\\r\\n\\r\\n&lt;li&gt;Kreuzfahrt ab/bis Dubai auf der MSC Splendida&lt;/li&gt;\\r\\n&lt;li&gt;Unterkunft in der gebuchten Kabinenkategorie&lt;/li&gt;\\r\\n&lt;li&gt;Vollpension, d.h. Fr&#252;hst&#252;ck, Mittagessen, Nachmittagstee, Snacks, Abendessen&lt;/li&gt;\\r\\n&lt;li&gt;Vielf&#228;ltiges Sportangebot, inkl. Nutzung Fitnesscenter und Open-Air- Sportanlagen&lt;/li&gt;\\r\\n&lt;li&gt;Entertainment&lt;/li&gt;\\r\\n&lt;li&gt;Qualifizierte Kinderbetreuung&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n\\r\\n\\r\\n\\r\\n&quot;,\r\n\t\t&quot;title&quot;: &quot;Von Dubai &#252;ber Manama in 15 Tagen&quot;,\r\n\t\t&quot;nights&quot;: 14,\r\n\t\t&quot;company&quot;: &quot;MSC&quot;,\r\n\t\t&quot;zone&quot;: &quot;Emirate und Orient&quot;,\r\n\t\t&quot;schiffsbeschreibung&quot;: &quot;&lt;p&gt;&lt;strong&gt;Schiffsdaten&lt;/strong&gt;&lt;/p&gt;\\r\\n&lt;ul&gt;\\r\\n&lt;li&gt;Inbetriebnahme: 2009&lt;/li&gt;\\r\\n&lt;li&gt;L&#228;nge: 333 m&lt;/li&gt;\\r\\n&lt;li&gt;H&#246;he: 67 m&lt;/li&gt;\\r\\n&lt;li&gt;Breite: 38 m&lt;/li&gt;\\r\\n&lt;li&gt;Tiefgang: 8,45 m&lt;/li&gt;\\r\\n&lt;li&gt;Tonnage: 137.936 BRT&lt;/li&gt;\\r\\n&lt;li&gt;Geschwindigkeit: 23 Knoten&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Decks: 18&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Kabine: 1.637&lt;/li&gt;\\r\\n&lt;li&gt;Passagiere: 3.247&lt;/li&gt;\\r\\n&lt;li&gt;Besatzung: 1.370&lt;/li&gt;\\r\\n&lt;li&gt;Sprachen an Bord: Italienisch, Deutsch, Franz&#246;sisch, Englisch&lt;/li&gt;\\r\\n&lt;li&gt;Bordw&#228;hrung: US-Dollar, Euro&lt;/li&gt;\\r\\n&lt;li&gt;Internet an Bord: Es gibt ein Internetcaf&#233; und in allen Kabinen kann eine Internetverbindung gegen einen Geb&#252;hr dazu gebucht werden.&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n&quot;,\r\n\t\t&quot;sails_nid&quot;: 509662,\r\n\t\t&quot;arrival&quot;: 1552694400,\r\n\t\t&quot;departure&quot;: 1551484800,\r\n\t\t&quot;cabinname&quot;: &quot;Balkonkabine Aurea (Kat. B3): &quot;,\r\n\t\t&quot;cabintype&quot;: &quot;Balkonkabine&quot;,\r\n\t\t&quot;cabinnid&quot;: 232853,\r\n\t\t&quot;catalogPrice&quot;: 0,\r\n\t\t&quot;discountPrice&quot;: 0,\r\n\t\t&quot;discountPercentage&quot;: 0,\r\n\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;nid&quot;: 509660,\r\n\t\t&quot;includesservices&quot;: &quot;&lt;ul&gt;\\r\\n\\r\\n&lt;li&gt;Kreuzfahrt ab/bis Dubai auf der MSC Splendida&lt;/li&gt;\\r\\n&lt;li&gt;Unterkunft in der gebuchten Kabinenkategorie&lt;/li&gt;\\r\\n&lt;li&gt;Vollpension, d.h. Fr&#252;hst&#252;ck, Mittagessen, Nachmittagstee, Snacks, Abendessen&lt;/li&gt;\\r\\n&lt;li&gt;Vielf&#228;ltiges Sportangebot, inkl. Nutzung Fitnesscenter und Open-Air- Sportanlagen&lt;/li&gt;\\r\\n&lt;li&gt;Entertainment&lt;/li&gt;\\r\\n&lt;li&gt;Qualifizierte Kinderbetreuung&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n\\r\\n\\r\\n\\r\\n&quot;,\r\n\t\t&quot;title&quot;: &quot;Von Dubai &#252;ber Manama in 15 Tagen&quot;,\r\n\t\t&quot;nights&quot;: 14,\r\n\t\t&quot;company&quot;: &quot;MSC&quot;,\r\n\t\t&quot;zone&quot;: &quot;Emirate und Orient&quot;,\r\n\t\t&quot;schiffsbeschreibung&quot;: &quot;&lt;p&gt;&lt;strong&gt;Schiffsdaten&lt;/strong&gt;&lt;/p&gt;\\r\\n&lt;ul&gt;\\r\\n&lt;li&gt;Inbetriebnahme: 2009&lt;/li&gt;\\r\\n&lt;li&gt;L&#228;nge: 333 m&lt;/li&gt;\\r\\n&lt;li&gt;H&#246;he: 67 m&lt;/li&gt;\\r\\n&lt;li&gt;Breite: 38 m&lt;/li&gt;\\r\\n&lt;li&gt;Tiefgang: 8,45 m&lt;/li&gt;\\r\\n&lt;li&gt;Tonnage: 137.936 BRT&lt;/li&gt;\\r\\n&lt;li&gt;Geschwindigkeit: 23 Knoten&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Decks: 18&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Kabine: 1.637&lt;/li&gt;\\r\\n&lt;li&gt;Passagiere: 3.247&lt;/li&gt;\\r\\n&lt;li&gt;Besatzung: 1.370&lt;/li&gt;\\r\\n&lt;li&gt;Sprachen an Bord: Italienisch, Deutsch, Franz&#246;sisch, Englisch&lt;/li&gt;\\r\\n&lt;li&gt;Bordw&#228;hrung: US-Dollar, Euro&lt;/li&gt;\\r\\n&lt;li&gt;Internet an Bord: Es gibt ein Internetcaf&#233; und in allen Kabinen kann eine Internetverbindung gegen einen Geb&#252;hr dazu gebucht werden.&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n&quot;,\r\n\t\t&quot;sails_nid&quot;: 509662,\r\n\t\t&quot;arrival&quot;: 1552694400,\r\n\t\t&quot;departure&quot;: 1551484800,\r\n\t\t&quot;cabinname&quot;: &quot;Aurea Suite (Kat. S3): &quot;,\r\n\t\t&quot;cabintype&quot;: &quot;Suite&quot;,\r\n\t\t&quot;cabinnid&quot;: 232854,\r\n\t\t&quot;catalogPrice&quot;: 0,\r\n\t\t&quot;discountPrice&quot;: 0,\r\n\t\t&quot;discountPercentage&quot;: 0,\r\n\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;nid&quot;: 509660,\r\n\t\t&quot;includesservices&quot;: &quot;&lt;ul&gt;\\r\\n\\r\\n&lt;li&gt;Kreuzfahrt ab/bis Dubai auf der MSC Splendida&lt;/li&gt;\\r\\n&lt;li&gt;Unterkunft in der gebuchten Kabinenkategorie&lt;/li&gt;\\r\\n&lt;li&gt;Vollpension, d.h. Fr&#252;hst&#252;ck, Mittagessen, Nachmittagstee, Snacks, Abendessen&lt;/li&gt;\\r\\n&lt;li&gt;Vielf&#228;ltiges Sportangebot, inkl. Nutzung Fitnesscenter und Open-Air- Sportanlagen&lt;/li&gt;\\r\\n&lt;li&gt;Entertainment&lt;/li&gt;\\r\\n&lt;li&gt;Qualifizierte Kinderbetreuung&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n\\r\\n\\r\\n\\r\\n&quot;,\r\n\t\t&quot;title&quot;: &quot;Von Dubai &#252;ber Manama in 15 Tagen&quot;,\r\n\t\t&quot;nights&quot;: 14,\r\n\t\t&quot;company&quot;: &quot;MSC&quot;,\r\n\t\t&quot;zone&quot;: &quot;Emirate und Orient&quot;,\r\n\t\t&quot;schiffsbeschreibung&quot;: &quot;&lt;p&gt;&lt;strong&gt;Schiffsdaten&lt;/strong&gt;&lt;/p&gt;\\r\\n&lt;ul&gt;\\r\\n&lt;li&gt;Inbetriebnahme: 2009&lt;/li&gt;\\r\\n&lt;li&gt;L&#228;nge: 333 m&lt;/li&gt;\\r\\n&lt;li&gt;H&#246;he: 67 m&lt;/li&gt;\\r\\n&lt;li&gt;Breite: 38 m&lt;/li&gt;\\r\\n&lt;li&gt;Tiefgang: 8,45 m&lt;/li&gt;\\r\\n&lt;li&gt;Tonnage: 137.936 BRT&lt;/li&gt;\\r\\n&lt;li&gt;Geschwindigkeit: 23 Knoten&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Decks: 18&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Kabine: 1.637&lt;/li&gt;\\r\\n&lt;li&gt;Passagiere: 3.247&lt;/li&gt;\\r\\n&lt;li&gt;Besatzung: 1.370&lt;/li&gt;\\r\\n&lt;li&gt;Sprachen an Bord: Italienisch, Deutsch, Franz&#246;sisch, Englisch&lt;/li&gt;\\r\\n&lt;li&gt;Bordw&#228;hrung: US-Dollar, Euro&lt;/li&gt;\\r\\n&lt;li&gt;Internet an Bord: Es gibt ein Internetcaf&#233; und in allen Kabinen kann eine Internetverbindung gegen einen Geb&#252;hr dazu gebucht werden.&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n&quot;,\r\n\t\t&quot;sails_nid&quot;: 509662,\r\n\t\t&quot;arrival&quot;: 1552694400,\r\n\t\t&quot;departure&quot;: 1551484800,\r\n\t\t&quot;cabinname&quot;: &quot;Deluxe Suite (Kat. YC1): &quot;,\r\n\t\t&quot;cabintype&quot;: &quot;Suite&quot;,\r\n\t\t&quot;cabinnid&quot;: 232855,\r\n\t\t&quot;catalogPrice&quot;: 0,\r\n\t\t&quot;discountPrice&quot;: 0,\r\n\t\t&quot;discountPercentage&quot;: 0,\r\n\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;nid&quot;: 509660,\r\n\t\t&quot;includesservices&quot;: &quot;&lt;ul&gt;\\r\\n\\r\\n&lt;li&gt;Kreuzfahrt ab/bis Dubai auf der MSC Splendida&lt;/li&gt;\\r\\n&lt;li&gt;Unterkunft in der gebuchten Kabinenkategorie&lt;/li&gt;\\r\\n&lt;li&gt;Vollpension, d.h. Fr&#252;hst&#252;ck, Mittagessen, Nachmittagstee, Snacks, Abendessen&lt;/li&gt;\\r\\n&lt;li&gt;Vielf&#228;ltiges Sportangebot, inkl. Nutzung Fitnesscenter und Open-Air- Sportanlagen&lt;/li&gt;\\r\\n&lt;li&gt;Entertainment&lt;/li&gt;\\r\\n&lt;li&gt;Qualifizierte Kinderbetreuung&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n\\r\\n\\r\\n\\r\\n&quot;,\r\n\t\t&quot;title&quot;: &quot;Von Dubai &#252;ber Manama in 15 Tagen&quot;,\r\n\t\t&quot;nights&quot;: 14,\r\n\t\t&quot;company&quot;: &quot;MSC&quot;,\r\n\t\t&quot;zone&quot;: &quot;Emirate und Orient&quot;,\r\n\t\t&quot;schiffsbeschreibung&quot;: &quot;&lt;p&gt;&lt;strong&gt;Schiffsdaten&lt;/strong&gt;&lt;/p&gt;\\r\\n&lt;ul&gt;\\r\\n&lt;li&gt;Inbetriebnahme: 2009&lt;/li&gt;\\r\\n&lt;li&gt;L&#228;nge: 333 m&lt;/li&gt;\\r\\n&lt;li&gt;H&#246;he: 67 m&lt;/li&gt;\\r\\n&lt;li&gt;Breite: 38 m&lt;/li&gt;\\r\\n&lt;li&gt;Tiefgang: 8,45 m&lt;/li&gt;\\r\\n&lt;li&gt;Tonnage: 137.936 BRT&lt;/li&gt;\\r\\n&lt;li&gt;Geschwindigkeit: 23 Knoten&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Decks: 18&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Kabine: 1.637&lt;/li&gt;\\r\\n&lt;li&gt;Passagiere: 3.247&lt;/li&gt;\\r\\n&lt;li&gt;Besatzung: 1.370&lt;/li&gt;\\r\\n&lt;li&gt;Sprachen an Bord: Italienisch, Deutsch, Franz&#246;sisch, Englisch&lt;/li&gt;\\r\\n&lt;li&gt;Bordw&#228;hrung: US-Dollar, Euro&lt;/li&gt;\\r\\n&lt;li&gt;Internet an Bord: Es gibt ein Internetcaf&#233; und in allen Kabinen kann eine Internetverbindung gegen einen Geb&#252;hr dazu gebucht werden.&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n&quot;,\r\n\t\t&quot;sails_nid&quot;: 509662,\r\n\t\t&quot;arrival&quot;: 1552694400,\r\n\t\t&quot;departure&quot;: 1551484800,\r\n\t\t&quot;cabinname&quot;: &quot;Executive &amp; Family Suite (Kat. YC2): &quot;,\r\n\t\t&quot;cabintype&quot;: &quot;Suite&quot;,\r\n\t\t&quot;cabinnid&quot;: 232856,\r\n\t\t&quot;catalogPrice&quot;: 0,\r\n\t\t&quot;discountPrice&quot;: 0,\r\n\t\t&quot;discountPercentage&quot;: 0,\r\n\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;nid&quot;: 509660,\r\n\t\t&quot;includesservices&quot;: &quot;&lt;ul&gt;\\r\\n\\r\\n&lt;li&gt;Kreuzfahrt ab/bis Dubai auf der MSC Splendida&lt;/li&gt;\\r\\n&lt;li&gt;Unterkunft in der gebuchten Kabinenkategorie&lt;/li&gt;\\r\\n&lt;li&gt;Vollpension, d.h. Fr&#252;hst&#252;ck, Mittagessen, Nachmittagstee, Snacks, Abendessen&lt;/li&gt;\\r\\n&lt;li&gt;Vielf&#228;ltiges Sportangebot, inkl. Nutzung Fitnesscenter und Open-Air- Sportanlagen&lt;/li&gt;\\r\\n&lt;li&gt;Entertainment&lt;/li&gt;\\r\\n&lt;li&gt;Qualifizierte Kinderbetreuung&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n\\r\\n\\r\\n\\r\\n&quot;,\r\n\t\t&quot;title&quot;: &quot;Von Dubai &#252;ber Manama in 15 Tagen&quot;,\r\n\t\t&quot;nights&quot;: 14,\r\n\t\t&quot;company&quot;: &quot;MSC&quot;,\r\n\t\t&quot;zone&quot;: &quot;Emirate und Orient&quot;,\r\n\t\t&quot;schiffsbeschreibung&quot;: &quot;&lt;p&gt;&lt;strong&gt;Schiffsdaten&lt;/strong&gt;&lt;/p&gt;\\r\\n&lt;ul&gt;\\r\\n&lt;li&gt;Inbetriebnahme: 2009&lt;/li&gt;\\r\\n&lt;li&gt;L&#228;nge: 333 m&lt;/li&gt;\\r\\n&lt;li&gt;H&#246;he: 67 m&lt;/li&gt;\\r\\n&lt;li&gt;Breite: 38 m&lt;/li&gt;\\r\\n&lt;li&gt;Tiefgang: 8,45 m&lt;/li&gt;\\r\\n&lt;li&gt;Tonnage: 137.936 BRT&lt;/li&gt;\\r\\n&lt;li&gt;Geschwindigkeit: 23 Knoten&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Decks: 18&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Kabine: 1.637&lt;/li&gt;\\r\\n&lt;li&gt;Passagiere: 3.247&lt;/li&gt;\\r\\n&lt;li&gt;Besatzung: 1.370&lt;/li&gt;\\r\\n&lt;li&gt;Sprachen an Bord: Italienisch, Deutsch, Franz&#246;sisch, Englisch&lt;/li&gt;\\r\\n&lt;li&gt;Bordw&#228;hrung: US-Dollar, Euro&lt;/li&gt;\\r\\n&lt;li&gt;Internet an Bord: Es gibt ein Internetcaf&#233; und in allen Kabinen kann eine Internetverbindung gegen einen Geb&#252;hr dazu gebucht werden.&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n&quot;,\r\n\t\t&quot;sails_nid&quot;: 509662,\r\n\t\t&quot;arrival&quot;: 1552694400,\r\n\t\t&quot;departure&quot;: 1551484800,\r\n\t\t&quot;cabinname&quot;: &quot;Royal Suite (Kat. YC3): &quot;,\r\n\t\t&quot;cabintype&quot;: &quot;Suite&quot;,\r\n\t\t&quot;cabinnid&quot;: 232857,\r\n\t\t&quot;catalogPrice&quot;: 0,\r\n\t\t&quot;discountPrice&quot;: 0,\r\n\t\t&quot;discountPercentage&quot;: 0,\r\n\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;nid&quot;: 509660,\r\n\t\t&quot;includesservices&quot;: &quot;&lt;ul&gt;\\r\\n\\r\\n&lt;li&gt;Kreuzfahrt ab/bis Dubai auf der MSC Splendida&lt;/li&gt;\\r\\n&lt;li&gt;Unterkunft in der gebuchten Kabinenkategorie&lt;/li&gt;\\r\\n&lt;li&gt;Vollpension, d.h. Fr&#252;hst&#252;ck, Mittagessen, Nachmittagstee, Snacks, Abendessen&lt;/li&gt;\\r\\n&lt;li&gt;Vielf&#228;ltiges Sportangebot, inkl. Nutzung Fitnesscenter und Open-Air- Sportanlagen&lt;/li&gt;\\r\\n&lt;li&gt;Entertainment&lt;/li&gt;\\r\\n&lt;li&gt;Qualifizierte Kinderbetreuung&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n\\r\\n\\r\\n\\r\\n&quot;,\r\n\t\t&quot;title&quot;: &quot;Von Dubai &#252;ber Manama in 15 Tagen&quot;,\r\n\t\t&quot;nights&quot;: 14,\r\n\t\t&quot;company&quot;: &quot;MSC&quot;,\r\n\t\t&quot;zone&quot;: &quot;Emirate und Orient&quot;,\r\n\t\t&quot;schiffsbeschreibung&quot;: &quot;&lt;p&gt;&lt;strong&gt;Schiffsdaten&lt;/strong&gt;&lt;/p&gt;\\r\\n&lt;ul&gt;\\r\\n&lt;li&gt;Inbetriebnahme: 2009&lt;/li&gt;\\r\\n&lt;li&gt;L&#228;nge: 333 m&lt;/li&gt;\\r\\n&lt;li&gt;H&#246;he: 67 m&lt;/li&gt;\\r\\n&lt;li&gt;Breite: 38 m&lt;/li&gt;\\r\\n&lt;li&gt;Tiefgang: 8,45 m&lt;/li&gt;\\r\\n&lt;li&gt;Tonnage: 137.936 BRT&lt;/li&gt;\\r\\n&lt;li&gt;Geschwindigkeit: 23 Knoten&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Decks: 18&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Kabine: 1.637&lt;/li&gt;\\r\\n&lt;li&gt;Passagiere: 3.247&lt;/li&gt;\\r\\n&lt;li&gt;Besatzung: 1.370&lt;/li&gt;\\r\\n&lt;li&gt;Sprachen an Bord: Italienisch, Deutsch, Franz&#246;sisch, Englisch&lt;/li&gt;\\r\\n&lt;li&gt;Bordw&#228;hrung: US-Dollar, Euro&lt;/li&gt;\\r\\n&lt;li&gt;Internet an Bord: Es gibt ein Internetcaf&#233; und in allen Kabinen kann eine Internetverbindung gegen einen Geb&#252;hr dazu gebucht werden.&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n&quot;,\r\n\t\t&quot;sails_nid&quot;: 509662,\r\n\t\t&quot;arrival&quot;: 1552694400,\r\n\t\t&quot;departure&quot;: 1551484800,\r\n\t\t&quot;cabinname&quot;: &quot;Deluxe Suite Kat. YH1&quot;,\r\n\t\t&quot;cabintype&quot;: &quot;Suite&quot;,\r\n\t\t&quot;cabinnid&quot;: 243945,\r\n\t\t&quot;catalogPrice&quot;: 0,\r\n\t\t&quot;discountPrice&quot;: 0,\r\n\t\t&quot;discountPercentage&quot;: 0,\r\n\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;nid&quot;: 509660,\r\n\t\t&quot;includesservices&quot;: &quot;&lt;ul&gt;\\r\\n\\r\\n&lt;li&gt;Kreuzfahrt ab/bis Dubai auf der MSC Splendida&lt;/li&gt;\\r\\n&lt;li&gt;Unterkunft in der gebuchten Kabinenkategorie&lt;/li&gt;\\r\\n&lt;li&gt;Vollpension, d.h. Fr&#252;hst&#252;ck, Mittagessen, Nachmittagstee, Snacks, Abendessen&lt;/li&gt;\\r\\n&lt;li&gt;Vielf&#228;ltiges Sportangebot, inkl. Nutzung Fitnesscenter und Open-Air- Sportanlagen&lt;/li&gt;\\r\\n&lt;li&gt;Entertainment&lt;/li&gt;\\r\\n&lt;li&gt;Qualifizierte Kinderbetreuung&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n\\r\\n\\r\\n\\r\\n&quot;,\r\n\t\t&quot;title&quot;: &quot;Von Dubai &#252;ber Manama in 15 Tagen&quot;,\r\n\t\t&quot;nights&quot;: 14,\r\n\t\t&quot;company&quot;: &quot;MSC&quot;,\r\n\t\t&quot;zone&quot;: &quot;Emirate und Orient&quot;,\r\n\t\t&quot;schiffsbeschreibung&quot;: &quot;&lt;p&gt;&lt;strong&gt;Schiffsdaten&lt;/strong&gt;&lt;/p&gt;\\r\\n&lt;ul&gt;\\r\\n&lt;li&gt;Inbetriebnahme: 2009&lt;/li&gt;\\r\\n&lt;li&gt;L&#228;nge: 333 m&lt;/li&gt;\\r\\n&lt;li&gt;H&#246;he: 67 m&lt;/li&gt;\\r\\n&lt;li&gt;Breite: 38 m&lt;/li&gt;\\r\\n&lt;li&gt;Tiefgang: 8,45 m&lt;/li&gt;\\r\\n&lt;li&gt;Tonnage: 137.936 BRT&lt;/li&gt;\\r\\n&lt;li&gt;Geschwindigkeit: 23 Knoten&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Decks: 18&lt;/li&gt;\\r\\n&lt;li&gt;Anzahl der Kabine: 1.637&lt;/li&gt;\\r\\n&lt;li&gt;Passagiere: 3.247&lt;/li&gt;\\r\\n&lt;li&gt;Besatzung: 1.370&lt;/li&gt;\\r\\n&lt;li&gt;Sprachen an Bord: Italienisch, Deutsch, Franz&#246;sisch, Englisch&lt;/li&gt;\\r\\n&lt;li&gt;Bordw&#228;hrung: US-Dollar, Euro&lt;/li&gt;\\r\\n&lt;li&gt;Internet an Bord: Es gibt ein Internetcaf&#233; und in allen Kabinen kann eine Internetverbindung gegen einen Geb&#252;hr dazu gebucht werden.&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n&quot;,\r\n\t\t&quot;sails_nid&quot;: 509662,\r\n\t\t&quot;arrival&quot;: 1552694400,\r\n\t\t&quot;departure&quot;: 1551484800,\r\n\t\t&quot;cabinname&quot;: &quot;Innenkabine Wellness (Kat. IW): &quot;,\r\n\t\t&quot;cabintype&quot;: &quot;Innenkabine&quot;,\r\n\t\t&quot;cabinnid&quot;: 360681,\r\n\t\t&quot;catalogPrice&quot;: 0,\r\n\t\t&quot;discountPrice&quot;: 0,\r\n\t\t&quot;discountPercentage&quot;: 0,\r\n\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t}\r\n]\r\n\r\nThat works fine. I  use a second command to manipulate the Arrival/departue object:\r\n\r\n    C:\\import\\Dreamlines\\jq.exe &quot;.[].arrival |= todateiso8601 | .[].departure |= todateiso8601&quot; C:\\import\\Dreamlines\\import_sails.json | out-file -filepath C:\\import\\Dreamlines\\date_sails.json -encoding Unicode\r\n\r\nOn the new system i got following error: JQ: Invalid numeric literal at line 1, column 3. First i thought the api changed some data but on the old system works that fine. I checked the json and the validor says that this is a valid json.\r\n\r\nTips?\r\n\r\nRegards\r\nTimo\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49817756/jq-invalid-numeric-literal-at-line-1-column-3",
        "title": "JQ: Invalid numeric literal at line 1, column 3"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1523807246,
                "creation_date": 1523807246,
                "answer_id": 49843812,
                "question_id": 49843350,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The way you’ve formulated the question makes it sound as though it’s some kind of homework or assignment, so let’s assume you really are looking for help rather than an explicit answer. \r\n\r\nFirst, it would make sense to learn about asking questions on stackoverflow.com; for that, the mcve page would be a good starting point. In your case, the points of clarification that would be helpful are whether the input is an object, and whether the relevant keys all occur within the top-most level object(s).\r\n\r\nSecond, in reading through the jq documentation, pay particular attention to the `to_entries`, `from-entries`, and `with_entries` filters.\r\n\r\nThird, if you require a completely generic solution, search the web using these search terms:\r\n\r\n    (stackoverflow OR faq) jq def walk\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "jq command to replace specific words in json file"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1523807246,
        "creation_date": 1523804424,
        "question_id": 49843350,
        "body_markdown": "Good evening all,\r\nI am looking for a solution to replace specific words in a json file using jq command. The field I want to be changed is called &quot;Stock&quot; and if the value is &quot;Add to cart&quot; or just &quot;add&quot; I want this replaced with &quot;In stock&quot;.\r\n\r\nWould you guys mind to help me since I have zero knowledge in jq but I need to use it for my project?\r\n\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/49843350/jq-command-to-replace-specific-words-in-json-file",
        "title": "jq command to replace specific words in json file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523865142,
                "post_id": 49849884,
                "comment_id": 86718740,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3066828,
                    "reputation": 375,
                    "user_id": 2598329,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7b835567de683cac00fe22da80cf4ba6?s=256&d=identicon&r=PG",
                    "display_name": "akutz",
                    "link": "https://stackoverflow.com/users/2598329/akutz"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523889004,
                "post_id": 49849884,
                "comment_id": 86734520,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1523858357,
                "last_edit_date": 1523858357,
                "creation_date": 1523856034,
                "answer_id": 49850070,
                "question_id": 49849884,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Basically, use map function over the email list.\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    data = {\r\n      &quot;login&quot;: &quot;username&quot;,\r\n      &quot;emails&quot;: [\r\n        &quot;email_1@example.com&quot;,\r\n        &quot;email_2@example.com&quot;\r\n      ]\r\n    }\r\n\r\n    result = data.emails.map((x)=&gt; ({&quot;login&quot;: data.login, &quot;email&quot;: x}));\r\n    console.log(result);\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\nMy misunderstanding, for the `jq` version look at the answer of @RomanPerekhrest\r\n\r\n",
                "title": "How do I use jq to map {a:b,c:[0,1]} to [{c:c[0],a:b},{c:c[1],a:b}]?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1523857672,
                "creation_date": 1523857672,
                "answer_id": 49850339,
                "question_id": 49849884,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** approach:\r\n\r\n    jq &#39;.login as $uname | .emails | map({email: ., login: $uname})&#39; input.json\r\n\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;email&quot;: &quot;email_1@example.com&quot;,\r\n        &quot;login&quot;: &quot;username&quot;\r\n      },\r\n      {\r\n        &quot;email&quot;: &quot;email_2@example.com&quot;,\r\n        &quot;login&quot;: &quot;username&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "How do I use jq to map {a:b,c:[0,1]} to [{c:c[0],a:b},{c:c[1],a:b}]?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1523862082,
                "creation_date": 1523862082,
                "answer_id": 49851289,
                "question_id": 49849884,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A jq-esque (look, no variables!) solution:\r\n\r\n    [{login} + {email: .emails[]}]\r\n\r\nOr even more succinctly:\r\n\r\n    [{login, email: .emails[]}]\r\n\r\n(Maybe you could get away without the outer-square-brackets?)",
                "title": "How do I use jq to map {a:b,c:[0,1]} to [{c:c[0],a:b},{c:c[1],a:b}]?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1523863693,
        "creation_date": 1523854723,
        "last_edit_date": 1523863693,
        "question_id": 49849884,
        "body_markdown": "I am trying to trying to transform\r\n\r\n    {\r\n      &quot;login&quot;: &quot;username&quot;,\r\n      &quot;emails&quot;: [\r\n        &quot;email_1@example.com&quot;,\r\n        &quot;email_2@example.com&quot;\r\n      ]\r\n    }\r\n\r\ninto\r\n\r\n    [\r\n      {\r\n        &quot;email&quot;: &quot;email_1@example.com&quot;,\r\n        &quot;login&quot;: &quot;username&quot;\r\n      },\r\n      {\r\n        &quot;email&quot;: &quot;email_2@example.com&quot;,\r\n        &quot;login&quot;: &quot;username&quot;\r\n      }\r\n    ]\r\n\r\nHowever, for the life of me I am unable to figure out how. I&#39;ve looked into jq&#39;s map and reduce functionality, but I must be getting the syntax incorrect.\r\n\r\nI would appreciate any help y&#39;all might provide. Thanks!\r\n\r\n**EDIT**\r\n\r\nThanks to everyone that responded. As you may have guessed, this was the core problem for a larger transformation. I&#39;m actually working on around 752 separate JSON files in a directory, each with a similar object. I wanted to transform them all into a single array of logins and e-mails. Thanks to @peak&#39;s answer, I managed to create the following:\r\n\r\n    jq -s &#39;.[] | {login, email: .emails[]?}&#39; *.json | jq -s &#39;map(select(true))&#39;\r\n\r\nPlease note that I changed `.emails[]` to `.emails[]?` to account for the very real possibility that some values for `.emails` are `null`.",
        "link": "https://stackoverflow.com/questions/49849884/how-do-i-use-jq-to-map-ab-c0-1-to-cc0-ab-cc1-ab",
        "title": "How do I use jq to map {a:b,c:[0,1]} to [{c:c[0],a:b},{c:c[1],a:b}]?"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "amazon-lightsail"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1523861538,
                "last_edit_date": 1523861538,
                "creation_date": 1523860758,
                "answer_id": 49850976,
                "question_id": 49850316,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The basic query for making the selection you describe would be:\r\n\r\n    .instanceSnapshots | map(select(.name|startswith(&quot;autosnap&quot;)))\r\n\r\n(If you didn&#39;t need to preserve the array structure, you could go with:\r\n\r\n    .instanceSnapshots[] | select(.name|startswith(&quot;autosnap&quot;))\r\n\r\n)\r\n\r\nYou could then perform additional filtering by extending the pipeline.\r\n\r\nIf you were to use `test/1`, the appropriate invocation would be `test(&quot;^autosnap&quot;)` or perhaps `test(&quot;^autosnap-&quot;)`. \r\n\r\n## Example\r\n\r\n    .instanceSnapshots\r\n    | map(select(.name|startswith(&quot;autosnap&quot;)))\r\n    | map(select(.fromInstanceName == &quot;WordPress-Test-Instance&quot;))\r\n    | sort_by(.createdAt)\r\n    | .[].name\r\n\r\nThe two successive `select`s could of course be compacted into one.  For efficiency, the sorting should be done as late as possible.\r\n\r\n## Postscript\r\nAlthough you might indeed be able to get away with commencing the pipeline with `.[]` instead of `.instanceSnapshots`, the latter is advisable in case the JSON schema changes.  In a sense, the whole point of data formats like JSON is to make it easy to write queries that are robust with respect to (sane) [schema-evolution][1].\r\n\r\n\r\n  [1]: https://en.wikipedia.org/wiki/Schema_evolution",
                "title": "Using jq to parse json output of AWS CLI tools with Lightsail"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1523861538,
        "creation_date": 1523857549,
        "question_id": 49850316,
        "body_markdown": "I&#39;m trying to modify a script to automate lightsail snapshots, and I am having trouble modifying the jq query. \r\n\r\nI&#39;m trying to parse the output of `aws lightsail get-instance-snapshots`\r\n\r\nThis is the original line from the script:\r\n\r\n    aws lightsail get-instance-snapshots | jq &#39;.[] | sort_by(.createdAt) | select(.[0].fromInstanceName == &quot;WordPress-Test-Instance&quot;) | .[].name&#39;\r\n\r\nwhich returns a list of snapshot names with one per line.\r\n\r\nI need to modify the query so that is does not return all snapshots, but rather only ones where the name start with &#39;autosnap&#39;. i&#39;m doing this as the script rotates snapshots, but I don&#39;t want it to delete snapshots I manually create (which will not start with &#39;autosnap&#39;).\r\n\r\nHere is a redacted sample output from `aws lightsail get-instance-snapshots`\r\n\r\n    {\r\n        &quot;instanceSnapshots&quot;: [\r\n            {\r\n                &quot;location&quot;: {\r\n                    &quot;availabilityZone&quot;: &quot;all&quot;,\r\n                    &quot;regionName&quot;: &quot;*****&quot;\r\n                },\r\n                &quot;arn&quot;: &quot;*****&quot;,\r\n                &quot;fromBlueprintId&quot;: &quot;wordpress_4_9_2_1&quot;,\r\n                &quot;name&quot;: &quot;autosnap-WordPress-Test-Instance-2018-04-16_01.46&quot;,\r\n                &quot;fromInstanceName&quot;: &quot;WordPress-Test-Instance&quot;,\r\n                &quot;fromBundleId&quot;: &quot;nano_1_2&quot;,\r\n                &quot;supportCode&quot;: &quot;*****&quot;,\r\n                &quot;sizeInGb&quot;: 20,\r\n                &quot;createdAt&quot;: 1523843190.117,\r\n                &quot;fromAttachedDisks&quot;: [],\r\n                &quot;fromInstanceArn&quot;: &quot;*****&quot;,\r\n                &quot;resourceType&quot;: &quot;InstanceSnapshot&quot;,\r\n                &quot;state&quot;: &quot;available&quot;\r\n            },\r\n            {\r\n                &quot;location&quot;: {\r\n                    &quot;availabilityZone&quot;: &quot;all&quot;,\r\n                    &quot;regionName&quot;: &quot;*****&quot;\r\n                },\r\n                &quot;arn&quot;: &quot;*****&quot;,\r\n                &quot;fromBlueprintId&quot;: &quot;wordpress_4_9_2_1&quot;,\r\n                &quot;name&quot;: &quot;Premanent-WordPress-Test-Instance-2018-04-16_01.40&quot;,\r\n                &quot;fromInstanceName&quot;: &quot;WordPress-Test-Instance&quot;,\r\n                &quot;fromBundleId&quot;: &quot;nano_1_2&quot;,\r\n                &quot;supportCode&quot;: &quot;*****&quot;,\r\n                &quot;sizeInGb&quot;: 20,\r\n                &quot;createdAt&quot;: 1523842851.69,\r\n                &quot;fromAttachedDisks&quot;: [],\r\n                &quot;fromInstanceArn&quot;: &quot;*****&quot;,\r\n                &quot;resourceType&quot;: &quot;InstanceSnapshot&quot;,\r\n                &quot;state&quot;: &quot;available&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\n\r\nI would have thought something like this would work, but I&#39;m not having any luck after many attempts...\r\n\r\n    aws lightsail get-instance-snapshots | jq &#39;.[] | sort_by(.createdAt) | select(.[0].fromInstanceName == &quot;WordPress-Test-Instance&quot;) | select(.[0].name | test(&quot;autosnap&quot;)) |.[].name&#39;\r\n\r\nAny help would be greatly appreciated!",
        "link": "https://stackoverflow.com/questions/49850316/using-jq-to-parse-json-output-of-aws-cli-tools-with-lightsail",
        "title": "Using jq to parse json output of AWS CLI tools with Lightsail"
    },
    {
        "tags": [
            "node.js",
            "command-prompt",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3274563,
                    "reputation": 6820,
                    "user_id": 2757035,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/b70cbba438368bb424ba5c02eb2711a9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "underscore_d",
                    "link": "https://stackoverflow.com/users/2757035/underscore-d"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1523871233,
                "post_id": 49853966,
                "comment_id": 86722381,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1523881387,
                "post_id": 49853966,
                "comment_id": 86728877,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 171717,
                    "reputation": 72609,
                    "user_id": 399317,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/28235d26ee007743c9d2150759d29139?s=256&d=identicon&r=PG",
                    "display_name": "Kos",
                    "link": "https://stackoverflow.com/users/399317/kos"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524059931,
                "post_id": 49853966,
                "comment_id": 86818658,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1524059715,
                "last_edit_date": 1524059715,
                "creation_date": 1523871933,
                "answer_id": 49854244,
                "question_id": 49853966,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There are numerous ways to install jq on a Windows machine, without using chocolatey. Start with the binaries available via https://stedolan.github.io/jq/download/\r\n\r\nAlternatively, you can use the ConvertFrom-Json command to convert any JSON text into a PowerShell object.",
                "title": "Alternative for jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1524059715,
        "creation_date": 1523871109,
        "last_edit_date": 1523879798,
        "question_id": 49853966,
        "body_markdown": "I am running a script which requires the `jq` command. It looks something like this:- \r\n\r\n&lt;!-- language: lang-none --&gt;\r\n\r\n    devHubSfdxAuthUrl=$(sfdx force:org:display --verbose -u $DEV_HUB_USERNAME --json | **jq** -r .result.sfdxAuthUrl)\r\n\r\nJQ is not installed in my PC. Actually I am working in a system in my office, having restricted access.\r\n\r\nI searched for the possible solution to install JQ. I concluded that I need to install Chocolatey first, in order o install and use JQ. As my office network restricts the access to the link to download chocolatey, I need any alternative solution, that I could use in place of JQ.\r\n\r\nThank you",
        "link": "https://stackoverflow.com/questions/49853966/alternative-for-jq",
        "title": "Alternative for jq"
    },
    {
        "tags": [
            "yaml",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1524031368,
                "last_edit_date": 1524031368,
                "creation_date": 1523911795,
                "answer_id": 49866005,
                "question_id": 49863906,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One way to solve the problem (as I understand it) with minimal changes to your jq query is using an &quot;indexof&quot; function, e.g.:\r\n\r\n    # Returns the least integer index corresponding to \r\n    # the first element in the input array or object\r\n    # at which f is truthy, else null\r\n    def indexof(f):\r\n      label $out\r\n      | foreach .[] as $x (null;\r\n           .+1;\r\n           if ($x|f) then (.-1, break $out) else empty end) \r\n        // null;\r\n\r\n\r\nYour query can then be recast as follows:\r\n\r\n    if .kind == &quot;Deployment&quot; \r\n    then (.metadata.name,.spec.template.metadata.labels.app) |=\r\n             &quot;ORG-&quot; + &quot;DEV-&quot; +  sub(&quot;-\\\\$appEnv&quot;;&quot;&quot;)\r\n          | (.spec.template.spec.containers[].env | indexof(.name == &quot;MYROLE&quot;)) as $ix\r\n          | if $ix \r\n            then .spec.template.spec.containers[].env[$ix].value |= &quot;ORG-&quot; + &quot;DEV-&quot; + .\r\n            else empty\r\n            end \r\n    elif .kind == &quot;Service&quot;\r\n    then (.metadata.name,.metadata.labels.name,.spec.selector.app) |=\r\n      &quot;ORG-&quot; + &quot;DEV-&quot; +  sub(&quot;-\\\\$appEnv&quot;;&quot;&quot;) \r\n    else .\r\n    end\r\n\r\nOf course this is still not robust because of the use of `containers[]`.\r\n\r\n## Generic solution\r\n\r\nThe following assumes that all &quot;MYROLE&quot; components are to be modified:\r\n\r\n    if .kind == &quot;Deployment&quot; \r\n    then (.metadata.name,.spec.template.metadata.labels.app) |=\r\n            (&quot;ORG-&quot; + &quot;DEV-&quot; +  sub(&quot;-\\\\$appEnv&quot;;&quot;&quot;))\r\n          | .spec.template.spec as $spec\r\n          | reduce range(0; $spec.containers | length) as $c (.;\r\n    \t      reduce range(0; $spec.containers[$c].env|length) as $ix (.;\r\n    \t        if $spec.containers[$c].env[$ix].name == &quot;MYROLE&quot;\r\n    \t        then .spec.template.spec.containers[$c].env[$ix].value |=\r\n    \t          &quot;ORG-&quot; + &quot;DEV-&quot; + .\r\n                else .\r\n                end))\r\n    elif .kind == &quot;Service&quot; \r\n    then (.metadata.name,.metadata.labels.name,.spec.selector.app) |=\r\n           &quot;ORG-&quot; + &quot;DEV-&quot; +  sub(&quot;-\\\\$appEnv&quot;;&quot;&quot;) \r\n    else .\r\n    end\r\n\r\n## &quot;Floating&quot; solution\r\n\r\nIn this section, we&#39;ll focus on the goal of updating \r\n`.containers[$i].env[$j].value` \r\nif `.containers[$i].env[$j].name` is a specified value, no matter where this relative path occurs.\r\n\r\n    # paths for which: **.containers.*.env.*.name == $value\r\n    def relevantPaths($value):\r\n      . as $in\r\n      | paths \r\n      | select(.[-1] == &quot;name&quot; and .[-3] == &quot;env&quot; and .[-5] == &quot;containers&quot;) as $p\r\n      | select($in|getpath($p) == $value) ;\r\n      \r\n    reduce (relevantPaths(&quot;MYROLE&quot;) | ((.[-1] = &quot;value&quot;))) as $p (.;\r\n      setpath($p; &quot;ORG-DEV-&quot; + getpath($p)) )\r\n\r\n",
                "title": "How to update value of a yaml key value pair using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1524031368,
        "creation_date": 1523902977,
        "last_edit_date": 1523904143,
        "question_id": 49863906,
        "body_markdown": "I would updating a few keys in a kubernetes yaml file using yq / jq. The files contains multiple yaml documents for kubernetes deployments and services. I have managed to update the values of some keys. But I am stuck on updating the key value pairs in an array (env). I have it working when I hard code the array index. But this makes it brittle. Is there a correct way to look up the environment name and update it&#39;s value with a prefix.\r\n\r\n\r\n    apiVersion: extensions/v1beta1\r\n    kind: Deployment\r\n    metadata:\r\n      name: zxl-portalsvc-deployment-$appEnv\r\n    spec:\r\n      replicas: 1 \r\n      template: \r\n        metadata:\r\n          labels:\r\n            app: zxl-portalsvc-$appEnv\r\n        spec:\r\n          containers:\r\n          - name: zxl-portalsvc\r\n            image:  artifactory.oss.oxcart.com:5000/frontface-zxl-mca:5.6.4_17\r\n            imagePullPolicy: Always\r\n            resources:\r\n              limits:\r\n                cpu: &quot;2&quot;\r\n                memory: 4096Mi\r\n              requests:\r\n                cpu: &quot;1&quot;\r\n                memory: 2048Mi\r\n            env:\r\n            - name: MYROLE\r\n              value: &quot;zxl-portalsvc-service-$appEnv.frontface.svc.cluster.local&quot;\r\n            - name: MYAPPS\r\n              value: &quot;contentservices.war portalserver.war c1-integration.war&quot;\r\n            - name: tomcat_Xmx\r\n              value: &quot;3276m&quot;\r\n            ports:\r\n            - containerPort: 8080\r\n            volumeMounts:\r\n              - name: frontface-configs\r\n                mountPath: /usr/local/tomcat/frontface/config\r\n              - name: sso-configs\r\n                mountPath: /usr/local/tomcat/frontface/sso-config/idp_metadata.xml\r\n                subPath: idp_metadata.xml\r\n              - name: sso-configs\r\n                mountPath: /usr/local/tomcat/frontface/sso-config/zxlKeystore.jks\r\n                subPath: zxlKeystore.jks\r\n              - name: tomcat-configs\r\n                mountPath: /usr/local/tomcat/conf/context.xml\r\n                subPath: context.xml\r\n              - name: tomcat-configs\r\n                mountPath: /usr/local/tomcat/conf/logging.properties\r\n                subPath: logging.properties\r\n              - name: tomcat-configs\r\n                mountPath: /usr/local/tomcat/conf/server.xml\r\n                subPath: server.xml\r\n              - name: tomcat-configs\r\n                mountPath: /usr/local/tomcat/conf/tomcat-users.xml\r\n                subPath: tomcat-users.xml\r\n              - name: tomcat-configs\r\n                mountPath: /usr/local/tomcat/conf/web.xml\r\n                subPath: web.xml\r\n              - name: tomcat-configs\r\n                mountPath: /usr/local/tomcat/bin/setenv.sh\r\n                subPath: setenv.sh\r\n\r\n          - name: zxl-nginxsvc\r\n            image: artifactory.oss.oxcart.com:5000/oxcart-httpauth:1.3.0\r\n            resources:\r\n              limits:\r\n                cpu: 250m\r\n                memory: 200Mi\r\n              requests:\r\n                cpu: 200m\r\n                memory: 100Mi\r\n            env:\r\n            - name: proxyDst\r\n              value: &quot;localhost&quot;\r\n            ports:\r\n            - containerPort: 80\r\n            volumeMounts:\r\n              - name: nginx-configs\r\n                mountPath: /etc/nginx/conf.d/nginx.htpasswd\r\n                subPath: nginx.htpasswd\r\n              - name: nginx-configs\r\n                mountPath: /etc/nginx/conf.d/default.conf\r\n                subPath: default.conf\r\n\r\n          volumes:\r\n          - name: frontface-configs\r\n            configMap:\r\n              name: frontface-config-$appEnv\r\n          - name: sso-configs\r\n            secret:\r\n              secretName: sso-config-$appEnv\r\n          - name: tomcat-configs\r\n            configMap:\r\n              name: tomcat-config-$appEnv\r\n          - name: nginx-configs\r\n            configMap:\r\n              name: nginx-config-$appEnv\r\n\r\n    ---\r\n\r\n    apiVersion: v1\r\n    kind: Service\r\n    metadata:\r\n      labels:\r\n        name: zxl-portalsvc-service-$appEnv\r\n      name: zxl-portalsvc-service-$appEnv\r\n    spec:\r\n      ports:\r\n        - protocol: TCP\r\n          port: 8080\r\n      selector:\r\n        app: zxl-portalsvc-$appEnv\r\n\r\n\r\nI have it partially working except it is brittle. If the match is not the first element then it will break. Is there a way to fix resolve this. Maybe by identifying the array index of the match.\r\n\r\nHere is where I am at so far:\r\n\r\n\r\n    cat yq_test.yml | yq -y &#39;if .kind == &quot;Deployment&quot; \r\n        then (.metadata.name,.spec.template.metadata.labels.app) |= &quot;ORG-&quot; + &quot;DEV-&quot; +  sub(&quot;-\\\\$appEnv&quot;;&quot;&quot;) | \r\n            if .spec.template.spec.containers[].env[].name == &quot;MYROLE&quot; then \r\n                .spec.template.spec.containers[].env[0].value  = &quot;ORG-&quot; + &quot;DEV-&quot; + .spec.template.spec.containers[].env[0].value \r\n            else empty end \r\n    elif .kind == &quot;Service&quot; then \r\n        (.metadata.name,.metadata.labels.name,.spec.selector.app) |= &quot;ORG-&quot; + &quot;DEV-&quot; +  sub(&quot;-\\\\$appEnv&quot;;&quot;&quot;) \r\n    else . end&#39;",
        "link": "https://stackoverflow.com/questions/49863906/how-to-update-value-of-a-yaml-key-value-pair-using-jq",
        "title": "How to update value of a yaml key value pair using jq"
    },
    {
        "tags": [
            "json",
            "powershell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 134563,
                    "reputation": 1238,
                    "user_id": 336783,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bfb7fca078ed0ec16d8b1d496d669696?s=256&d=identicon&r=PG",
                    "display_name": "Sam Martin",
                    "link": "https://stackoverflow.com/users/336783/sam-martin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524055616,
                "post_id": 49894470,
                "comment_id": 86815562,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1524059617,
                "creation_date": 1524059617,
                "answer_id": 49901539,
                "question_id": 49894470,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could use the ConvertFrom-Json command to convert any piece of JSON directly into a PowerShell object.",
                "title": "JQ under windows: Direct JSON Input"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1524124834,
                "last_edit_date": 1524124834,
                "creation_date": 1524063178,
                "answer_id": 49902887,
                "question_id": 49894470,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Sorry if the question is confusing. I found a way to work with variables directly on the commandline, e.g:\r\n\r\n    $variable | C:\\jq.exe [Filter]\r\n\r\nThere was no Explanation in the JQ Manual how to pass json text directly on the commandshell to jq. But i found it. Thanks for your help.\r\n\r\nRegards\r\nTimo\r\n",
                "title": "JQ under windows: Direct JSON Input"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1524124834,
        "creation_date": 1524039059,
        "last_edit_date": 1524055400,
        "question_id": 49894470,
        "body_markdown": "I  use a powershell script to get JSON Information from a webinterdace. Actually i store the JSON Information from there into a file before i use JQ 1.5 (under Windows 10) to transform the json into a format that i can upload into a database. But since i use jq in the same powershell enviroment, i think i can avoid that redirection and work directly with the json text (with a variable or with the json text direct in the jq command). I checked the Manual but found no clear answer on that question (for me). I found in the Manual the --argjson command that Looks like that i need. But the Manual is not clear how i define the variable under Windows/powershell.\r\n\r\nRegards\r\nTimo",
        "link": "https://stackoverflow.com/questions/49894470/jq-under-windows-direct-json-input",
        "title": "JQ under windows: Direct JSON Input"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "loops",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524140110,
                "post_id": 49920852,
                "comment_id": 86857225,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524140959,
                "post_id": 49920852,
                "comment_id": 86857769,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524141104,
                "post_id": 49920852,
                "comment_id": 86857869,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524145542,
                "post_id": 49920852,
                "comment_id": 86860998,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1524236495,
                "last_edit_date": 1524236495,
                "creation_date": 1524140328,
                "answer_id": 49920964,
                "question_id": 49920852,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "### Immediate Issue - Invalid Input\r\n\r\nThe &quot;invalid character&quot; at hand here is almost certainly a carriage return. Use `dos2unix` to convert your input file to a proper UNIX text file, and your original code will work (albeit very inefficiently, rereading your whole `big.json` every time it wants to extract a single property).\r\n\r\n### Performant Implementation - Loop In JQ, Not Bash\r\n\r\nDon&#39;t use a bash loop for this at all -- it&#39;s much more efficient to have `jq` do the looping.\r\n\r\nNote the `sub(&quot;\\r$&quot;; &quot;&quot;)` used in this code to remove trailing carriage returns so it can accept input in DOS format.\r\n\r\n    jq -rR --argfile infile big.json &#39;\r\n    sub(&quot;\\r$&quot;; &quot;&quot;) as $keyname\r\n    | ($keyname | split(&quot;.&quot;)) as $pieces\r\n    | (reduce $pieces[] as $piece ($infile; .[$piece]?)) as $value\r\n    | ($keyname, ($value | tojson))\r\n    &#39; &lt;big.properties.service\r\n\r\nproperly emits as output, when given the inputs in the question:\r\n\r\n    cfg.keyload.backend.app.shutdown.timeout\r\n    &quot;5s&quot;\r\n    cfg.keyload.backend.app.jmx.enable\r\n    true\r\n    cfg.keyload.backend.app.jmx.nonexistent\r\n    null\r\n    cfg.nonexistent\r\n    null",
                "title": "Looping over a list of keys to extract from a JSON file with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1524338910,
                "creation_date": 1524338910,
                "answer_id": 49959473,
                "question_id": 49920852,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your properties file is effectively paths in the json that you want to retrieve values from. Convert them to paths that `jq` recognizes so you can get those values. Just make an array of keys that would need to be traversed.  Be sure to read your properties file as raw input (`-R`) since it&#39;s not json, and use raw output (`-r`) to be able to output the paths as you want.\r\n\r\n    $ jq --argfile big big.json &#39;\r\n        ., (split(&quot;.&quot;) as $p | $big | getpath($p) | tojson)\r\n    &#39; -Rr big.properties.service\r\n    cfg.keyload.backend.app.shutdown.timeout\r\n    &quot;5s&quot;\r\n    cfg.keyload.backend.app.jmx.enable\r\n    true\r\n    cfg.keyload.backend.app.jmx.nonexistent\r\n    null\r\n    cfg.nonexistent\r\n    null\r\n\r\n",
                "title": "Looping over a list of keys to extract from a JSON file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1524338910,
        "creation_date": 1524140011,
        "last_edit_date": 1524236773,
        "question_id": 49920852,
        "body_markdown": "I&#39;m trying to extract a series of properties (named in an input file) in jq and getting error when I feed those from bash via a loop:\r\n\r\n    while read line; do echo $line; cat big.json | jq &quot;.$line&quot;; sleep 1; done &lt; big.properties.service\r\n\r\n    cfg.keyload.service.count\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\n\r\n\r\nWhen i try to do it manually it works\r\n\r\n    $ line=cfg.keyload.service.count\r\n    $ echo $line\r\n    cfg.keyload.service.count\r\n    $ cat big.json | jq &quot;.$line&quot;\r\n    1\r\n\r\nIs there any way to get it work in loop? \r\n\r\n\r\nHere is example\r\n\r\n\r\n    cat &gt;big.json &lt;&lt;EOF\r\n    {\r\n      &quot;cfg&quot;: {\r\n        &quot;keyload&quot;: {\r\n          &quot;backend&quot;: {\r\n        &quot;app&quot;: {\r\n          &quot;shutdown&quot;: {\r\n            &quot;timeout&quot;: &quot;5s&quot;\r\n                      },\r\n          &quot;jmx&quot;: {\r\n            &quot;enable&quot;: true\r\n                        }\r\n               }\r\n           }\r\n         }\r\n    }\r\n    }\r\n    EOF\r\n\r\n    cat &gt;big.properties.service &lt;&lt;EOF\r\n    cfg.keyload.backend.app.shutdown.timeout\r\n    cfg.keyload.backend.app.jmx.enable\r\n    cfg.keyload.backend.app.jmx.nonexistent\r\n    cfg.nonexistent\r\n    EOF\r\n\r\n...output should be:\r\n\r\n    cfg.keyload.backend.app.shutdown.timeout\r\n    &quot;5s&quot;\r\n    cfg.keyload.backend.app.jmx.enable\r\n    true\r\n    cfg.keyload.backend.app.jmx.nonexistent\r\n    null\r\n    cfg.nonexistent\r\n    null\r\n",
        "link": "https://stackoverflow.com/questions/49920852/looping-over-a-list-of-keys-to-extract-from-a-json-file-with-jq",
        "title": "Looping over a list of keys to extract from a JSON file with jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "newline",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1524173988,
                "post_id": 49930626,
                "comment_id": 86877223,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524174111,
                "post_id": 49930626,
                "comment_id": 86877267,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1524190309,
        "creation_date": 1524173915,
        "last_edit_date": 1524190309,
        "question_id": 49930626,
        "body_markdown": "Is there a way to have `jq` substitute the characters `&#39;\\n&#39;` for an actual newline in command output? \r\n\r\nFor example, I have the following JSON:\r\n\r\n    {\r\n        &quot;stderr&quot;: &quot;Traceback (most recent call last):\\n  File \\&quot;download.py\\&quot;, line 157, in &lt;module&gt;\\n    cli()\\n  File \\&quot;/var/task/click/core.py\\&quot;, line 722, in __call__\\n    return self.main(*args, **kwargs)\\n  File \\&quot;/var/task/click/core.py\\&quot;, line 697, in main\\n    rv = self.invoke(ctx)\\n  File \\&quot;/var/task/click/core.py\\&quot;, line 895, in invoke\\n    return ctx.invoke(self.callback, **ctx.params)\\n  File \\&quot;/var/task/click/core.py\\&quot;, line 535, in invoke\\n    return callback(*args, **kwargs)\\n  File \\&quot;download.py\\&quot;, line 77, in cli\\n    pool.map(lambda f: f.download(log_level=inspector_log_level), files_to_download)\\n  File \\&quot;/var/lang/lib/python3.6/multiprocessing/pool.py\\&quot;, line 260, in map\\n    return self._map_async(func, iterable, mapstar, chunksize).get()\\n  File \\&quot;/var/lang/lib/python3.6/multiprocessing/pool.py\\&quot;, line 608, in get\\n    raise self._value\\n  File \\&quot;/var/lang/lib/python3.6/multiprocessing/pool.py\\&quot;, line 119, in worker\\n    result = (True, func(*args, **kwds))\\n  File \\&quot;/var/lang/lib/python3.6/multiprocessing/pool.py\\&quot;, line 44, in mapstar\\n    return list(map(*args))\\n  File \\&quot;download.py\\&quot;, line 77, in &lt;lambda&gt;\\n    pool.map(lambda f: f.download(log_level=inspector_log_level), files_to_download)\\n  File \\&quot;/var/task/src/keepout.py\\&quot;, line 63, in download\\n    self.tempfile = mgr.download_url(self.url_or_path, suffix=file_extension)\\n  File \\&quot;/var/task/src/download.py\\&quot;, line 24, in download_url\\n    shutil.copyfileobj(fsrc, fdst, length=16 * 1024)\\n  File \\&quot;/var/lang/lib/python3.6/shutil.py\\&quot;, line 82, in copyfileobj\\n    fdst.write(buf)\\n  File \\&quot;/var/lang/lib/python3.6/tempfile.py\\&quot;, line 483, in func_wrapper\\n    return func(*args, **kwargs)\\nOSError: [Errno 28] No space left on device\\n&quot;\r\n    }\r\n\r\n\r\nI&#39;d love if I could pipe it through `jq` and see the value of the field formatted with actual newlines, like\r\n\r\n    {\r\n        &quot;stderr&quot;: &quot;Traceback (most recent call last):\r\n      File \\&quot;download.py\\&quot;, line 157, in &lt;module&gt;\r\n        cli()\r\n      File \\&quot;/var/task/click/core.py\\&quot;, line 722, in __call__\r\n        return self.main(*args, **kwargs)\r\n      File \\&quot;/var/task/click/core.py\\&quot;, line 697, in main\r\n        rv = self.invoke(ctx)\r\n      File \\&quot;/var/task/click/core.py\\&quot;, line 895, in invoke\r\n        return ctx.invoke(self.callback, **ctx.params)\r\n      File \\&quot;/var/task/click/core.py\\&quot;, line 535, in invoke\r\n        return callback(*args, **kwargs)\r\n      File \\&quot;download.py\\&quot;, line 77, in cli\r\n        pool.map(lambda f: f.download(log_level=inspector_log_level), files_to_download)\r\n      File \\&quot;/var/lang/lib/python3.6/multiprocessing/pool.py\\&quot;, line 260, in map\r\n        return self._map_async(func, iterable, mapstar, chunksize).get()\r\n      File \\&quot;/var/lang/lib/python3.6/multiprocessing/pool.py\\&quot;, line 608, in get\r\n        raise self._value\r\n      File \\&quot;/var/lang/lib/python3.6/multiprocessing/pool.py\\&quot;, line 119, in worker\r\n        result = (True, func(*args, **kwds))\r\n      File \\&quot;/var/lang/lib/python3.6/multiprocessing/pool.py\\&quot;, line 44, in mapstar\r\n        return list(map(*args))\r\n      File \\&quot;download.py\\&quot;, line 77, in &lt;lambda&gt;\r\n        pool.map(lambda f: f.download(log_level=inspector_log_level), files_to_download)\r\n      File \\&quot;/var/task/src/keepout.py\\&quot;, line 63, in download\r\n        self.tempfile = mgr.download_url(self.url_or_path, suffix=file_extension)\r\n      File \\&quot;/var/task/src/download.py\\&quot;, line 24, in download_url\r\n        shutil.copyfileobj(fsrc, fdst, length=16 * 1024)\r\n      File \\&quot;/var/lang/lib/python3.6/shutil.py\\&quot;, line 82, in copyfileobj\r\n        fdst.write(buf)\r\n      File \\&quot;/var/lang/lib/python3.6/tempfile.py\\&quot;, line 483, in func_wrapper\r\n        return func(*args, **kwargs)\r\n    OSError: [Errno 28] No space left on device\r\n    &quot;\r\n    }\r\n\r\nIs there a way to do this? \r\n \r\n",
        "link": "https://stackoverflow.com/questions/49930626/how-to-substitute-n-for-newline-with-jq",
        "title": "How to substitute &#39;\\n&#39; for newline with jq"
    },
    {
        "tags": [
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1524175242,
                "creation_date": 1524175242,
                "answer_id": 49930871,
                "question_id": 49930733,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "you can use this \r\n\r\n    jq &#39;.properties[&quot;jira-key&quot;]&#39; test.json\r\n\r\notherwise jq parses dash as a subtraction",
                "title": "jq parse issue with array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1524190228,
        "creation_date": 1524174490,
        "last_edit_date": 1524190228,
        "question_id": 49930733,
        "body_markdown": "I&#39;m using jq to parse the value but not getting expected results, can anyone please suggest me \r\ncontents are \r\n\r\n    {\r\n      &quot;id&quot;: &quot;8a9o0laf3ff0&quot;,\r\n      &quot;displayId&quot;: &quot;8a0a&quot;,\r\n      &quot;author&quot;: {\r\n        &quot;name&quot;: &quot;Rahul&quot;,\r\n        &quot;emailAddress&quot;: &quot;donotreply@mail.com&quot;\r\n      },\r\n      &quot;authorTimestamp&quot;: 1524168139000,\r\n      &quot;message&quot;: &quot;SD-90&quot;,\r\n      &quot;parents&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;8c1679f0813c&quot;,\r\n          &quot;displayId&quot;: &quot;8c0f&quot;,\r\n          &quot;author&quot;: {\r\n            &quot;name&quot;: &quot;Sahotay&quot;,\r\n            &quot;emailAddress&quot;: &quot;donotreply@mail.com&quot;\r\n          },\r\n          &quot;authorTimestamp&quot;: 1523544887000,\r\n          &quot;message&quot;: &quot;Fixing issues in SD-88&quot;,\r\n          &quot;parents&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;d022838cf4e6&quot;,\r\n              &quot;displayId&quot;: &quot;d0a3&quot;\r\n            }\r\n          ]\r\n        }\r\n      ],\r\n      &quot;properties&quot;: {\r\n        &quot;jira-key&quot;: [\r\n          &quot;SD-90&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\nI would like to grab value of `jira-key`\r\n\r\n    jq &#39;.properties&#39; myjason.json\r\n    {\r\n      &quot;jira-key&quot;: [\r\n        &quot;SD-90&quot;\r\n      ]\r\n    }\r\n\r\nbut if i&#39;m using `.jira-key[]` its not working \r\n",
        "link": "https://stackoverflow.com/questions/49930733/jq-parse-issue-with-array",
        "title": "jq parse issue with array"
    },
    {
        "tags": [
            "json",
            "date",
            "filter",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524212749,
                "post_id": 49936680,
                "comment_id": 86890046,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3760519,
                    "reputation": 89,
                    "user_id": 3966111,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ZFs6Q.jpg?s=256",
                    "display_name": "maqueiouseur",
                    "link": "https://stackoverflow.com/users/3966111/maqueiouseur"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524213319,
                "post_id": 49936680,
                "comment_id": 86890382,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1524215426,
                "last_edit_date": 1524215426,
                "creation_date": 1524214278,
                "answer_id": 49937726,
                "question_id": 49936680,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Requirements of the form &quot;at least one&quot; can usually be satisfied efficiently using `any/2`, e.g. \r\n\r\n    any(.roles[]; .role_name == &quot;HOUSE&quot;)\r\n\r\nThe check for the year can (apparently) be accomplished by:\r\n\r\n    .start | .[:4] | tonumber &gt;= 2017\r\n\r\n## Solution\r\nTo produce an array of objects satisfying the two conditions:\r\n\r\n    map(select(\r\n      any(.roles[]; .role_name == &quot;HOUSE&quot;) and\r\n      any(.roles[]; .start[:4] | tonumber &gt;= 2017) ))\r\n    \r\n`.start[:4]` is short for `.start|.[0:4]`\r\n    ",
                "title": "date/numeric filter with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1524215426,
        "creation_date": 1524210656,
        "last_edit_date": 1524213840,
        "question_id": 49936680,
        "body_markdown": "I have a json that looks like this (it&#39;s the result of simple jq filter):\r\n\r\n    [{\r\n\t\t&quot;name&quot;: &quot;Corrine&quot;,\r\n\t\t&quot;firstname&quot;: &quot;Odile&quot;,\r\n\t\t&quot;uid&quot;: &quot;PA2685&quot;,\r\n\t\t&quot;roles&quot;: [{\r\n\t\t\t\t&quot;role_name&quot;: &quot;GQ&quot;,\r\n\t\t\t\t&quot;start&quot;: &quot;2012-06-20&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;role_name&quot;: &quot;HOUSE&quot;,\r\n\t\t\t\t&quot;start&quot;: &quot;2012-06-26&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;role_name&quot;: &quot;HOUSE&quot;,\r\n\t\t\t\t&quot;start&quot;: &quot;2017-06-28&quot;\r\n\t\t\t}\r\n\t\t]\r\n\t},\r\n\t{\r\n\t\t&quot;name&quot;: &quot;Blanche&quot;,\r\n\t\t&quot;firstname&quot;: &quot;Matthieu&quot;,\r\n\t\t&quot;uid&quot;: &quot;PA2685&quot;,\r\n\t\t&quot;roles&quot;: [{\r\n\t\t\t\t&quot;role_name&quot;: &quot;SENATE&quot;,\r\n\t\t\t\t&quot;start&quot;: &quot;2014-06-20&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;role_name&quot;: &quot;SENATE&quot;,\r\n\t\t\t\t&quot;start&quot;: &quot;2012-06-26&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;role_name&quot;: &quot;SENATE&quot;,\r\n\t\t\t\t&quot;start&quot;: &quot;2012-06-28&quot;\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n    ]\r\n\r\nI would like to filter in two ways:\r\n\r\n- select only the first-level objects that have at least one ```role_name``` (inside the ```roles``` array) whose value is HOUSE; \r\n- and from this group select only the ones that have at least one ```start``` whose date is in 2017 or after.\r\n\r\nIn the json above &quot;Corrine Odile&quot; would be the only one selected.\r\n\r\nI tried some ```with_entries(select(.value``` expressions, but my I&#39;m confused about how to deal with the dates as well as the &quot;at least one&quot; requirement.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/49936680/date-numeric-filter-with-jq",
        "title": "date/numeric filter with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "translation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1524473417,
                "last_edit_date": 1524473417,
                "creation_date": 1524332361,
                "answer_id": 49958483,
                "question_id": 49958035,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "[EDIT: The following response was in answer to the question when it described (a) the mapping as shown below, and (b) the input data as having the form:\r\n\r\n    [\r\n      {\r\n        &quot;list&quot;: [\r\n          {\r\n            &quot;value&quot;: 1,\r\n            &quot;id1&quot;: 12\r\n          },\r\n          {\r\n            &quot;value&quot;: 15,\r\n            &quot;id2&quot;: 13\r\n          },\r\n          {\r\n            &quot;value&quot;: -4,\r\n            &quot;id3&quot;: 14\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nEND OF EDIT]\r\n\r\nIn the following I&#39;ll assume that the mapping is available via the following function, but that is an inessential assumption:\r\n\r\n    def mapping: {\r\n      &quot;id1&quot;: &quot;newId1&quot;,\r\n      &quot;id2&quot;: &quot;newId2&quot;,\r\n      &quot;id3&quot;: &quot;newId3&quot;\r\n    } ;\r\n\r\n\r\nThe following jq filter will then produce the desired output:\r\n\r\n    map( .list\r\n         |= (map( to_entries[]\r\n                  | (mapping[.key]) as $mapped\r\n                  | select($mapped)\r\n                  | {($mapped|tostring): .value} )\r\n             | add) )\r\n           \r\n\r\n",
                "title": "jq: translate array of objects to object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1524370655,
                "last_edit_date": 1524370655,
                "creation_date": 1524337563,
                "answer_id": 49959303,
                "question_id": 49958035,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There&#39;s plenty of ways to skin a cat. I&#39;d do it like this:\r\n\r\n    .[].list |= reduce .[] as $i ({};\r\n        ($i.id|tostring) as $k\r\n          | (select($mapping | has($k))[$mapping[$k]] = $i.value) // .\r\n    )\r\n\r\nYou would just provide the mapping through a separate file or argument.\r\n\r\n    $ cat program.jq\r\n    .[].list |= reduce .[] as $i ({};\r\n        ($i.id|tostring) as $k\r\n          | (select($mapping | has($k))[$mapping[$k]] = $i.value) // .\r\n    )\r\n\r\n    $ cat mapping.json\r\n    {\r\n      &quot;12&quot;: &quot;newId1&quot;,\r\n      &quot;13&quot;: &quot;newId2&quot;,\r\n      &quot;14&quot;: &quot;newId3&quot;\r\n    }\r\n\r\n    $ jq --argfile mapping mapping.json -f program.jq input.json\r\n    [\r\n      {\r\n        &quot;list&quot;: {\r\n          &quot;newId1&quot;: 1,\r\n          &quot;newId2&quot;: 15,\r\n          &quot;newId3&quot;: -4\r\n        }\r\n      }\r\n    ]\r\n\r\n",
                "title": "jq: translate array of objects to object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1524473312,
                "creation_date": 1524473312,
                "answer_id": 49976875,
                "question_id": 49958035,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a reduce-free solution to the revised problem. \r\n\r\nIn the following I&#39;ll assume that the mapping is available via the following function, but that is an inessential assumption:\r\n\r\n    def mapping:\r\n    {\r\n      &quot;12&quot;: &quot;newId1&quot;,\r\n      &quot;13&quot;: &quot;newId2&quot;,\r\n      &quot;14&quot;: &quot;newId3&quot;\r\n    } ;\r\n\r\n\r\n    map( .list\r\n         |= (map( mapping[.id|tostring] as $mapped\r\n                  | select($mapped)\r\n                  |  {($mapped): .value} )\r\n             | add) )\r\n\r\n\r\nThe &quot;select&quot; is for safety (i.e., it checks that the .id under consideration is indeed mapped).  It might also be appropriate to ensure that `$mapped` is a string by writing `{($mapped|tostring): .value}`.\r\n\r\n",
                "title": "jq: translate array of objects to object"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1525494877,
        "creation_date": 1524329230,
        "last_edit_date": 1525494877,
        "question_id": 49958035,
        "body_markdown": "I have a response from curl in a format like this:\r\n\r\n    [\r\n      {\r\n        &quot;list&quot;: [\r\n          {\r\n            &quot;value&quot;: 1,\r\n            &quot;id&quot;: 12\r\n          },\r\n          {\r\n            &quot;value&quot;: 15,\r\n            &quot;id&quot;: 13\r\n          },\r\n          {\r\n            &quot;value&quot;: -4,\r\n            &quot;id&quot;: 14\r\n          }\r\n        ]\r\n      },\r\n      ...\r\n    ]\r\n\r\nGiven a mapping between ids like this:\r\n\r\n    {\r\n      &quot;12&quot;: &quot;newId1&quot;,\r\n      &quot;13&quot;: &quot;newId2&quot;,\r\n      &quot;14&quot;: &quot;newId3&quot;\r\n    }\r\n\r\nI want to make this:\r\n\r\n    [\r\n      {\r\n        &quot;list&quot;: {\r\n          &quot;newId1&quot;: 1,\r\n          &quot;newId2&quot;: 15,\r\n          &quot;newId3&quot;: -4,\r\n        }\r\n      },\r\n      ...\r\n    ]\r\n\r\nSuch that I get a mapping from ids to values (and along the way I&#39;d like to remap the ids).\r\n\r\nI&#39;ve been working at this for a while and every time I get a deadend.\r\n\r\nNote: I can use Shell or the like to preform loops if necessary.\r\n\r\nedit: Here&#39;s one version what I&#39;ve developed so far:\r\n\r\n    jq &#39;[].list.id = ($mapping.[] | select(.id == key)) | del(.id)&#39; -M --argjson &quot;mapping&quot; &quot;$mapping&quot;\r\n\r\nI don&#39;t think it&#39;s the best one, but I&#39;m looking to see if I can find an old version that was closer to what I need.",
        "link": "https://stackoverflow.com/questions/49958035/jq-translate-array-of-objects-to-object",
        "title": "jq: translate array of objects to object"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1524348974,
                "creation_date": 1524348974,
                "answer_id": 49960662,
                "question_id": 49960144,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    to_entries\r\n    | map( {name: .key, age: .value.age} )\r\n",
                "title": "nested objects with arbitrary keys to key-value objects with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1524396344,
        "creation_date": 1524344199,
        "last_edit_date": 1524396344,
        "question_id": 49960144,
        "body_markdown": "There is an json object with n nested objects, where the key ist arbitrary and the nested objects have all the same structure. \r\n\r\nExample:\r\n\r\n    {\r\n      &quot;albert&quot;:{ \r\n           &quot;age&quot;: 35\r\n      }, \r\n      &quot;sarah&quot;:{ \r\n           &quot;age&quot;: 33\r\n      },\r\n      &quot;otto&quot;:{\r\n            &quot;age&quot;:27\r\n      }\r\n    }\r\n\r\n\r\nwith jq the output should  be an array and look like this:\r\n\r\n    [\r\n      {&quot;name&quot;:&quot;albert&quot;,&quot;age&quot;:35},\r\n      {&quot;name&quot;:&quot;sarah&quot;&quot;,&quot;age&quot;:32},\r\n      {&quot;name&quot;:&quot;otto&quot;,&quot;age&quot;:27},\r\n    ]\r\n\r\n\r\nCan somebody help me?\r\n\r\nThank you,\r\n",
        "link": "https://stackoverflow.com/questions/49960144/nested-objects-with-arbitrary-keys-to-key-value-objects-with-jq",
        "title": "nested objects with arbitrary keys to key-value objects with jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1524423427,
                "post_id": 49967054,
                "comment_id": 86955121,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1524408592,
                "creation_date": 1524408592,
                "answer_id": 49967223,
                "question_id": 49967054,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The output can be formatted as csv by using the `--raw-output` option:\r\n\r\n    jq --raw-output &#39;&quot;\\&quot;\\(.code)\\&quot;, \\&quot;\\(.msg)\\&quot;&quot;&#39;",
                "title": "How to convert the simplest JSON to CSV or Text using jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1524417920,
                "creation_date": 1524417920,
                "answer_id": 49968742,
                "question_id": 49967054,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You might like to consider a generic solution:\r\n\r\n    jq -r &#39;[.[]] | @csv&#39;",
                "title": "How to convert the simplest JSON to CSV or Text using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1524417920,
        "creation_date": 1524407523,
        "question_id": 49967054,
        "body_markdown": "My json like this from the command like `curl https://sm.ms/api/upload`:\r\n\r\n    {\r\n      &quot;code&quot;: &quot;error&quot;,\r\n      &quot;msg&quot;: &quot;No files were uploaded.&quot;\r\n    }\r\n\r\n**Now I want to get a text like this** (all values of this json):\r\n\r\n    &quot;error&quot;, &quot;No files were uploaded.&quot;\r\n\r\nI use the command `curl https://sm.ms/api/upload | jq -r .` but I can only get the json content. The document seems like not to support this funtion.\r\n\r\n\r\nI search for the web for a long time but there&#39;s nothing helpful, so I hope you can help me and thank you~",
        "link": "https://stackoverflow.com/questions/49967054/how-to-convert-the-simplest-json-to-csv-or-text-using-jq",
        "title": "How to convert the simplest JSON to CSV or Text using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1524449751,
                "creation_date": 1524449751,
                "answer_id": 49972531,
                "question_id": 49972375,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using your approach:\r\n\r\n    mp_keys=&quot;a,b,c,d&quot;\r\n\r\n    echo &#39;{&quot;a&quot;:1, &quot;b&quot;:2, &quot;c&quot;:3, &quot;d&quot;: 4}&#39; |\r\n      jq -r --arg mpk &quot;$mp_keys&quot; &#39;\r\n        ($mpk|split(&quot;,&quot;)) as $mpkeys\r\n        | [ .[ $mpkeys[] ] ]\r\n        | @csv &#39;\r\n\r\nwould yield:\r\n\r\n    1,2,3,4\r\n\r\n\r\n\r\n",
                "title": "jq - filter using list of object identifier-index stored in a variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1524623012,
        "creation_date": 1524447936,
        "last_edit_date": 1524623012,
        "question_id": 49972375,
        "body_markdown": "I&#39;m writing a reusable Bash script that allows me to query an API to get data about parliamentary members and store it in csv format. \r\n\r\nThe json response of the API has a lot of keys (name, gender, birthdate, commission membership, vote...), and, depending on what I&#39;d like to do, I do not always want to capture the same keys. So I would like to abstract this part of the code in order to be able to write:\r\n\r\n    mp_keys= a,b,c,d\r\n\r\n    curl https://mp.com | jq &#39;. | [$mp_keys] | @csv&#39;\r\n\r\nso that it is interpreted by jq as    \r\n\r\n    jq &#39;. | [.a, .b, .c, .d] | @ csv&#39; \r\n\r\nI don&#39;t have a set structure for the variable format, so it could be: \r\n\r\n* ``mp_keys=&quot;a,b,c,d&quot;`` or\r\n* ``mp_keys=&quot;.a, .b, .c, .d&quot;`` or \r\n* ``mp_key1=a, mp_key2=b, mp_key3=c, mp_key4=d``\r\n\r\nI know that in jq I can use the following structure:\r\n\r\n    jq --arg mp_key1 &quot;${mp_key1}&quot; --arg mp_key2 &quot;${mp_key2}&quot; --arg mp_key3 &quot;${mp_key3}&quot; --arg mp_key4 &quot;${mp_key4}&quot; &#39;. \r\n    | [.[$mp_key1], .[$mp_key2], .[$mp_key3], .[$mp_key4]] \r\n    | @csv&#39;\r\n\r\nBut it obviously becomes tedious very quickly. \r\n\r\nLastly I could also build the jq command as a string then apply ``eval`` to it but I would prefer using a proper jq solution.\r\n\r\nEdit\r\n----\r\n\r\n \r\nI will break down @peak&#39;s answer for future reference, as it&#39;s very useful to understand what&#39;s happening. His answer is reproduced below:\r\n\r\n    mp_keys=&quot;a,b,c,d&quot;\r\n\r\n    echo &#39;{&quot;a&quot;:1, &quot;b&quot;:2, &quot;c&quot;:3, &quot;d&quot;: 4}&#39; |\r\n    jq -r --arg mpk &quot;$mp_keys&quot; &#39;\r\n    ($mpk|split(&quot;,&quot;)) as $mpkeys\r\n    | [ .[ $mpkeys[] ] ]\r\n    | @csv &#39;\r\n\r\nFirst, it&#39;s important to understand that jq will:\r\n\r\n1. evaluate the value of ``$mpkeys`` first, which implies doing the ``split(&quot;,&quot;)`` on ``$mpk``\r\n2. then pass the json sent through ``echo``.\r\n\r\nSo we can do the same to understand what&#39;s happening. The ``( )`` tells jq to process this section in priority, so we can start by replacing the parenthesis with its results. \r\n\r\n1. the string ``&quot;a,b,c,d&quot;``, stored in ``$mpk``, is split and stored into the array ``[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;]`` as described in the [section on ``split(str)``of jq&#39;s manual][1].\r\n2. The array is subsequently stored into ``$mpkeys`` through ``as``.\r\n\r\nWhich means that an equivalent of the initial code can be written as:\r\n\r\n    echo &#39;{&quot;a&quot;:1, &quot;b&quot;:2, &quot;c&quot;:3, &quot;d&quot;: 4}&#39; |\r\n    jq -r --arg mpk &quot;$mp_keys&quot; &#39;\r\n    [&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d] as $mpkeys\r\n    | [ .[ $mpkeys[] ] ]\r\n    | @csv &#39;\r\n\r\nOf course now the --arg is useless, as ``$mpk`` was there to hold our initial string. So we can simplify further with:\r\n\r\n    echo &#39;{&quot;a&quot;:1, &quot;b&quot;:2, &quot;c&quot;:3, &quot;d&quot;: 4}&#39; |\r\n    jq -r &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d] as $mpkeys\r\n    | [ .[ $mpkeys[] ] ]\r\n    | @csv &#39;\r\n\r\nLet&#39;s now break down ``[ .[ $mpkeys[] ] ]``:\r\n\r\n* because ``$mpkeys`` is an array, ``$mpkeys[]`` stands for the individual elements of the array, equivalent to ``&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;``. Instead of a single element (an array), we now have 4 elements (strings), which will be transformed individually by the filters around them (the brackets)\r\n* ``$mpkeys[]`` is then wrapped into ``.[]`` which applies to each of the 4 elements, and is consequently equivalent to ``.[&quot;a&quot;]``, ``.[&quot;b&quot;]``, ``.[&quot;c&quot;]``, ``.[&quot;d&quot;]``. Each of those elements is a generic object index, which are equivalent to the object-identifier index form (``.a, .b, .c, .d``) as [described in jq&#39;s manual][2].\r\n* the final outer ``[ ]`` simply wraps everything inside an array, which is necessary to pass the result to ``@csv``. \r\n\r\nSo the equivalent to the code above is:\r\n\r\n    echo &#39;{&quot;a&quot;:1, &quot;b&quot;:2, &quot;c&quot;:3, &quot;d&quot;: 4}&#39; |\r\n    jq -r &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d] as $mpkeys\r\n    | [ .[&quot;a&quot;], .[&quot;b&quot;], .[&quot;c&quot;], .[&quot;d&quot;] ]\r\n    | @csv &#39;\r\n\r\nHere ``$mpkeys`` serves no purpose, so we actually have:\r\n\r\n     echo &#39;{&quot;a&quot;:1, &quot;b&quot;:2, &quot;c&quot;:3, &quot;d&quot;: 4}&#39; |\r\n    jq -r &#39; [ .[&quot;a&quot;], .[&quot;b&quot;], .[&quot;c&quot;], .[&quot;d&quot;] ]\r\n    | @csv &#39;\r\n\r\nThere we are.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions\r\n  [2]: https://stedolan.github.io/jq/manual/#Basicfilters",
        "link": "https://stackoverflow.com/questions/49972375/jq-filter-using-list-of-object-identifier-index-stored-in-a-variable",
        "title": "jq - filter using list of object identifier-index stored in a variable"
    },
    {
        "tags": [
            "python",
            "json",
            "spotify",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4342327,
                    "reputation": 149742,
                    "user_id": 3545273,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/RDWxl.png?s=256",
                    "display_name": "Serge Ballesta",
                    "link": "https://stackoverflow.com/users/3545273/serge-ballesta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524473930,
                "post_id": 49976488,
                "comment_id": 86970139,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 25548,
                    "reputation": 5470,
                    "user_id": 65706,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://www.gravatar.com/avatar/6e0652a12b8a5b2577f91f0e192ea3f9?s=256&d=identicon&r=PG",
                    "display_name": "Yordan Georgiev",
                    "link": "https://stackoverflow.com/users/65706/yordan-georgiev"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594721360,
                "post_id": 49976488,
                "comment_id": 111217956,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1524472069,
                "creation_date": 1524472069,
                "answer_id": 49976543,
                "question_id": 49976488,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As the exception message states, you are trying to call a module.\r\n\r\nYou have probably used `import jq` instead of `from jq import jq`.\r\n\r\n",
                "title": "Filtering JSON from API through jq in Python"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1524472069,
        "creation_date": 1524471882,
        "question_id": 49976488,
        "body_markdown": "I&#39;m trying to filter out the field &quot;name&quot; to store in a file. I&#39;m filtering like so: \r\n\r\n    r =requests.get(&#39;https://api.spotify.com/v1/albums/70yMNdgyIj9SrQXFmdJKx9&#39;, \r\n    headers=headers)\r\n\r\n    print(jq(&quot;.[name]&quot;).transform(json.loads(r)))\r\n\r\nI get the error:     print(jq(&quot;.[name]&quot;).transform(text=r))\r\nTypeError: &#39;module&#39; object is not callable\r\n\r\nAny help on the matter? The documentation for jq python bindings is not very clear to me https://pypi.org/project/jq/\r\n",
        "link": "https://stackoverflow.com/questions/49976488/filtering-json-from-api-through-jq-in-python",
        "title": "Filtering JSON from API through jq in Python"
    },
    {
        "tags": [
            "bash",
            "shell",
            "perl",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5913981,
                    "reputation": 67084,
                    "user_id": 4653379,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/249722473de5a118b8acc86dc3729a20?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "zdim",
                    "link": "https://stackoverflow.com/users/4653379/zdim"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524552867,
                "post_id": 49995039,
                "comment_id": 87006607,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2207538,
                    "reputation": 5166,
                    "user_id": 1950349,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/5b390c1bb809c1c2f89b554fcfa64822?s=256&d=identicon&r=PG",
                    "display_name": "user1950349",
                    "link": "https://stackoverflow.com/users/1950349/user1950349"
                },
                "reply_to_user": {
                    "account_id": 5913981,
                    "reputation": 67084,
                    "user_id": 4653379,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/249722473de5a118b8acc86dc3729a20?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "zdim",
                    "link": "https://stackoverflow.com/users/4653379/zdim"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524552975,
                "post_id": 49995039,
                "comment_id": 87006659,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5913981,
                    "reputation": 67084,
                    "user_id": 4653379,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/249722473de5a118b8acc86dc3729a20?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "zdim",
                    "link": "https://stackoverflow.com/users/4653379/zdim"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1524553034,
                "post_id": 49995039,
                "comment_id": 87006700,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1524553037,
                "post_id": 49995039,
                "comment_id": 87006704,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2207538,
                    "reputation": 5166,
                    "user_id": 1950349,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/5b390c1bb809c1c2f89b554fcfa64822?s=256&d=identicon&r=PG",
                    "display_name": "user1950349",
                    "link": "https://stackoverflow.com/users/1950349/user1950349"
                },
                "reply_to_user": {
                    "account_id": 5913981,
                    "reputation": 67084,
                    "user_id": 4653379,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/249722473de5a118b8acc86dc3729a20?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "zdim",
                    "link": "https://stackoverflow.com/users/4653379/zdim"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524553117,
                "post_id": 49995039,
                "comment_id": 87006759,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2207538,
                    "reputation": 5166,
                    "user_id": 1950349,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/5b390c1bb809c1c2f89b554fcfa64822?s=256&d=identicon&r=PG",
                    "display_name": "user1950349",
                    "link": "https://stackoverflow.com/users/1950349/user1950349"
                },
                "reply_to_user": {
                    "account_id": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1524553197,
                "post_id": 49995039,
                "comment_id": 87006800,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1524557288,
                "last_edit_date": 1524557288,
                "creation_date": 1524554913,
                "answer_id": 49995756,
                "question_id": 49995039,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use following script in `bash` with the help of `jq`:\r\n\r\n    #!/usr/bin/env bash\r\n    \r\n    # convert both files to valid JSON data\r\n    sed -E &#39;s/([[:alnum:]_]+)=/&quot;\\1&quot;:/g&#39; primary.txt &gt; _pri.txt\r\n    sed -E &#39;s/([[:alnum:]_]+)=/&quot;\\1&quot;:/g&#39; secondary.txt &gt; _sec.txt\r\n    \r\n    # loop through keys from primary and extract values from both files\r\n    while read k; do\r\n       printf &#39;{&quot;text&quot;:&quot;for client id %s.&quot;,&quot;pri&quot;:%s,&quot;sec&quot;:%s}\\n&#39; &quot;${k//\\&quot;/}&quot; \\\r\n          &quot;$(jq -c &quot;.$k&quot; _pri.txt | sed &#39;s/,/&amp; /g&#39;)&quot; \\\r\n          &quot;$(jq -c &quot;.$k&quot; _sec.txt | sed &#39;s/,/&amp; /g&#39;)&quot;\r\n    done &lt; &lt;(jq &#39;keys[]&#39; _pri.txt)\r\n\r\n    # cleanup\r\n    rm -f _pri.txt _sec.txt\r\n&lt;p/&gt;\r\n\r\n    {&quot;text&quot;:&quot;for client id 1.&quot;,&quot;pri&quot;:[0, 273, 546, 819],&quot;sec&quot;:[342, 1102, 608, 684]}\r\n    {&quot;text&quot;:&quot;for client id 2.&quot;,&quot;pri&quot;:[274, 1, 820],&quot;sec&quot;:[115, 191, 837, 1559]}\r\n    {&quot;text&quot;:&quot;for client id 3.&quot;,&quot;pri&quot;:[1016, 275, 821],&quot;sec&quot;:[1256, 116]}",
                "title": "Extract primary and secondary numbers for each ID and make a JSON string"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1536903596,
                "last_edit_date": 1536903596,
                "creation_date": 1524555046,
                "answer_id": 49995801,
                "question_id": 49995039,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With Perl.  Data is extracted using regex, into a hash clientid =&gt; string with numbers.  Then the value is overwritten by an arrayref obtained by splitting that string. Then the two such hashes are combined into a hashref, that is converted into JSON using [JSON::XS](http://search.cpan.org/~mlehmann/JSON-XS-3.02/XS.pm)\r\n\r\n\r\n    use warnings;\r\n    use strict;\r\n    use feature &#39;say&#39;;\r\n    \r\n    use JSON::XS;\r\n    \r\n    my ($f1, $f2) = (&#39;primary.txt&#39;, &#39;secondary.txt&#39;);\r\n    \r\n    open my $fh, &#39;&lt;&#39;, $f1 or die &quot;Can&#39;t open $f1: $!&quot;;\r\n    my %h1 = &lt;$fh&gt; =~ /(\\d+)=\\[(.*?)\\]/g;\r\n    $h1{$_} = [ split /,\\s*/, $h1{$_} ]  for keys %h1; \r\n    \r\n    open $fh, &#39;&lt;&#39;, $f2 or die &quot;Can&#39;t open $f2: $!&quot;;\r\n    my %h2 = &lt;$fh&gt; =~ /(\\d+)=\\[(.*?)\\]/g;\r\n    $h2{$_} = [ split /,\\s*/, $h2{$_} ]  for keys %h2; \r\n    close $fh;\r\n    \r\n    my %client_id = ( 1 =&gt; &#39;one&#39;, 2 =&gt; &#39;two&#39;, 3 =&gt; &#39;three&#39; );\r\n  \r\n    for (keys %client_id) {\r\n        my $for_json = {\r\n            &quot;text&quot; =&gt; &quot;for client id $client_id{$_}.&quot;,\r\n            &quot;pri&quot; =&gt; $h1{$_},\r\n            &quot;sec&quot; =&gt; $h2{$_},\r\n        };\r\n        my $coder = JSON::XS-&gt;new;\r\n        my $json = $coder-&gt;encode($for_json);\r\n        say $json;\r\n    }\r\n\r\n---\r\n\r\nIf processing of both is indeed always the same put it in a subroutine\r\n\r\n    my ($f1, $f2) = (&#39;primary.txt&#39;, &#39;secondary.txt&#39;);\r\n        \r\n    my %h1 = %{ clientID_nums($f1) };\r\n    my %h2 = %{ clientID_nums($f2) };\r\n    \r\n    ...\r\n\r\n    sub clientID_nums {\r\n        my ($file) = @_; \r\n        \r\n        open my $fh, &#39;&lt;&#39;, $file or die &quot;Can&#39;t open $file: $!&quot;;\r\n        my %h = &lt;$fh&gt; =~ /(\\d+)=\\[(.*?)\\]/g;\r\n        $h{$_} = [ split /,\\s*/, $h{$_} ]  for keys %h; \r\n    \r\n        return \\%h;\r\n    }\r\n\r\nTo literally just generate (and print) the JSON string\r\n\r\n    say JSON::XS-&gt;new-&gt;encode($for_json);\r\n\r\nor, rather, using the module&#39;s functional interface\r\n\r\n    say encode_json $for_json;\r\n\r\nwhere `encode_json` is exported by default (and expects and emits UTF-8).",
                "title": "Extract primary and secondary numbers for each ID and make a JSON string"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -3,
                "last_activity_date": 1524572373,
                "last_edit_date": 1524572373,
                "creation_date": 1524556209,
                "answer_id": 49996163,
                "question_id": 49995039,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "\r\n\r\n\r\n\r\n    #!/usr/bin/perl\r\n    use strict;\r\n    use warnings;\r\n    use JSON;\r\n    \r\n    my %hash;\r\n    \r\n    foreach (&#39;primary.txt&#39;, &#39;secondary.txt&#39;) {\r\n    open FILE, &#39;&lt;&#39;, $_ or die &quot;Could not read file $_ because $!\\n&quot;;\r\n    local $/ = undef;\r\n    $hash{$_} = decode_json &lt;FILE&gt;;\r\n    close FILE\r\n    }\r\n    \r\n    foreach (sort keys %{ $hash{&#39;secondary.txt&#39;}}) {\r\n    next unless\r\n        (exists $hash{&#39;primary.txt&#39;}-&gt;{$_}) &amp;&amp;\r\n        (&#39;ARRAY&#39; eq ref $hash{&#39;primary.txt&#39;}-&gt;{$_});\r\n    \t\t\r\n    print &quot;{\\&quot;text\\&quot;:\\&quot;client id $_.\\&quot;,\\&quot;pri\\&quot;:[&quot;.   join(&#39;,&#39;,@{$hash{&#39;primary.txt&#39;}-&gt;{$_}})  .&quot;],\\&quot;sec\\&quot;:[&quot;. join(&#39;,&#39;,@{$hash{&#39;primary.txt&#39;}-&gt;{$_}}) .&quot;]}\\n&quot;\r\n    }\r\n\r\n",
                "title": "Extract primary and secondary numbers for each ID and make a JSON string"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1524575225,
                "creation_date": 1524575225,
                "answer_id": 50002508,
                "question_id": 49995039,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "\r\n&lt;!-- language-all: lang-none --&gt;\r\n\r\nHere&#39;s an alternative Perl solution. It uses the non-core \r\n[`Lingua::EN::Numbers`](https://metacpan.org/pod/Lingua::EN::Numbers) module\r\nto convert from binary to English numbers. If you would rather not install this module then you can either use a simple array or keep the numbers as decimal digits\r\n\r\n&lt;!-- language: lang-perl --&gt;\r\n\r\n    use strict;\r\n    use warnings &#39;all&#39;;\r\n    use autodie;\r\n\r\n    use JSON &#39;to_json&#39;;\r\n    use Lingua::EN::Numbers &#39;num2en&#39;;\r\n\r\n    my %data;\r\n\r\n    for my $file ( qw/ primary.txt secondary.txt / ) {\r\n\r\n        open my $fh, &#39;&lt;&#39;, $file;\r\n        local $/;\r\n\r\n        for my $item ( split /\\]\\s*,/, &lt;$fh&gt; ) {\r\n            my ( $key, @values ) = $item =~ /\\d+/g;\r\n            push @{ $data{$key} }, \\@values;\r\n        }\r\n    }\r\n\r\n    for my $n ( sort { $a &lt;=&gt; $b } keys %data ) {\r\n\r\n        my $num = num2en($n);\r\n\r\n        my %json = (\r\n            text =&gt; &quot;for client id $num&quot;,\r\n            pri  =&gt; $data{$n}[0],\r\n            sec  =&gt; $data{$n}[1],\r\n        );\r\n\r\n        print to_json( \\%json, { canonical =&gt; 1 } ), &quot;\\n&quot;;\r\n    }\r\n\r\n###output\r\n\r\n    {&quot;pri&quot;:[&quot;342&quot;,&quot;1102&quot;,&quot;608&quot;,&quot;684&quot;],&quot;sec&quot;:[&quot;342&quot;,&quot;1102&quot;,&quot;608&quot;,&quot;684&quot;],&quot;text&quot;:&quot;for client id one&quot;}\r\n    {&quot;pri&quot;:[&quot;115&quot;,&quot;191&quot;,&quot;837&quot;,&quot;1559&quot;],&quot;sec&quot;:[&quot;115&quot;,&quot;191&quot;,&quot;837&quot;,&quot;1559&quot;],&quot;text&quot;:&quot;for client id two&quot;}\r\n    {&quot;pri&quot;:[&quot;1256&quot;,&quot;116&quot;],&quot;sec&quot;:[&quot;1256&quot;,&quot;116&quot;],&quot;text&quot;:&quot;for client id three&quot;}",
                "title": "Extract primary and secondary numbers for each ID and make a JSON string"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1524638957,
                "last_edit_date": 1524638957,
                "creation_date": 1524580715,
                "answer_id": 50004420,
                "question_id": 49995039,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here are two solutions which, once the primary.txt and secondary.txt files have been converted to JSON, each require just one invocation of jq.\r\n\r\nFor the conversion to JSON, I&#39;ll assume that &quot;=&quot; can naively be changed to &quot;:&quot; -- this assumption makes it trivial to use `tr` or `sed`; I&#39;ll then use  [`any-json`][1] to complete the conversion, and to tie everything together, I&#39;ll use `bash`, but there are many alternatives, notably [`hjson`][2] as an alternative to `any-json`.\r\n\r\nFor the strings of cardinals, the first solution assumes a suitable JSON array is available, and for the sake of illustration, I&#39;ll assume this is available as a file: cardinals.json (as shown below).  The generic solution assumes that &quot;AP-style&quot; numbers would be acceptable.\r\n\r\n    #!/bin/bash\r\n    \r\n    for f in primary secondary ; do\r\n          any-json --input-format=hjson &lt;(sed &#39;s/=/:/g&#39; $f.txt) &gt; $f.json\r\n          # ALTERNATIVELY: sed &#39;s/=/:/g&#39; $f.txt | hjson -j &gt; $f.json \r\n    done\r\n      \r\n    jq -s --argfile ids cardinals.json &#39;.[0] as $p | .[1] as $s\r\n       | range(0; $ids|length) as $ix\r\n       | ($ix+1|tostring) as $i\r\n       | select($p | has($i) )\r\n       | {&quot;text&quot;: (&quot;for client &quot; + $ids[$ix] + &quot;.&quot;),\r\n          &quot;pri&quot;: $p[$i],\r\n          &quot;sec&quot;: $s[$i] }\r\n    &#39; primary.json secondary.json\r\n\r\n## Generic solution\r\nThis generic solution assumes that AP-style (Associated Press) numbers are acceptable.  It allows the keys in primary.txt to be any strings whatsoever.\r\n\r\n    jq -s --argfile ids cardinals.json &#39;\r\n        def apnumber:\r\n          (tonumber? // null) as $i\r\n          | if $i and $i &gt;= 0 and $i &lt; 10                             \r\n            then [&quot;zero&quot;, &quot;one&quot;, &quot;two&quot;, &quot;three&quot;, &quot;four&quot;, &quot;five&quot;, &quot;six&quot;, &quot;seven&quot;, &quot;eight&quot;, &quot;nine&quot;][$i]\r\n            else .\r\n            end;\r\n\r\n       .[0] as $p | .[1] as $s\r\n       | ($p|keys_unsorted[]) as $i\r\n       | {&quot;text&quot;: (&quot;for client &quot; + ($i|apnumber) + &quot;.&quot;),\r\n          &quot;pri&quot;: $p[$i],\r\n          &quot;sec&quot;: $s[$i] }\r\n    &#39; primary.json secondary.json\r\n\r\n\r\n### cardinals.json\r\n\r\nHere is the output of:\r\n\r\n    ruby -e &#39;require &quot;humanize&quot;; 1.upto(30){|i| p i.humanize}&#39; | jq -s\r\n\r\n---\r\n    [\r\n      &quot;one&quot;,\r\n      &quot;two&quot;,\r\n      &quot;three&quot;,\r\n      &quot;four&quot;,\r\n      &quot;five&quot;,\r\n      &quot;six&quot;,\r\n      &quot;seven&quot;,\r\n      &quot;eight&quot;,\r\n      &quot;nine&quot;,\r\n      &quot;ten&quot;,\r\n      &quot;eleven&quot;,\r\n      &quot;twelve&quot;,\r\n      &quot;thirteen&quot;,\r\n      &quot;fourteen&quot;,\r\n      &quot;fifteen&quot;,\r\n      &quot;sixteen&quot;,\r\n      &quot;seventeen&quot;,\r\n      &quot;eighteen&quot;,\r\n      &quot;nineteen&quot;,\r\n      &quot;twenty&quot;,\r\n      &quot;twenty-one&quot;,\r\n      &quot;twenty-two&quot;,\r\n      &quot;twenty-three&quot;,\r\n      &quot;twenty-four&quot;,\r\n      &quot;twenty-five&quot;,\r\n      &quot;twenty-six&quot;,\r\n      &quot;twenty-seven&quot;,\r\n      &quot;twenty-eight&quot;,\r\n      &quot;twenty-nine&quot;,\r\n      &quot;thirty&quot;\r\n    ]\r\n\r\n\r\n  [1]: https://www.npmjs.com/package/any-json\r\n  [2]: http://hjson.org/users.html",
                "title": "Extract primary and secondary numbers for each ID and make a JSON string"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 2,
        "last_activity_date": 1536903596,
        "creation_date": 1524552349,
        "last_edit_date": 1524565205,
        "question_id": 49995039,
        "body_markdown": "I have two files as shown below: In general I will have more than three client IDs and primary and secondary numbers for each ID will be around 50-60.\r\n\r\n###primary.txt\r\n\r\n    {1=[0, 273, 546, 819], 2=[274, 1, 820], 3=[1016, 275, 821]}\r\n\r\nThis means client ID `1` has primary numbers `[0, 273, 546, 819]`. Similarly for other IDs.\r\n\r\n###secondary.txt\r\n\r\n    {1=[342, 1102, 608, 684], 2=[115, 191, 837, 1559], 3=[1256, 116]}\r\n    \r\nThis means client ID `1` has secondary numbers `[342, 1102, 608, 684]`. Similarly for other IDs.\r\n\r\nI need to read these two files, combine primary and secondary numbers for each ID, and make a JSON string like this for each ID.\r\n\r\n###For clientid 1\r\n\r\n    {&quot;text&quot;:&quot;for client id one.&quot;,&quot;pri&quot;:[0, 273, 546, 819],&quot;sec&quot;:[342, 1102, 608, 684]}\r\n\r\n###For client ID 2\r\n\r\n    {&quot;text&quot;:&quot;for client id two.&quot;,&quot;pri&quot;:[274, 1, 820],&quot;sec&quot;:[115, 191, 837, 1559]}\r\n\r\n###For client ID 3\r\n\r\n    {&quot;text&quot;:&quot;for client id three.&quot;,&quot;pri&quot;:[1016, 275, 821],&quot;sec&quot;:[1256, 116]}\r\n\r\nIs it possible to do this in shell script or Perl? I just want to print it out on the console. Below is what I have tried but I&#39;m unable to figure out how to make proper JSON for each client ID.\r\n\r\n    for n in {1..3}\r\n    do\r\n      echo &quot;$n:&quot;\r\n      for f in primary.txt secondary.txt\r\n      do\r\n        sed -r &quot;s/.*\\b$n=\\[([^]\\]+).*/\\1/&quot; $f\r\n      done\r\n    echo\r\n    done",
        "link": "https://stackoverflow.com/questions/49995039/extract-primary-and-secondary-numbers-for-each-id-and-make-a-json-string",
        "title": "Extract primary and secondary numbers for each ID and make a JSON string"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1524663451,
                "creation_date": 1524663451,
                "answer_id": 50023810,
                "question_id": 50023609,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** approach:\r\n\r\n    jq &#39;.features | map(del(.type) | {Data: tojson})&#39; file.json\r\n\r\nOr the same with *array* construction `[...]`:\r\n\r\n    jq &#39;[.features[] | del(.type) | {Data: tojson}]&#39; file.json\r\n\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;Data&quot;: &quot;{\\&quot;properties\\&quot;:{\\&quot;district\\&quot;:\\&quot;d1\\&quot;,\\&quot;district_code\\&quot;:\\&quot;101\\&quot;,\\&quot;block_code\\&quot;:\\&quot;1010070\\&quot;}}&quot;\r\n      },\r\n      {\r\n        &quot;Data&quot;: &quot;{\\&quot;properties\\&quot;:{\\&quot;district\\&quot;:\\&quot;d1\\&quot;,\\&quot;district_code\\&quot;:\\&quot;101\\&quot;,\\&quot;block_code\\&quot;:\\&quot;1010100\\&quot;}}&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "Adding quotes to an json array and add attribute key with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1524663451,
        "creation_date": 1524662816,
        "question_id": 50023609,
        "body_markdown": "This below is my original json:\r\n\r\n    {\r\n    &quot;type&quot;: &quot;type1&quot;,\r\n    &quot;name&quot;: &quot;abc&quot;,\r\n    &quot;features&quot;: [\r\n    { &quot;type&quot;: &quot;Feature&quot;, &quot;properties&quot;: { &quot;district&quot;: &quot;d1&quot;, &quot;district_code&quot;: &quot;101&quot;, &quot;block_code&quot;: &quot;1010070&quot; }},\r\n    { &quot;type&quot;: &quot;Feature&quot;, &quot;properties&quot;: { &quot;district&quot;: &quot;d1&quot;, &quot;district_code&quot;: &quot;101&quot;, &quot;block_code&quot;: &quot;1010100&quot; }}]\r\n    }\r\n\r\nMy expected result:\r\n\r\n    [\r\n      {\r\n        &quot;Data&quot;: &quot;{\\&quot;properties\\&quot;:{\\&quot;district\\&quot;:\\&quot;d1\\&quot;,\\&quot;district_code\\&quot;:\\&quot;101\\&quot;,\\&quot;block_code\\&quot;:\\&quot;1010070\\&quot;}}&quot;\r\n       },\r\n      {\r\n        &quot;Data&quot;: &quot;{\\&quot;properties\\&quot;:{\\&quot;district\\&quot;:\\&quot;d1\\&quot;,\\&quot;district_code\\&quot;:\\&quot;101\\&quot;,\\&quot;block_code\\&quot;:\\&quot;1010100\\&quot;}}&quot;\r\n      }\r\n    ]\r\n\r\nSo far I am only able to add quotes by:\r\n\r\n    .features[] | del(.type) | tojson\r\n\r\n\r\nwhich will only give me:\r\n\r\n    &quot;{\\&quot;properties\\&quot;:{\\&quot;district\\&quot;:\\&quot;d1\\&quot;,\\&quot;district_code\\&quot;:\\&quot;101\\&quot;,\\&quot;block_code\\&quot;:\\&quot;1010070\\&quot;}}&quot;\r\n    &quot;{\\&quot;properties\\&quot;:{\\&quot;district\\&quot;:\\&quot;d1\\&quot;,\\&quot;district_code\\&quot;:\\&quot;101\\&quot;,\\&quot;block_code\\&quot;:\\&quot;1010100\\&quot;}}&quot;\r\n\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/50023609/adding-quotes-to-an-json-array-and-add-attribute-key-with-jq",
        "title": "Adding quotes to an json array and add attribute key with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1524684550,
                "post_id": 50029781,
                "comment_id": 87076074,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 13336740,
                    "reputation": 55,
                    "user_id": 9626352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-Dmly2_FRewo/AAAAAAAAAAI/AAAAAAAADMg/w57b-RDTm98/s256-rj/photo.jpg",
                    "display_name": " phear ",
                    "link": "https://stackoverflow.com/users/9626352/phear"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524685780,
                "post_id": 50029781,
                "comment_id": 87076609,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1524689160,
                "last_edit_date": 1524689160,
                "creation_date": 1524687413,
                "answer_id": 50030655,
                "question_id": 50029781,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With single **`jq`** command:\r\n\r\nSample `input.json`:\r\n\r\n    {\r\n      &quot;Johnny Cage&quot;: {\r\n        &quot;firstname&quot;: &quot;Johnny&quot;,\r\n        &quot;lastname&quot;: &quot;Cage&quot;,\r\n        &quot;height&quot;: 183,\r\n        &quot;weight&quot;: 82,\r\n        &quot;hands&quot;: 2,\r\n        &quot;legs&quot;: 2\r\n      }\r\n    }\r\n\r\n\r\n----------\r\n\r\n    jq -r &#39;to_entries[] | (.key | sub(&quot; &quot;; &quot;.&quot;)) as $name \r\n           | .value | to_entries[]\r\n           | &quot;mk.fighter.\\($name).\\(.key) \\(.value)&quot;&#39; input.json\r\n\r\nTo get `$name` as a combination of inner `firstname` and `lastname` keys replace &lt;br&gt;`(.key | sub(&quot; &quot;; &quot;.&quot;)) as $name` with `&quot;\\(.value.firstname).\\(.value.lastname)&quot; as $name`\r\n\r\n\r\n----------\r\n\r\n\r\nThe output:\r\n\r\n    mk.fighter.Johnny.Cage.firstname Johnny\r\n    mk.fighter.Johnny.Cage.lastname Cage\r\n    mk.fighter.Johnny.Cage.height 183\r\n    mk.fighter.Johnny.Cage.weight 82\r\n    mk.fighter.Johnny.Cage.hands 2\r\n    mk.fighter.Johnny.Cage.legs 2\r\n\r\n\r\n",
                "title": "How to create key:value list from JSON? Key name should contain some values from object itself"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1524782370,
        "creation_date": 1524683623,
        "last_edit_date": 1524782370,
        "question_id": 50029781,
        "body_markdown": "I&#39;m trying to parse JSON and store certain values as metrics in Graphite.\r\nIn order to make my Graphite more user-friendly I have to form a metric name, that contains some values from its object.\r\nI got working solution on bash loops + jq, but it&#39;s really slow. So I&#39;m asking for help :)\r\n\r\nHere is my input:\r\n\r\n    {\r\n    ...\r\n      },\r\n      &quot;Johnny Cage&quot;: {\r\n        &quot;firstname&quot;: &quot;Johnny&quot;,\r\n        &quot;lastname&quot;: &quot;Cage&quot;,\r\n        &quot;height&quot;: 183,\r\n        &quot;weight&quot;: 82,\r\n        &quot;hands&quot;: 2,\r\n        &quot;legs&quot;: 2,\r\n        ...\r\n      },\r\n      ...\r\n    }\r\nDesired output:\r\n\r\n    mk.fighter.Johnny.Cage.firstname Johnny\r\n    mk.fighter.Johnny.Cage.lastname Cage\r\n    mk.fighter.Johnny.Cage.height 183\r\n    mk.fighter.Johnny.Cage.weight 82\r\n    mk.fighter.Johnny.Cage.hands 2\r\n    mk.fighter.Johnny.Cage.legs 2\r\n    ...\r\n",
        "link": "https://stackoverflow.com/questions/50029781/how-to-create-keyvalue-list-from-json-key-name-should-contain-some-values-from",
        "title": "How to create key:value list from JSON? Key name should contain some values from object itself"
    },
    {
        "tags": [
            "json",
            "linux",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1524689320,
                "last_edit_date": 1524689320,
                "creation_date": 1524689168,
                "answer_id": 50031091,
                "question_id": 50031040,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I guess you want [`keys`][1]:\r\n\r\n    jq &#39;.x|keys&#39; input.json\r\n    [\r\n      &quot;a&quot;,\r\n      &quot;b&quot;,\r\n      &quot;c&quot;,\r\n      &quot;d&quot;\r\n    ]\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#keys,keys_unsorted",
                "title": "omit child values with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1524775620,
        "creation_date": 1524688985,
        "last_edit_date": 1524775620,
        "question_id": 50031040,
        "body_markdown": "I&#39;ve got the following document\r\n\r\n\r\n    ~/ cat /tmp/stuff2 | jq &#39;.&#39;\r\n    {\r\n      &quot;x&quot;: {\r\n        &quot;a&quot;: {\r\n          &quot;c1&quot;: 2,\r\n          &quot;c2&quot;: &quot;sss&quot;\r\n        },\r\n        &quot;b&quot;: {\r\n          &quot;c1&quot;: 3,\r\n          &quot;c2&quot;: &quot;sfs&quot;,\r\n          &quot;c3&quot;: {\r\n            &quot;d1&quot;: &quot;aa&quot;,\r\n            &quot;d2&quot;: 3\r\n          }\r\n        },\r\n        &quot;c&quot;: {\r\n          &quot;c1&quot;: 5,\r\n          &quot;c2&quot;: &quot;ssy&quot;\r\n        },\r\n        &quot;d&quot;: {\r\n          &quot;c1&quot;: 8,\r\n          &quot;c2&quot;: &quot;esy&quot;\r\n        }\r\n      }\r\n    }\r\n\r\n\r\n\r\nI would like to do something like the following:\r\n\r\n    ~/ cat /tmp/stuff2 | jq &#39;.x | &lt;1st level|not child&gt;&#39;\r\n    {\r\n      &quot;a&quot;,\r\n      &quot;b&quot;,\r\n      &quot;c&quot;,\r\n      &quot;d&quot;\r\n    }\r\n\r\nBu I cannot fin a way to omit the subvalues or child of those indexes.\r\n\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/50031040/omit-child-values-with-jq",
        "title": "omit child values with jq"
    },
    {
        "tags": [
            "regex",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2117537,
                    "reputation": 5780,
                    "user_id": 1881450,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/202416461e32a17e8b99fc658c058888?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Nam Nguyen",
                    "link": "https://stackoverflow.com/users/1881450/nam-nguyen"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524695909,
                "post_id": 50032199,
                "comment_id": 87080619,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1524696995,
                "last_edit_date": 1524696995,
                "creation_date": 1524696260,
                "answer_id": 50032343,
                "question_id": 50032199,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following seems to be what you&#39;re after:\r\n\r\n    map(. as $in | select(&quot;progressive&quot; | test($in|.[&quot;genre&quot;])))\r\n\r\n\r\n(`$in|.[&quot;genre&quot;]` can be abbreviated to `$in.genre` but I left the pipe to make things a bit clearer.)\r\n\r\nNotice how we use `. as $in` to set things up so we can call `test` with the appropriate input and argument.\r\n\r\n## Variation\r\n\r\nA little less typing ...\r\n\r\n    map(.genre as $g | select(&quot;progressive&quot; | test($g)))\r\n\r\n\r\n\r\n",
                "title": "JQ search object with regex"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1524698375,
        "creation_date": 1524695253,
        "last_edit_date": 1524698375,
        "question_id": 50032199,
        "body_markdown": "I&#39;ve been playing around with JQ https://jqplay.org to extract JSON data and I saw the `test` operation that allows me to use regex to extract data. In below sample run, I passed in regex pattern `&quot;^progressive$&quot;` into `test` to search for data:\r\n\r\n\r\n**DATA**:\r\n\r\n    [\r\n      {&quot;genre&quot;: &quot;progressive&quot;},\r\n      {&quot;genre&quot;: &quot;a progressive 1&quot;}\r\n    ]\r\n\r\n\r\n**QUERY**:\r\n\r\n    map(select(.genre | test(&quot;^progressive$&quot;)))\r\n\r\n\r\n**RESULT**:\r\n\r\n    [\r\n      {\r\n        &quot;genre&quot;: &quot;progressive&quot;\r\n      }\r\n    ]\r\n\r\n==========================================================================\r\n\r\nNow, I want to do opposite above. `genre` value in the JSON is my regex and what I pass in `test` is my data. For example:\r\n\r\n**DATA**:\r\n\r\n    [\r\n      {&quot;genre&quot;: &quot;^progressive$&quot;},\r\n      {&quot;genre&quot;: &quot;^abc$&quot;}\r\n    ]\r\n\r\n\r\n**QUERY**:\r\n\r\nI have not figured out the query yet :( but I have tried following but it did not return what I want or error out.\r\n\r\n    map(select(&quot;progressive&quot; | test(.[&quot;genre&quot;])))\r\n\r\n\r\n**EXPECTED RESULT**:\r\n\r\n    [\r\n      {\r\n        &quot;genre&quot;: &quot;^progressive$&quot;\r\n      }\r\n    ]\r\n\r\nI don&#39;t know if it is possible to do or if anyone knows howto. I&#39;m thinking of doing the long way which will loop through each object in array and extract `genre` value out and then compared with `progressive`. This is a long way and it will work but I&#39;m curious if anyone knows a better and more efficient way.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/50032199/jq-search-object-with-regex",
        "title": "JQ search object with regex"
    },
    {
        "tags": [
            "json",
            "jq",
            "juju"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 44493,
                    "reputation": 1596,
                    "user_id": 130639,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/ab7aaf4e9821bbdbd726f3a6e920e5da?s=256&d=identicon&r=PG",
                    "display_name": "Jim",
                    "link": "https://stackoverflow.com/users/130639/jim"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524852078,
                "post_id": 50055538,
                "comment_id": 87152200,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524881311,
                "post_id": 50055538,
                "comment_id": 87161128,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 44493,
                    "reputation": 1596,
                    "user_id": 130639,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/ab7aaf4e9821bbdbd726f3a6e920e5da?s=256&d=identicon&r=PG",
                    "display_name": "Jim",
                    "link": "https://stackoverflow.com/users/130639/jim"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1524993755,
                "post_id": 50055538,
                "comment_id": 87185855,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1525099352,
                "last_edit_date": 1525099352,
                "creation_date": 1525004875,
                "answer_id": 50086556,
                "question_id": 50055538,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It is unclear to me how exactly the value of &quot;unit-name&quot; is supposed to be derived, but the following should get you on your way:\r\n\r\n    def machine($id):\r\n      first(.applications[]\r\n        | (.units? // empty)\r\n        | to_entries[]\r\n        | select(.value.machine == $id)\r\n        | .key ) ;\r\n    \r\n    . as $in\r\n    | .machines\r\n    | to_entries[]\r\n    | .key as $key\r\n    | {($key): {\r\n                 &quot;unit-name&quot;: (.value |.[&quot;instance-id&quot;]),\r\n                 &quot;machine&quot;: ($in|machine($key))\r\n      \t       } }\r\n\r\n\t  \r\n\r\n\r\nWith your input, this produces a stream of objects beginning:\r\n\r\n    {\r\n      &quot;0&quot;: {\r\n        &quot;unit-name&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;machine&quot;: &quot;easyrsa/0&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;1&quot;: {\r\n        &quot;unit-name&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;machine&quot;: &quot;etcd/0&quot;\r\n      }\r\n    }\r\n\r\n### Takeaways\r\nThe solution illustrates three noteworthy points:\r\n\r\n1. `to_entries` is useful when one has to work with key/value combinations when the specific key (or keys) of interest is (or are) not known beforehand; an alternative is to use `keys_unsorted`;\r\n\r\n2. dollar-variables are handy when pulling together information from distinct sources;\r\n\r\n3. jq&#39;s support for function definitions makes it possible to write programs that are more readable and maintainable than they would otherwise be.\r\n",
                "title": "juju status and jq filtering blend stuff from multiple objects in JSON status"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1525099352,
        "creation_date": 1524805281,
        "last_edit_date": 1524993506,
        "question_id": 50055538,
        "body_markdown": "**tl;dr**\r\n\r\nI&#39;m trying to get a JSON representation of `juju status` output which objectifies the machine, the instance-id, and the unit such that the JSON looks similar to:\r\n\r\n\r\n    {\r\n      &quot;0&quot;: {\r\n              &quot;instance-id&quot;: &quot;i-xxxxxxxxxxxxxx&quot;,\r\n              &quot;unit-name&quot;: &quot;easyrsa/0&quot;\r\n           },\r\n      &quot;1&quot;: {\r\n              &quot;instance-id&quot;: &quot;i-xxxxxxxxxxxxxx&quot;,\r\n              &quot;unit-name&quot;: &quot;etcd/0&quot;\r\n           },\r\n      &quot;2&quot;: {\r\n              &quot;instance-id&quot;: &quot;i-xxxxxxxxxxxxxx&quot;,\r\n              &quot;unit-name&quot;: &quot;kubeapi-load-balancer/0&quot;\r\n           },\r\n      &quot;10&quot;: {\r\n              &quot;instance-id&quot;: &quot;i-xxxxxxxxxxxxxx&quot;,\r\n              &quot;unit-name&quot;: &quot;kubernetes-worker/4&quot;\r\n           },\r\n      &quot;11&quot;: {\r\n              &quot;instance-id&quot;: &quot;i-xxxxxxxxxxxxxx&quot;,\r\n              &quot;unit-name&quot;: &quot;kubernetes-worker/5&quot;\r\n           },\r\n      &quot;12&quot;: {\r\n              &quot;instance-id&quot;: &quot;i-xxxxxxxxxxxxxx&quot;,\r\n              &quot;unit-name&quot;: &quot;kubernetes-master/3&quot;\r\n           }\r\n    }\r\n\r\n\r\n**The long of it:**\r\n\r\nMunging `juju status --format json` is complicated for me because the data to be munged is split between two different main objects in the JSON. Since the keys for the machines are not iterable, yet, I&#39;m not able to reference them later like I could an array -- or at least that&#39;s where I think I&#39;m getting messed up.\r\n\r\n\r\nSome things I&#39;ve tried but failed (mostly because I struggle with how to store the `.machines` keys for use later)... \r\n\r\n`juju status --format json | jq -r &#39;.machines as $m | .machines | [foreach keys[] as $item ({m: $item, id: $m[$item].&quot;instance-id&quot;})]&#39;`\r\n\r\n`... | juju status --format json | jq -r &#39;.machines | keys[] as $k...`\r\n\r\n`... | juju status --format json | jq -r &#39;.machines | keys[] as $k |...`\r\n\r\nEither I don&#39;t get the result I need or I get a syntax error. I&#39;ve never had a need to use `foreach` in jq context. In fact, this is the most complicated thing I&#39;ve tried to accomplish with `jq` so I&#39;m way outside my comfort zone here. Any assistance would be greatly appreciated.\r\n\r\n\r\nHere&#39;s an sample `juju status` JSON object:\r\n\r\n    {\r\n      &quot;model&quot;: {\r\n        &quot;name&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;controller&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;cloud&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;region&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;version&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;model-status&quot;: {\r\n          &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n        },\r\n        &quot;sla&quot;: &quot;xxxxxxxxxx&quot;\r\n      },\r\n      &quot;machines&quot;: {\r\n        &quot;0&quot;: {\r\n          &quot;juju-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;dns-name&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;ip-addresses&quot;: [\r\n            &quot;10.0.0.229&quot;,\r\n            &quot;252.0.229.1&quot;\r\n          ],\r\n          &quot;instance-id&quot;: &quot;i-xxxxxxxxxxxxxx&quot;,\r\n          &quot;machine-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;series&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;network-interfaces&quot;: {\r\n            &quot;eth0&quot;: {\r\n              &quot;ip-addresses&quot;: [\r\n                &quot;10.0.0.229&quot;\r\n              ],\r\n              &quot;mac-address&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;gateway&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;is-up&quot;: true\r\n            },\r\n            &quot;fan-252&quot;: {\r\n              &quot;ip-addresses&quot;: [\r\n                &quot;252.0.229.1&quot;\r\n              ],\r\n              &quot;mac-address&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;is-up&quot;: true\r\n            }\r\n          },\r\n          &quot;constraints&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;hardware&quot;: &quot;xxxxxxxxxx&quot;\r\n        },\r\n        &quot;1&quot;: {\r\n          &quot;juju-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;dns-name&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;ip-addresses&quot;: [\r\n            &quot;10.0.0.61&quot;,\r\n            &quot;252.0.61.1&quot;\r\n          ],\r\n          &quot;instance-id&quot;: &quot;i-xxxxxxxxxxxxxx&quot;,\r\n          &quot;machine-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;series&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;network-interfaces&quot;: {\r\n            &quot;eth0&quot;: {\r\n              &quot;ip-addresses&quot;: [\r\n                &quot;10.0.0.61&quot;\r\n              ],\r\n              &quot;mac-address&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;gateway&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;is-up&quot;: true\r\n            },\r\n            &quot;fan-252&quot;: {\r\n              &quot;ip-addresses&quot;: [\r\n                &quot;252.0.61.1&quot;\r\n              ],\r\n              &quot;mac-address&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;is-up&quot;: true\r\n            }\r\n          },\r\n          &quot;constraints&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;hardware&quot;: &quot;xxxxxxxxxx&quot;\r\n        },\r\n        &quot;10&quot;: {\r\n          &quot;juju-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;dns-name&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;ip-addresses&quot;: [\r\n            &quot;10.0.0.37&quot;,\r\n            &quot;252.0.37.1&quot;\r\n          ],\r\n          &quot;instance-id&quot;: &quot;i-xxxxxxxxxxxxxx&quot;,\r\n          &quot;machine-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;series&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;network-interfaces&quot;: {\r\n            &quot;ens5&quot;: {\r\n              &quot;ip-addresses&quot;: [\r\n                &quot;10.0.0.37&quot;\r\n              ],\r\n              &quot;mac-address&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;gateway&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;is-up&quot;: true\r\n            },\r\n            &quot;fan-252&quot;: {\r\n              &quot;ip-addresses&quot;: [\r\n                &quot;252.0.37.1&quot;\r\n              ],\r\n              &quot;mac-address&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;is-up&quot;: true\r\n            }\r\n          },\r\n          &quot;constraints&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;hardware&quot;: &quot;xxxxxxxxxx&quot;\r\n        },\r\n        &quot;11&quot;: {\r\n          &quot;juju-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;dns-name&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;ip-addresses&quot;: [\r\n            &quot;10.0.0.54&quot;\r\n          ],\r\n          &quot;instance-id&quot;: &quot;i-xxxxxxxxxxxxxx&quot;,\r\n          &quot;machine-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;series&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;network-interfaces&quot;: {\r\n            &quot;ens5&quot;: {\r\n              &quot;ip-addresses&quot;: [\r\n                &quot;10.0.0.54&quot;\r\n              ],\r\n              &quot;mac-address&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;gateway&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;is-up&quot;: true\r\n            }\r\n          },\r\n          &quot;constraints&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;hardware&quot;: &quot;xxxxxxxxxx&quot;\r\n        },\r\n        &quot;12&quot;: {\r\n          &quot;juju-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;dns-name&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;ip-addresses&quot;: [\r\n            &quot;10.0.0.101&quot;\r\n          ],\r\n          &quot;instance-id&quot;: &quot;i-xxxxxxxxxxxxxx&quot;,\r\n          &quot;machine-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;series&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;network-interfaces&quot;: {\r\n            &quot;ens5&quot;: {\r\n              &quot;ip-addresses&quot;: [\r\n                &quot;10.0.0.101&quot;\r\n              ],\r\n              &quot;mac-address&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;gateway&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;is-up&quot;: true\r\n            }\r\n          },\r\n          &quot;constraints&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;hardware&quot;: &quot;xxxxxxxxxx&quot;\r\n        },\r\n        &quot;2&quot;: {\r\n          &quot;juju-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;dns-name&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;ip-addresses&quot;: [\r\n            &quot;10.0.0.184&quot;,\r\n            &quot;252.0.184.1&quot;\r\n          ],\r\n          &quot;instance-id&quot;: &quot;i-xxxxxxxxxxxxxx&quot;,\r\n          &quot;machine-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;series&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;network-interfaces&quot;: {\r\n            &quot;eth0&quot;: {\r\n              &quot;ip-addresses&quot;: [\r\n                &quot;10.0.0.184&quot;\r\n              ],\r\n              &quot;mac-address&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;gateway&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;is-up&quot;: true\r\n            },\r\n            &quot;fan-252&quot;: {\r\n              &quot;ip-addresses&quot;: [\r\n                &quot;252.0.184.1&quot;\r\n              ],\r\n              &quot;mac-address&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;is-up&quot;: true\r\n            }\r\n          },\r\n          &quot;constraints&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;hardware&quot;: &quot;xxxxxxxxxx&quot;\r\n        }\r\n      },\r\n      &quot;applications&quot;: {\r\n        &quot;easyrsa&quot;: {\r\n          &quot;charm&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;series&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;os&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-origin&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-name&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-rev&quot;: 39,\r\n          &quot;can-upgrade-to&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;exposed&quot;: false,\r\n          &quot;application-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;relations&quot;: {\r\n            &quot;client&quot;: [\r\n              &quot;etcd&quot;,\r\n              &quot;kubeapi-load-balancer&quot;,\r\n              &quot;kubernetes-master&quot;,\r\n              &quot;kubernetes-worker&quot;\r\n            ]\r\n          },\r\n          &quot;units&quot;: {\r\n            &quot;easyrsa/0&quot;: {\r\n              &quot;workload-status&quot;: {\r\n                &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n              },\r\n              &quot;juju-status&quot;: {\r\n                &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;since&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n              },\r\n              &quot;leader&quot;: true,\r\n              &quot;machine&quot;: &quot;0&quot;,\r\n              &quot;public-address&quot;: &quot;xxxxxxxxxx&quot;\r\n            }\r\n          },\r\n          &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n        },\r\n        &quot;etcd&quot;: {\r\n          &quot;charm&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;series&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;os&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-origin&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-name&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-rev&quot;: 77,\r\n          &quot;can-upgrade-to&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;exposed&quot;: false,\r\n          &quot;application-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;relations&quot;: {\r\n            &quot;certificates&quot;: [\r\n              &quot;easyrsa&quot;\r\n            ],\r\n            &quot;cluster&quot;: [\r\n              &quot;etcd&quot;\r\n            ],\r\n            &quot;db&quot;: [\r\n              &quot;flannel&quot;,\r\n              &quot;kubernetes-master&quot;\r\n            ]\r\n          },\r\n          &quot;units&quot;: {\r\n            &quot;etcd/0&quot;: {\r\n              &quot;workload-status&quot;: {\r\n                &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n              },\r\n              &quot;juju-status&quot;: {\r\n                &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;since&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n              },\r\n              &quot;leader&quot;: true,\r\n              &quot;machine&quot;: &quot;1&quot;,\r\n              &quot;open-ports&quot;: [\r\n                &quot;2379/tcp&quot;\r\n              ],\r\n              &quot;public-address&quot;: &quot;xxxxxxxxxx&quot;\r\n            }\r\n          },\r\n          &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n        },\r\n        &quot;flannel&quot;: {\r\n          &quot;charm&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;series&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;os&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-origin&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-name&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-rev&quot;: 52,\r\n          &quot;can-upgrade-to&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;exposed&quot;: false,\r\n          &quot;application-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;relations&quot;: {\r\n            &quot;cni&quot;: [\r\n              &quot;kubernetes-master&quot;,\r\n              &quot;kubernetes-worker&quot;\r\n            ],\r\n            &quot;etcd&quot;: [\r\n              &quot;etcd&quot;\r\n            ]\r\n          },\r\n          &quot;subordinate-to&quot;: [\r\n            &quot;kubernetes-master&quot;,\r\n            &quot;kubernetes-worker&quot;\r\n          ],\r\n          &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n        },\r\n        &quot;kubeapi-load-balancer&quot;: {\r\n          &quot;charm&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;series&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;os&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-origin&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-name&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-rev&quot;: 57,\r\n          &quot;can-upgrade-to&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;exposed&quot;: true,\r\n          &quot;application-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;relations&quot;: {\r\n            &quot;apiserver&quot;: [\r\n              &quot;kubernetes-master&quot;\r\n            ],\r\n            &quot;certificates&quot;: [\r\n              &quot;easyrsa&quot;\r\n            ],\r\n            &quot;loadbalancer&quot;: [\r\n              &quot;kubernetes-master&quot;\r\n            ],\r\n            &quot;website&quot;: [\r\n              &quot;kubernetes-worker&quot;\r\n            ]\r\n          },\r\n          &quot;units&quot;: {\r\n            &quot;kubeapi-load-balancer/0&quot;: {\r\n              &quot;workload-status&quot;: {\r\n                &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n              },\r\n              &quot;juju-status&quot;: {\r\n                &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;since&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n              },\r\n              &quot;leader&quot;: true,\r\n              &quot;machine&quot;: &quot;2&quot;,\r\n              &quot;open-ports&quot;: [\r\n                &quot;443/tcp&quot;\r\n              ],\r\n              &quot;public-address&quot;: &quot;xxxxxxxxxx&quot;\r\n            }\r\n          },\r\n          &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n        },\r\n        &quot;kubernetes-master&quot;: {\r\n          &quot;charm&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;series&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;os&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-origin&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-name&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-rev&quot;: 102,\r\n          &quot;can-upgrade-to&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;exposed&quot;: false,\r\n          &quot;application-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;relations&quot;: {\r\n            &quot;certificates&quot;: [\r\n              &quot;easyrsa&quot;\r\n            ],\r\n            &quot;cni&quot;: [\r\n              &quot;flannel&quot;\r\n            ],\r\n            &quot;etcd&quot;: [\r\n              &quot;etcd&quot;\r\n            ],\r\n            &quot;kube-api-endpoint&quot;: [\r\n              &quot;kubeapi-load-balancer&quot;\r\n            ],\r\n            &quot;kube-control&quot;: [\r\n              &quot;kubernetes-worker&quot;\r\n            ],\r\n            &quot;loadbalancer&quot;: [\r\n              &quot;kubeapi-load-balancer&quot;\r\n            ]\r\n          },\r\n          &quot;units&quot;: {\r\n            &quot;kubernetes-master/3&quot;: {\r\n              &quot;workload-status&quot;: {\r\n                &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n              },\r\n              &quot;juju-status&quot;: {\r\n                &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;since&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n              },\r\n              &quot;leader&quot;: true,\r\n              &quot;machine&quot;: &quot;12&quot;,\r\n              &quot;open-ports&quot;: [\r\n                &quot;6443/tcp&quot;\r\n              ],\r\n              &quot;public-address&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;subordinates&quot;: {\r\n                &quot;flannel/9&quot;: {\r\n                  &quot;workload-status&quot;: {\r\n                    &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                    &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n                    &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n                  },\r\n                  &quot;juju-status&quot;: {\r\n                    &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                    &quot;since&quot;: &quot;xxxxxxxxxx&quot;,\r\n                    &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n                  },\r\n                  &quot;upgrading-from&quot;: &quot;xxxxxxxxxx&quot;,\r\n                  &quot;public-address&quot;: &quot;xxxxxxxxxx&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n        },\r\n        &quot;kubernetes-worker&quot;: {\r\n          &quot;charm&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;series&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;os&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-origin&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-name&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;charm-rev&quot;: 114,\r\n          &quot;can-upgrade-to&quot;: &quot;xxxxxxxxxx&quot;,\r\n          &quot;exposed&quot;: false,\r\n          &quot;application-status&quot;: {\r\n            &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n            &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n          },\r\n          &quot;relations&quot;: {\r\n            &quot;certificates&quot;: [\r\n              &quot;easyrsa&quot;\r\n            ],\r\n            &quot;cni&quot;: [\r\n              &quot;flannel&quot;\r\n            ],\r\n            &quot;kube-api-endpoint&quot;: [\r\n              &quot;kubeapi-load-balancer&quot;\r\n            ],\r\n            &quot;kube-control&quot;: [\r\n              &quot;kubernetes-master&quot;\r\n            ]\r\n          },\r\n          &quot;units&quot;: {\r\n            &quot;kubernetes-worker/4&quot;: {\r\n              &quot;workload-status&quot;: {\r\n                &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n              },\r\n              &quot;juju-status&quot;: {\r\n                &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;since&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n              },\r\n              &quot;machine&quot;: &quot;10&quot;,\r\n              &quot;open-ports&quot;: [\r\n                &quot;80/tcp&quot;,\r\n                &quot;443/tcp&quot;\r\n              ],\r\n              &quot;public-address&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;subordinates&quot;: {\r\n                &quot;flannel/7&quot;: {\r\n                  &quot;workload-status&quot;: {\r\n                    &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                    &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n                    &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n                  },\r\n                  &quot;juju-status&quot;: {\r\n                    &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                    &quot;since&quot;: &quot;xxxxxxxxxx&quot;,\r\n                    &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n                  },\r\n                  &quot;upgrading-from&quot;: &quot;xxxxxxxxxx&quot;,\r\n                  &quot;public-address&quot;: &quot;xxxxxxxxxx&quot;\r\n                }\r\n              }\r\n            },\r\n            &quot;kubernetes-worker/5&quot;: {\r\n              &quot;workload-status&quot;: {\r\n                &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n              },\r\n              &quot;juju-status&quot;: {\r\n                &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;since&quot;: &quot;xxxxxxxxxx&quot;,\r\n                &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n              },\r\n              &quot;leader&quot;: true,\r\n              &quot;machine&quot;: &quot;11&quot;,\r\n              &quot;open-ports&quot;: [\r\n                &quot;80/tcp&quot;,\r\n                &quot;443/tcp&quot;\r\n              ],\r\n              &quot;public-address&quot;: &quot;xxxxxxxxxx&quot;,\r\n              &quot;subordinates&quot;: {\r\n                &quot;flannel/8&quot;: {\r\n                  &quot;workload-status&quot;: {\r\n                    &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                    &quot;message&quot;: &quot;xxxxxxxxxx&quot;,\r\n                    &quot;since&quot;: &quot;xxxxxxxxxx&quot;\r\n                  },\r\n                  &quot;juju-status&quot;: {\r\n                    &quot;current&quot;: &quot;xxxxxxxxxx&quot;,\r\n                    &quot;since&quot;: &quot;xxxxxxxxxx&quot;,\r\n                    &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n                  },\r\n                  &quot;leader&quot;: true,\r\n                  &quot;upgrading-from&quot;: &quot;xxxxxxxxxx&quot;,\r\n                  &quot;public-address&quot;: &quot;xxxxxxxxxx&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;version&quot;: &quot;xxxxxxxxxx&quot;\r\n        }\r\n      }\r\n    }",
        "link": "https://stackoverflow.com/questions/50055538/juju-status-and-jq-filtering-blend-stuff-from-multiple-objects-in-json-status",
        "title": "juju status and jq filtering blend stuff from multiple objects in JSON status"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1524874788,
                "last_edit_date": 1524874788,
                "creation_date": 1524874358,
                "answer_id": 50071648,
                "question_id": 50066818,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "messages.json effectively defines a dictionary, so let&#39;s begin by creating a JSON dictionary which we can lookup easily. This can be done conveniently using INDEX/2 which (in case your jq does not have it) is defined as follows:\r\n\r\n    def INDEX(stream; idx_expr):\r\n      reduce stream as $row ({};\r\n        .[$row|idx_expr|\r\n          if type != &quot;string&quot; then tojson\r\n          else .\r\n          end] |= $row);\r\n\r\nA first-cut solution is now straightforward:\r\n\r\n    INDEX($messages[]; .msg) as $dict\r\n    | inputs\r\n    | $dict[.msg]\r\n    | .out \r\n\r\nAssuming this is in program.jq, an appropriate invocation would be as follows (note especially the `-n` option):\r\n\r\n    jq -n --slurpfile messages messages.json -f program.jq log.json\r\n\r\nThe above will print `null` if the `.msg` in the log file is not in the dictionary. To filter out these nulls, you could (for example) add `select(.)` to the pipeline.\r\n\r\nAnother possibility would be to use the original `.msg`, as in this variation:\r\n\r\n    INDEX($messages[]; .msg) as $dict\r\n    | inputs\r\n    | . as $in\r\n    | $dict[.msg]\r\n    | .out // $in.msg\r\n\r\n\r\n\r\n",
                "title": "jq- reference current position in loop"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1524874788,
        "creation_date": 1524847001,
        "last_edit_date": 1524874591,
        "question_id": 50066818,
        "body_markdown": "I have a log file called `log.json` that&#39;s formatted like this:  \r\n\r\n    {&quot;msg&quot;: &quot;Service starting up!&quot;}  \r\n    {&quot;msg&quot;: &quot;Running a job!&quot;}\r\n    {&quot;msg&quot;: &quot;Error detected!&quot;}\r\n\r\nAnd another file called `messages.json`, which looks like this:\r\n\r\n    {&quot;msg&quot;: &quot;Service starting up!&quot;, &quot;out&quot;: &quot;The service has started&quot;}\r\n    {&quot;msg&quot;: &quot;Error detected!&quot;, &quot;out&quot;: &quot;Uh oh, there was an error!&quot;}\r\n    {&quot;msg&quot;: &quot;Service stopped&quot;, &quot;out&quot;: &quot;The service has stopped&quot;}\r\n\r\nI&#39;m trying to write a function using `jq` that reads in both files, and whenever it finds a `msg` in `log.json` that matches a `msg` in `messages.json`, print the value of `out` in the corresponding line in `messages.json`. So, in this case, I&#39;m hoping to get this as output:\r\n\r\n    &quot;The service has started&quot;\r\n    &quot;Uh oh, there was an error!&quot;\r\n\r\nThe closest that I&#39;ve been able to get so far is the following:\r\n\r\n    jq --argfile a log.json --argfile b messages.json -n &#39;if ($a[].msg == $b[].msg) then $b[].out else empty end&#39;\r\n\r\nThis successfully performs all of the comparisons that I&#39;m hoping to make. However, rather than printing the specific `out` that I&#39;m looking for, it instead prints every `out` whenever the if statement returns true (which makes sense. `$b[].out` was never redefined, and asks for each of them). So, this statement outputs:\r\n\r\n    &quot;The service has started&quot;\r\n    &quot;Uh oh, there was an error!&quot;\r\n    &quot;The service has stopped&quot;\r\n    &quot;The service has started&quot;\r\n    &quot;Uh oh, there was an error!&quot;\r\n    &quot;The service has stopped&quot;\r\n\r\nSo at this point, I need some way to ask for `$b[current_index].out`, and just print that. Is there a way for me to do this (or an entirely seperate approach that I can use)?",
        "link": "https://stackoverflow.com/questions/50066818/jq-reference-current-position-in-loop",
        "title": "jq- reference current position in loop"
    },
    {
        "tags": [
            "ansible",
            "jq",
            "aws-cli",
            "ansible-2.x"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 196383,
                    "reputation": 11705,
                    "user_id": 439790,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5f835bd73774acbc0c0ef33f5745ba0c?s=256&d=identicon&r=PG",
                    "display_name": "zigarn",
                    "link": "https://stackoverflow.com/users/439790/zigarn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1525155144,
                "post_id": 50109875,
                "comment_id": 87241303,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 353880,
                    "reputation": 11106,
                    "user_id": 691859,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/5333743a4b84fe403d8429a9eab75d94?s=256&d=identicon&r=PG",
                    "display_name": "2rs2ts",
                    "link": "https://stackoverflow.com/users/691859/2rs2ts"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1525195412,
                "post_id": 50109875,
                "comment_id": 87259395,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 353880,
                    "reputation": 11106,
                    "user_id": 691859,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/5333743a4b84fe403d8429a9eab75d94?s=256&d=identicon&r=PG",
                    "display_name": "2rs2ts",
                    "link": "https://stackoverflow.com/users/691859/2rs2ts"
                },
                "reply_to_user": {
                    "account_id": 196383,
                    "reputation": 11705,
                    "user_id": 439790,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5f835bd73774acbc0c0ef33f5745ba0c?s=256&d=identicon&r=PG",
                    "display_name": "zigarn",
                    "link": "https://stackoverflow.com/users/439790/zigarn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1525195461,
                "post_id": 50109875,
                "comment_id": 87259420,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 196383,
                    "reputation": 11705,
                    "user_id": 439790,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5f835bd73774acbc0c0ef33f5745ba0c?s=256&d=identicon&r=PG",
                    "display_name": "zigarn",
                    "link": "https://stackoverflow.com/users/439790/zigarn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1525196042,
                "post_id": 50109875,
                "comment_id": 87259712,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 196383,
                    "reputation": 11705,
                    "user_id": 439790,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5f835bd73774acbc0c0ef33f5745ba0c?s=256&d=identicon&r=PG",
                    "display_name": "zigarn",
                    "link": "https://stackoverflow.com/users/439790/zigarn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1525196530,
                "post_id": 50109875,
                "comment_id": 87259976,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 353880,
                    "reputation": 11106,
                    "user_id": 691859,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/5333743a4b84fe403d8429a9eab75d94?s=256&d=identicon&r=PG",
                    "display_name": "2rs2ts",
                    "link": "https://stackoverflow.com/users/691859/2rs2ts"
                },
                "reply_to_user": {
                    "account_id": 196383,
                    "reputation": 11705,
                    "user_id": 439790,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5f835bd73774acbc0c0ef33f5745ba0c?s=256&d=identicon&r=PG",
                    "display_name": "zigarn",
                    "link": "https://stackoverflow.com/users/439790/zigarn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1526066455,
                "post_id": 50109875,
                "comment_id": 87614579,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1526366261,
                "creation_date": 1526366261,
                "answer_id": 50343744,
                "question_id": 50109875,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The JSON content seems to be interpreted before sent to the stdin, so looks like simple quotes are sent (seen in verbose mode with `-vvv`):\r\n\r\n    &quot;stdin&quot;: &quot;{&#39;AutoScalingGroupARN&#39;: &#39;arn:aws:autoscaling:us-east-2:123456:autoScalin\r\n    gGroup:e75a213b-75fe-467c-8cf5-d7c51f76c471:autoScalingGroupName/myrole-dev&#39;, ...,\r\n     &#39;AvailabilityZones&#39;: [&#39;us-east-2a&#39;, &#39;us-east-2b&#39;, &#39;us-east-2c&#39;]}&quot;\r\n\r\nWhich is not JSON valid:\r\n\r\n    $ echo &quot;{&#39;AutoScalingGroupARN&#39;: &#39;arn:aws:autoscaling:us-east-2:123456:autoScalingGroup:e75a213b-75fe-467c-8cf5-d7c51f76c471:autoScalingGroupName/myrole-dev&#39;, &#39;HealthCheckGracePeriod&#39;: 300}&quot; | jq\r\n    parse error: Invalid numeric literal at line 1, column 23\r\n\r\n    $ echo &#39;{&quot;AutoScalingGroupARN&quot;: &quot;arn:aws:autoscaling:us-east-2:123456:autoScalingGroup:e75a213b-75fe-467c-8cf5-d7c51f76c471:autoScalingGroupName/myrole-dev&quot;, &quot;HealthCheckGracePeriod&quot;: 300}&#39; | jq\r\n    {\r\n      &quot;AutoScalingGroupARN&quot;: &quot;arn:aws:autoscaling:us-east-2:123456:autoScalingGroup:e75a213b-75fe-467c-8cf5-d7c51f76c471:autoScalingGroupName/myrole-dev&quot;,\r\n      &quot;HealthCheckGracePeriod&quot;: 300\r\n    }\r\n\r\nSo, you need to &quot;escape&quot; it.\r\nUnfortunately, the `to_json` filter, escape to much:\r\n\r\n    &quot;stdin&quot;: &quot;\\&quot;{\\\\\\&quot;AutoScalingGroupARN\\\\\\&quot;:\\\\\\&quot;arn:aws:autosca...\r\n\r\nBut the `string` filter fits perfectly:\r\n\r\n    &quot;stdin&quot;: &quot;{\\&quot;AutoScalingGroupARN\\&quot;:\\&quot;arn:aws:autosca...\r\n\r\n**So, the correct way with `stdin` is this**:\r\n\r\n    - shell: jq -r &#39;{{ stale_instance_filter }}&#39;\r\n      args:\r\n        stdin: &quot;{{ asgs_result.stdout | string }}&quot;",
                "title": "Probable quoting issue using the stdin argument of ansible&#39;s shell module"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1526366261,
        "creation_date": 1525133967,
        "last_edit_date": 1526066400,
        "question_id": 50109875,
        "body_markdown": "I&#39;ve got a playbook with the following tasks:\r\n\r\n    - set_fact:\r\n        asg_filter: &gt;\r\n          .AutoScalingGroups[] |\r\n          select(.Tags[] | select(.Key == &quot;Role&quot;).Value == &quot;myrole&quot;)\r\n    - shell: aws autoscaling --region us-west-2 describe-auto-scaling-groups | jq --compact-output &quot;{{ asg_filter }}&quot;\r\n      register: asgs_result\r\n    - set_fact:\r\n        stale_instance_filter: &gt;\r\n          .LaunchConfigurationName as $lc |\r\n          .Instances[] |\r\n          select(.LaunchConfigurationName != $lc) |\r\n          .InstanceId\r\n\r\nNow I want to use `stale_instance_filter` on `asgs_result.stdout`. The following works:\r\n\r\n    - shell: echo &#39;{{ asgs_result.stdout }}&#39; | jq -r &#39;{{ stale_instance_filter }}&#39;\r\n\r\nBut this doesn&#39;t:\r\n\r\n    - shell: jq -r &#39;{{ stale_instance_filter }}&#39;\r\n      args:\r\n        stdin: &quot;{{ asgs_result.stdout }}&quot;\r\n\r\nI get the following error message: `parse error: Invalid numeric literal at line 1, column 23` (which I believe is from the account number in the ARN for the ASG.) I think it&#39;s a quoting issue (maybe something about the double quotes in the JSON), but I&#39;ve also tried `asgs_result.stdout | quote` to no avail. I also tried the `command` module; it didn&#39;t help either. Of course this all works if I do it directly on the CLI.\r\n\r\nI realize I could combine the two `jq` filters but I want to reuse `asgs_result` for other things and don&#39;t want to have to make the query multiple times. How can I fix this so I can use the `stdin` argument?\r\n\r\nEdit: I was asked to provide an example of the value of asgs_result, well here you go, here&#39;s the `stdout` attribute in it (since I don&#39;t use anything else):\r\n\r\n    &quot;stdout&quot;: &quot;{\\&quot;AutoScalingGroupARN\\&quot;:\\&quot;arn:aws:autoscaling:us-east-2:123456:autoScalingGroup:e75a213b-75fe-467c-8cf5-d7c51f76c471:autoScalingGroupName/myrole-dev\\&quot;,\\&quot;TargetGroupARNs\\&quot;:[],\\&quot;SuspendedProcesses\\&quot;:[],\\&quot;DesiredCapacity\\&quot;:4,\\&quot;Tags\\&quot;:[{\\&quot;ResourceType\\&quot;:\\&quot;auto-scaling-group\\&quot;,\\&quot;ResourceId\\&quot;:\\&quot;myrole-dev\\&quot;,\\&quot;PropagateAtLaunch\\&quot;:true,\\&quot;Value\\&quot;:\\&quot;dev\\&quot;,\\&quot;Key\\&quot;:\\&quot;Dimension\\&quot;},{\\&quot;ResourceType\\&quot;:\\&quot;auto-scaling-group\\&quot;,\\&quot;ResouJceId\\&quot;:\\&quot;myrole-dev\\&quot;,\\&quot;PropagateAtLaunch\\&quot;:true,\\&quot;Value\\&quot;:\\&quot;true\\&quot;,\\&quot;Key\\&quot;:\\&quot;Monitored\\&quot;},{\\&quot;ResourceType\\&quot;:\\&quot;auto-scaling-group\\&quot;,\\&quot;ResourceId\\&quot;:\\&quot;myrole-dev\\&quot;,\\&quot;PropagateAtLaunch\\&quot;:true,\\&quot;Value\\&quot;:\\&quot;myrole\\&quot;,\\&quot;Key\\&quot;:\\&quot;Name\\&quot;},{\\&quot;ResourceType\\&quot;:\\&quot;auto-scaling-group\\&quot;,\\&quot;ResourceId\\&quot;:\\&quot;myrole-dev\\&quot;,\\&quot;PropagateAtLaunch\\&quot;:true,\\&quot;Value\\&quot;:\\&quot;myrole\\&quot;,\\&quot;Key\\&quot;:\\&quot;Role\\&quot;},{\\&quot;ResourceType\\&quot;:\\&quot;auto-scaling-group\\&quot;,\\&quot;ResourceId\\&quot;:\\&quot;myrole-dev\\&quot;,\\&quot;PropagateAtLaunch\\&quot;:true,\\&quot;Value\\&quot;:\\&quot;2035-09-30 18:55:31 +0000\\&quot;,\\&quot;Key\\&quot;:\\&quot;cleaner-destroy-after\\&quot;},{\\&quot;ResourceType\\&quot;:\\&quot;auto-scaling-group\\&quot;,\\&quot;ResourceId\\&quot;:\\&quot;myrole-dev\\&quot;,\\&quot;PropagateAtLaunch\\&quot;:true,\\&quot;Value\\&quot;:\\&quot;vpce-2c23ca45\\&quot;,\\&quot;Key\\&quot;:\\&quot;force_s3_endpoint_dependency\\&quot;},{\\&quot;ResourceType\\&quot;:\\&quot;auto-scaling-group\\&quot;,\\&quot;ResourceId\\&quot;:\\&quot;myrole-dev\\&quot;,\\&quot;PropagateAtLaunch\\&quot;:true,\\&quot;Value\\&quot;:\\&quot;owned\\&quot;,\\&quot;Key\\&quot;:\\&quot;kubernetes.io/cluster/dev\\&quot;}],\\&quot;EnabledMetrics\\&quot;:[],\\&quot;LoadBalancerNames\\&quot;:[],\\&quot;AutoScalingGroupName\\&quot;:\\&quot;myrole-dev\\&quot;,\\&quot;DefaultCooldown\\&quot;:300,\\&quot;MinSize\\&quot;:4,\\&quot;Instances\\&quot;:[{\\&quot;ProtectedFromScaleIn\\&quot;:false,\\&quot;AvailabilityZone\\&quot;:\\&quot;us-east-2b\\&quot;,\\&quot;InstanceId\\&quot;:\\&quot;i-0141fd35e3cf3ad0a\\&quot;,\\&quot;HealthStatus\\&quot;:\\&quot;Healthy\\&quot;,\\&quot;LifecycleState\\&quot;:\\&quot;InService\\&quot;,\\&quot;LaunchConfigurationName\\&quot;:\\&quot;dev_myrole_20180511171410107500000002\\&quot;},{\\&quot;ProtectedFromScaleIn\\&quot;:false,\\&quot;AvailabilityZone\\&quot;:\\&quot;us-east-2c\\&quot;,\\&quot;InstanceId\\&quot;:\\&quot;i-01aec2b3546d75190\\&quot;,\\&quot;HealthStatus\\&quot;:\\&quot;Healthy\\&quot;,\\&quot;LifecycleState\\&quot;:\\&quot;InService\\&quot;,\\&quot;LaunchConfigurationName\\&quot;:\\&quot;dev_myrole_20180511171410107500000002\\&quot;},{\\&quot;ProtectedFromScaleIn\\&quot;:false,\\&quot;AvailabilityZone\\&quot;:\\&quot;us-east-2a\\&quot;,\\&quot;InstanceId\\&quot;:\\&quot;i-0830b227f034d2859\\&quot;,\\&quot;HealthStatus\\&quot;:\\&quot;Healthy\\&quot;,\\&quot;LifecycleState\\&quot;:\\&quot;InService\\&quot;,\\&quot;LaunchConfigurationName\\&quot;:\\&quot;dev_myrole_20180511171410107500000002\\&quot;},{\\&quot;ProtectedFromScaleIn\\&quot;:false,\\&quot;AvailabilityZone\\&quot;:\\&quot;us-east-2b\\&quot;,\\&quot;InstanceId\\&quot;:\\&quot;i-0f7d847e8c168040b\\&quot;,\\&quot;HealthStatus\\&quot;:\\&quot;Healthy\\&quot;,\\&quot;LifecycleState\\&quot;:\\&quot;InService\\&quot;,\\&quot;LaunchConfigurationName\\&quot;:\\&quot;dev_myrole_20180511171410107500000002\\&quot;}],\\&quot;MaxSize\\&quot;:4,\\&quot;VPCZoneIdentifier\\&quot;:\\&quot;subnet-c348988e,subnet-79743210,subnet-156ee36e\\&quot;,\\&quot;HealthCheckGracePeriod\\&quot;:300,\\&quot;TerminationPolicies\\&quot;:[\\&quot;Default\\&quot;],\\&quot;LaunchConfigurationName\\&quot;:\\&quot;dev_myrole_20180511171410107500000002\\&quot;,\\&quot;CreatedTime\\&quot;:\\&quot;2018-02-20T22:35:32.183Z\\&quot;,\\&quot;AvailabilityZones\\&quot;:[\\&quot;us-east-2a\\&quot;,\\&quot;us-east-2b\\&quot;,\\&quot;us-east-2c\\&quot;],\\&quot;HealthCheckType\\&quot;:\\&quot;EC2\\&quot;,\\&quot;NewInstancesProtectedFromScaleIn\\&quot;:false}&quot;\r\n\r\nSorry that it is all on one line but I don&#39;t want to make anyone think there is a newline in there, because there isn&#39;t.",
        "link": "https://stackoverflow.com/questions/50109875/probable-quoting-issue-using-the-stdin-argument-of-ansibles-shell-module",
        "title": "Probable quoting issue using the stdin argument of ansible&#39;s shell module"
    }
]