[
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 12,
                "is_accepted": true,
                "score": 12,
                "last_activity_date": 1557088429,
                "last_edit_date": 1557088429,
                "creation_date": 1557087423,
                "answer_id": 55996042,
                "question_id": 55995980,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` itself is reading the first line, then `inputs` (having received that line as *its* input) will read the rest. Typically, you want to use the `-n` option to prevent `jq` from doing any reading itself, letting any `input` or `inputs` filters do the actual reading.\r\n\r\n    $ echo -n $&#39;line1\\nline2\\n&#39; | jq -nR &#39;inputs&#39;\r\n    &quot;line1&quot;\r\n    &quot;line2&quot;\r\n\r\nIn your case, letting `jq` read the header and `inputs` read the rest of the data is reasonable, but you have to *do* something with the header. This is probably more complicated than it needs to be, but does the job:\r\n\r\n    $ cat tmp.tsv\r\n    foo\tbar\tbaz\r\n    1\t2\t3\r\n    4\t5\t6\r\n    $ jq -R &#39;split(&quot;\\t&quot;) as $h | [inputs | split(&quot;\\t&quot;) | [{key: $h[0], value: .[0]}, {key: $h[1], value: .[1]}, {key: $h[2], value: .[2]}] | from_entries]&#39; tmp.tsv\r\n    [\r\n      {\r\n        &quot;foo&quot;: &quot;1&quot;,\r\n        &quot;bar&quot;: &quot;2&quot;,\r\n        &quot;baz&quot;: &quot;3&quot;\r\n      },\r\n      {\r\n        &quot;foo&quot;: &quot;4&quot;,\r\n        &quot;bar&quot;: &quot;5&quot;,\r\n        &quot;baz&quot;: &quot;6&quot;\r\n      }\r\n    ]\r\n\r\n`jq` reads the first line and splits it into the array `h`, then feeds that line to a filter which ignores it but uses `inputs` to read the rest of the lines, splitting each one up and creating a dict using (repeatedly) the value of `$h`.",
                "title": "Why does `inputs` skip the first line of the input file?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1557158958,
                "last_edit_date": 1557158958,
                "creation_date": 1557147453,
                "answer_id": 56005742,
                "question_id": 55995980,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "@chepner&#39;s explanation of `-n` is fine, but I&#39;d like to illustrate how `debug` can help clarify and/or demystify jq&#39;s behavior.\r\n\r\nSince every jq program is a filter, it is always possible to see what the input to any given filter is by prepending it with `debug`, so e.g.:\r\n\r\n    echo 1 2 3 | jq &#39;debug | inputs&#39;\r\n\r\nyields:\r\n\r\n    [&quot;DEBUG:&quot;,1]\r\n    2\r\n    3\r\n\r\nThat is, in this case, the input to `inputs` is 1, which is consumed by `inputs` and otherwise ignored.\r\n\r\nWe can similarly examine the effect of using the `-n` command-line option:\r\n\r\n\r\n    echo 1 2 3 | jq -n &#39;debug | inputs&#39;\r\n    [&quot;DEBUG:&quot;,null]\r\n    1\r\n    2\r\n    3\r\n\r\nThat is, we can now see that the `-n` option tells jq to provide `null` as the input to `inputs`, rather than obtaining it from STDIN.  \r\n\r\nIn short, `debug` is helpful not only for debugging, but also for DIY understanding.\r\n\r\n\r\n\r\n\r\n",
                "title": "Why does `inputs` skip the first line of the input file?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 10,
        "last_activity_date": 1557158958,
        "creation_date": 1557087009,
        "last_edit_date": 1557158788,
        "question_id": 55995980,
        "body_markdown": "Whenever I provide a file to jq and use the `inputs` command, I only get back all lines but the first one and I&#39;m wondering why is that\r\n\r\nI&#39;m currently using jq 1.6 and I&#39;m trying to use the `inputs` command to convert a TSV (Tab Separated Values) into JSON by grabbing the first line of the file as the headers and placing each header as the key of the corresponding value in the next lines\r\n\r\nIf I execute the following \r\n\r\n```bash \r\necho -n &#39;line1&#39;$&#39;\\n&#39;&#39;line2&#39; | jq -R &#39;inputs&#39;\r\n```\r\n\r\nThe result is \r\n```\r\nline2\r\n```\r\nand not\r\n```\r\nline1\r\nline2\r\n```\r\nas I&#39;d expect\r\n\r\nAs a workaround I&#39;m currently prepending a new line to the input i&#39;m giving to jq as in\r\n\r\n```\r\necho -n $&#39;\\n&#39;&#39;line1&#39;$&#39;\\n&#39;&#39;line2&#39; | jq -R &#39;inputs&#39;\r\n```\r\n\r\nbut my expectation is to be able to use `inputs` and have it process the first line",
        "link": "https://stackoverflow.com/questions/55995980/why-does-inputs-skip-the-first-line-of-the-input-file",
        "title": "Why does `inputs` skip the first line of the input file?"
    },
    {
        "tags": [
            "json",
            "count",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1129881,
                    "reputation": 12145,
                    "user_id": 1116230,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/55a894894150db28d6641f0c57e48bac?s=256&d=identicon&r=PG",
                    "display_name": "Nico Haase",
                    "link": "https://stackoverflow.com/users/1116230/nico-haase"
                },
                "edited": false,
                "score": 5,
                "creation_date": 1557128055,
                "post_id": 56000443,
                "comment_id": 98647761,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1557130279,
                "post_id": 56000443,
                "comment_id": 98648726,
                "content_license": "CC BY-SA 4.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": 1557146673,
                "post_id": 56000443,
                "comment_id": 98656454,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15880060,
                    "reputation": 23,
                    "user_id": 11458052,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-5HPijTpzlm4/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdAB9yixlPoY15qy_ffKyxGDseSMw/mo/s256-rj/photo.jpg",
                    "display_name": "Alex Tulio",
                    "link": "https://stackoverflow.com/users/11458052/alex-tulio"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1557183302,
                "post_id": 56000443,
                "comment_id": 98671526,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1557129627,
                "creation_date": 1557129627,
                "answer_id": 56001061,
                "question_id": 56000443,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I uploaded your json file to &quot;http://www.json-generator.com/api/json/get/cggsimUEBK?indent=2&quot; and the below code should give you the count. Just run this in your dev console.\r\n\r\n    function findCount(){  \r\n      var result = json.responseJSON;\r\n      var count=0;\r\n      result.forEach(function(item){\r\n       var impairments = item.impairments;\r\n         impairments.forEach(function(impairment){\r\n            if((impairment[&#39;name&#39;] == &quot;docsis-level&quot;)){ count++;}\r\n         });\r\n       });\r\n      console.log(count);\r\n      alert(count);  \r\n    }\r\n    var json = $.getJSON(&quot;http://www.json-generator.com/api/json/get/cggsimUEBK?indent=2&quot;,findCount);\r\n",
                "title": "count items w/ string"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1557187839,
                "last_edit_date": 1557187839,
                "creation_date": 1557146534,
                "answer_id": 56005509,
                "question_id": 56000443,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest way to count in jq is to use a function for that purpose:\r\n\r\n    def count(stream): reduce stream as $i (0; .+1);\r\n\r\nThis definition also supports solutions that are efficient with respect to both time and space.\r\n\r\nSince the JSON in the question is ill-formed, I&#39;ll propose two solutions - one based on objects with the &quot;impaired&quot; key:\r\n\r\n    count(.. | objects | select( has(&quot;impaired&quot;) and .name == &quot;docsis-level&quot;))\r\n\r\nand the other based on the &quot;impairments&quot; arrays:\r\n\r\n    count(.. | .impairments? // empty | .[] | select( .name? == &quot;docsis-level&quot;))\r\n\r\nThese two queries illustrate different styles of achieving varying degrees of robustness, but both are agnostic about where the pertinent objects reside in the input.\r\n\r\n## Addendum\r\n\r\nNow that the sample data has been revised, the following solution that depends on a regular structure can be offered:\r\n\r\n    count(.[] | .impairments[] | select( .name == &quot;docsis-level&quot;))",
                "title": "count items w/ string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -5,
        "last_activity_date": 1557187839,
        "creation_date": 1557127026,
        "last_edit_date": 1557187369,
        "question_id": 56000443,
        "body_markdown": "I need to count how many mac addresses have docsis-level impairments\r\n\r\nI&#39;ve tried to work around this filter from another example in this website but the problem is i need to count how many mac address has an impairment name of &quot;docsis-level&quot;\r\n\r\n```\r\n[\r\n  {\r\n    &quot;mac&quot;: &quot;BC:2E:48:D7:E6:EF&quot;,\r\n    &quot;timestamp&quot;: &quot;2019-05-06T06:06:13.568Z&quot;,\r\n    &quot;impairments&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;level&quot;,\r\n        &quot;impaired&quot;: true,\r\n        &quot;startFrequency&quot;: 76.279,\r\n        &quot;stopFrequency&quot;: 953.721,\r\n        &quot;level&quot;: 52.4\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;tilt&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 123,\r\n        &quot;stopFrequency&quot;: 795,\r\n        &quot;level&quot;: 8.28\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;roll-off&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 699,\r\n        &quot;stopFrequency&quot;: 795,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;suck-out&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 0,\r\n        &quot;stopFrequency&quot;: 0,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;peak&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 0,\r\n        &quot;stopFrequency&quot;: 0,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ripple&quot;,\r\n        &quot;impaired&quot;: true,\r\n        &quot;startFrequency&quot;: 119.932,\r\n        &quot;stopFrequency&quot;: 798.037,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;fm-ingress&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 0,\r\n        &quot;stopFrequency&quot;: 0,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;lte-ingress&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 0,\r\n        &quot;stopFrequency&quot;: 0,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;adjacency&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 179.982,\r\n        &quot;stopFrequency&quot;: 186.018,\r\n        &quot;level&quot;: 1.3\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-snr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 141.025,\r\n        &quot;stopFrequency&quot;: 141.025,\r\n        &quot;level&quot;: 33.7\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-level&quot;,\r\n        &quot;impaired&quot;: true,\r\n        &quot;startFrequency&quot;: 639.014,\r\n        &quot;stopFrequency&quot;: 639.014,\r\n        &quot;level&quot;: 27.47\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-tilt&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 165.107,\r\n        &quot;stopFrequency&quot;: 165.107,\r\n        &quot;level&quot;: 1.21\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-icfr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 752.803,\r\n        &quot;stopFrequency&quot;: 752.803,\r\n        &quot;level&quot;: 6.4\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-guard-band&quot;,\r\n        &quot;impaired&quot;: true,\r\n        &quot;startFrequency&quot;: 531.025,\r\n        &quot;stopFrequency&quot;: 531.025,\r\n        &quot;level&quot;: -32.33\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;correctable-cer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 603,\r\n        &quot;stopFrequency&quot;: 603,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;uncorrectable-cer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 603,\r\n        &quot;stopFrequency&quot;: 603,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;docsis-snr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 639,\r\n        &quot;stopFrequency&quot;: 639,\r\n        &quot;level&quot;: 38.9\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;docsis-level&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 633,\r\n        &quot;stopFrequency&quot;: 633,\r\n        &quot;level&quot;: 7.8\r\n      }\r\n    ],\r\n    &quot;ofdmData&quot;: {\r\n      &quot;numChannels&quot;: 0,\r\n      &quot;numProfiles&quot;: 0\r\n    }\r\n  },\r\n  {\r\n    &quot;mac&quot;: &quot;BC:2E:48:D7:EA:24&quot;,\r\n    &quot;timestamp&quot;: &quot;2019-05-06T06:06:13.536Z&quot;,\r\n    &quot;impairments&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;level&quot;,\r\n        &quot;impaired&quot;: true,\r\n        &quot;startFrequency&quot;: 76.279,\r\n        &quot;stopFrequency&quot;: 953.721,\r\n        &quot;level&quot;: 52.6\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;tilt&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 123,\r\n        &quot;stopFrequency&quot;: 795,\r\n        &quot;level&quot;: 8.69\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;roll-off&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 699,\r\n        &quot;stopFrequency&quot;: 795,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;suck-out&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 0,\r\n        &quot;stopFrequency&quot;: 0,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;peak&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 0,\r\n        &quot;stopFrequency&quot;: 0,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ripple&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 0,\r\n        &quot;stopFrequency&quot;: 0,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;fm-ingress&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 0,\r\n        &quot;stopFrequency&quot;: 0,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;lte-ingress&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 0,\r\n        &quot;stopFrequency&quot;: 0,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;adjacency&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 179.982,\r\n        &quot;stopFrequency&quot;: 186.018,\r\n        &quot;level&quot;: 1.4\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-snr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 141.025,\r\n        &quot;stopFrequency&quot;: 141.025,\r\n        &quot;level&quot;: 36.1\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-level&quot;,\r\n        &quot;impaired&quot;: true,\r\n        &quot;startFrequency&quot;: 639.014,\r\n        &quot;stopFrequency&quot;: 639.014,\r\n        &quot;level&quot;: 27.46\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-tilt&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 687.002,\r\n        &quot;stopFrequency&quot;: 687.002,\r\n        &quot;level&quot;: 0.65\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-icfr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 392.861,\r\n        &quot;stopFrequency&quot;: 392.861,\r\n        &quot;level&quot;: 5.4\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-guard-band&quot;,\r\n        &quot;impaired&quot;: true,\r\n        &quot;startFrequency&quot;: 507.061,\r\n        &quot;stopFrequency&quot;: 507.061,\r\n        &quot;level&quot;: -32.9\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;correctable-cer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 693,\r\n        &quot;stopFrequency&quot;: 693,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;uncorrectable-cer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 693,\r\n        &quot;stopFrequency&quot;: 693,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;docsis-snr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 651,\r\n        &quot;stopFrequency&quot;: 651,\r\n        &quot;level&quot;: 39.3\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;docsis-level&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 651,\r\n        &quot;stopFrequency&quot;: 651,\r\n        &quot;level&quot;: 8\r\n      }\r\n    ],\r\n    &quot;ofdmData&quot;: {\r\n      &quot;numChannels&quot;: 0,\r\n      &quot;numProfiles&quot;: 0\r\n    }\r\n  },\r\n  {\r\n    &quot;mac&quot;: &quot;B0:39:56:4B:B2:38&quot;,\r\n    &quot;timestamp&quot;: &quot;2019-05-06T05:05:34Z&quot;,\r\n    &quot;impairments&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;channel-snr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-level&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-tilt&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-icfr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-guard-band&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;correctable-cer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;uncorrectable-cer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;docsis-snr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 645,\r\n        &quot;stopFrequency&quot;: 645,\r\n        &quot;level&quot;: 39\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;docsis-level&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: -5.9\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-mer-mean&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 38.85\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-mer-sd&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.58\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-mean&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.02\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-rms&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.4\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-slope&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: -0.013\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-pk-pk&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 2.93\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-mean&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 1778\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-rms&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 17.26\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-slope&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.029\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-pk-pk&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 86.79\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-plc-cwer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-ncp-fail&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0\r\n      }\r\n    ],\r\n    &quot;ofdmData&quot;: {\r\n      &quot;numChannels&quot;: 1,\r\n      &quot;numProfiles&quot;: 4\r\n    }\r\n  },\r\n  {\r\n    &quot;mac&quot;: &quot;B0:39:56:4C:BF:40&quot;,\r\n    &quot;timestamp&quot;: &quot;2019-05-06T05:05:34Z&quot;,\r\n    &quot;impairments&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;channel-snr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-level&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-tilt&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-icfr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-guard-band&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;correctable-cer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;uncorrectable-cer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;docsis-snr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 675,\r\n        &quot;stopFrequency&quot;: 675,\r\n        &quot;level&quot;: 39.9\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;docsis-level&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 615,\r\n        &quot;stopFrequency&quot;: 615,\r\n        &quot;level&quot;: 6.9\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-mer-mean&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 40.07\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-mer-sd&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.58\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-mean&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: -0.03\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-rms&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.39\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-slope&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.002\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-pk-pk&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 2.06\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-mean&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 1882\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-rms&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 9.14\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-slope&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.032\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-pk-pk&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 62.88\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-plc-cwer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-ncp-fail&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0\r\n      }\r\n    ],\r\n    &quot;ofdmData&quot;: {\r\n      &quot;numChannels&quot;: 1,\r\n      &quot;numProfiles&quot;: 4\r\n    }\r\n  },\r\n  {\r\n    &quot;mac&quot;: &quot;A0:04:60:FC:8F:90&quot;,\r\n    &quot;timestamp&quot;: &quot;2019-05-06T05:05:34Z&quot;,\r\n    &quot;impairments&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;channel-snr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 669,\r\n        &quot;stopFrequency&quot;: 669,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-level&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 669,\r\n        &quot;stopFrequency&quot;: 669,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-tilt&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 669,\r\n        &quot;stopFrequency&quot;: 669,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-icfr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 669,\r\n        &quot;stopFrequency&quot;: 669,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-guard-band&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 669,\r\n        &quot;stopFrequency&quot;: 669,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;correctable-cer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 669,\r\n        &quot;stopFrequency&quot;: 669,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;uncorrectable-cer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 669,\r\n        &quot;stopFrequency&quot;: 669,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;docsis-snr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 645,\r\n        &quot;stopFrequency&quot;: 645,\r\n        &quot;level&quot;: 39.3\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;docsis-level&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 609,\r\n        &quot;stopFrequency&quot;: 609,\r\n        &quot;level&quot;: 12.4\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-mer-mean&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 39.84\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-mer-sd&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.58\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-mean&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: -0.03\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-rms&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.42\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-slope&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.011\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-pk-pk&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 2.37\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-mean&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 1807\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-rms&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 9.49\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-slope&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.027\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-pk-pk&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 65.65\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-plc-cwer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-ncp-fail&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0\r\n      }\r\n    ],\r\n    &quot;ofdmData&quot;: {\r\n      &quot;numChannels&quot;: 1,\r\n      &quot;numProfiles&quot;: 4\r\n    }\r\n  },\r\n  {\r\n    &quot;mac&quot;: &quot;B0:DA:F9:11:CD:25&quot;,\r\n    &quot;timestamp&quot;: &quot;2019-05-06T05:05:34Z&quot;,\r\n    &quot;impairments&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;channel-snr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-level&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-tilt&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-icfr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-guard-band&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;correctable-cer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;uncorrectable-cer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 663,\r\n        &quot;stopFrequency&quot;: 663,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;docsis-snr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 645,\r\n        &quot;stopFrequency&quot;: 645,\r\n        &quot;level&quot;: 37.9\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;docsis-level&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: -11.1\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-mer-mean&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 37.58\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-mer-sd&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.63\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-mean&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: -0.03\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-rms&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.49\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-slope&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: -0.013\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-pk-pk&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 3.21\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-mean&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 1839\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-rms&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 17.59\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-slope&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.027\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-pk-pk&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 95.32\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-plc-cwer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-ncp-fail&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0\r\n      }\r\n    ],\r\n    &quot;ofdmData&quot;: {\r\n      &quot;numChannels&quot;: 1,\r\n      &quot;numProfiles&quot;: 4\r\n    }\r\n  },\r\n  {\r\n    &quot;mac&quot;: &quot;D4:0A:A9:00:00:F1&quot;,\r\n    &quot;timestamp&quot;: &quot;2019-05-06T05:05:34Z&quot;,\r\n    &quot;impairments&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;channel-snr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 621,\r\n        &quot;stopFrequency&quot;: 621,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-level&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 621,\r\n        &quot;stopFrequency&quot;: 621,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-tilt&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 621,\r\n        &quot;stopFrequency&quot;: 621,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-icfr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 621,\r\n        &quot;stopFrequency&quot;: 621,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-guard-band&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 621,\r\n        &quot;stopFrequency&quot;: 621,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;correctable-cer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 621,\r\n        &quot;stopFrequency&quot;: 621,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;uncorrectable-cer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 621,\r\n        &quot;stopFrequency&quot;: 621,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;docsis-snr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 639,\r\n        &quot;stopFrequency&quot;: 639,\r\n        &quot;level&quot;: 37.3\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;docsis-level&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 615,\r\n        &quot;stopFrequency&quot;: 615,\r\n        &quot;level&quot;: 11.6\r\n      }\r\n    ],\r\n    &quot;ofdmData&quot;: {\r\n      &quot;numChannels&quot;: 0,\r\n      &quot;numProfiles&quot;: 0\r\n    }\r\n  },\r\n  {\r\n    &quot;mac&quot;: &quot;B0:39:56:4B:B1:F8&quot;,\r\n    &quot;timestamp&quot;: &quot;2019-05-06T05:05:34Z&quot;,\r\n    &quot;impairments&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;channel-snr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 669,\r\n        &quot;stopFrequency&quot;: 669,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-level&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 669,\r\n        &quot;stopFrequency&quot;: 669,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-tilt&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 669,\r\n        &quot;stopFrequency&quot;: 669,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-icfr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 669,\r\n        &quot;stopFrequency&quot;: 669,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;channel-guard-band&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 669,\r\n        &quot;stopFrequency&quot;: 669,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;correctable-cer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 669,\r\n        &quot;stopFrequency&quot;: 669,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;uncorrectable-cer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 669,\r\n        &quot;stopFrequency&quot;: 669,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;docsis-snr&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 675,\r\n        &quot;stopFrequency&quot;: 675,\r\n        &quot;level&quot;: 39.4\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;docsis-level&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 4.4\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-mer-mean&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 39.44\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-mer-sd&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.61\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-mean&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: -0.13\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-rms&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.72\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-slope&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.004\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-amp-pk-pk&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 3.42\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-mean&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 1851\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-rms&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 8.59\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-slope&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0.026\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-gd-pk-pk&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 58.58\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-plc-cwer&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ofdm-ncp-fail&quot;,\r\n        &quot;impaired&quot;: false,\r\n        &quot;startFrequency&quot;: 811,\r\n        &quot;stopFrequency&quot;: 904.95,\r\n        &quot;level&quot;: 0\r\n      }\r\n    ],\r\n    &quot;ofdmData&quot;: {\r\n      &quot;numChannels&quot;: 1,\r\n      &quot;numProfiles&quot;: 4\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nCount of mac with docsis-level = x number",
        "link": "https://stackoverflow.com/questions/56000443/count-items-w-string",
        "title": "count items w/ string"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1557226350,
                "last_edit_date": 1557226350,
                "creation_date": 1557225312,
                "answer_id": 56020680,
                "question_id": 56020478,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To supress errors use `... ?` operator, which is a shorthand for `try ...`. For example:\r\n&lt;pre&gt;\r\n&lt;code&gt;reduce (paths|select(.[-1]|endswith(&quot;Timestamp&quot;)&lt;/code&gt;&lt;b&gt;?&lt;/b&gt;&lt;code&gt;)) as $p\r\n(.; setpath($p; getpath($p)/1000|todate))&lt;/code&gt;\r\n&lt;/pre&gt;",
                "title": "jq: setpaths with regex on paths, how to handle paths that end with an integer which produce an error?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1557236258,
                "creation_date": 1557236258,
                "answer_id": 56023935,
                "question_id": 56020478,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For this type of problem, `walk/1` is often convenient:\r\n\r\n    def timestamps:\r\n      with_entries(if .key | endswith(&quot;Timestamp&quot;)\r\n                   then .value |= (./1000 | todate) else . end);\r\n\r\n    walk( if type == &quot;object&quot; then timestamps else . end )\r\n\r\n## As a one-liner\r\nIf you want a one-liner:\r\n\r\n    walk( if type == &quot;object&quot; then with_entries(if .key | endswith(&quot;Timestamp&quot;) then .value |= (./1000 | todate) else . end) else . end)\r\n\r\nIf your jq allows the `else .` to be omitted, this becomes a bit more digestible: \r\n\r\n    walk(if type == &quot;object&quot; then with_entries(if .key | endswith(&quot;Timestamp&quot;) then .value |= (./1000 | todate) end) end)\r\n\r\n\r\n\r\n",
                "title": "jq: setpaths with regex on paths, how to handle paths that end with an integer which produce an error?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1557236258,
        "creation_date": 1557224552,
        "last_edit_date": 1557226720,
        "question_id": 56020478,
        "body_markdown": "I have the following object:\r\n```\r\n{\r\n  &quot;domainId&quot;: &quot;hidden&quot;,\r\n  &quot;lastUsed&quot;: &quot;Thu Oct 04 2018&quot;,\r\n  &quot;lastUsedTimestamp&quot;: 1538673002460,\r\n  &quot;users&quot;: [\r\n    {\r\n      &quot;userId&quot;: &quot;hidden&quot;,\r\n      &quot;lastUsedTimestamp&quot;: 1538673002460\r\n    },\r\n    {\r\n      &quot;userId&quot;: &quot;hidden&quot;,\r\n      &quot;lastUsedTimestamp&quot;: 1536087726701\r\n    },\r\n    {\r\n      &quot;userId&quot;: &quot;hidden&quot;,\r\n      &quot;lastUsedTimestamp&quot;: 1536086675399\r\n    },\r\n    {\r\n      &quot;userId&quot;: &quot;hidden&quot;,\r\n      &quot;lastUsedTimestamp&quot;: 1536182646984\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to convert all `lastUsedTimestamp` values to a date. This works with:\r\n```\r\nreduce (paths | select(.[-1] == &quot;lastUsedTimestamp&quot;)) as $p \r\n  (.;setpath($p; getpath($p) / 1000 | todate))\r\n```\r\n\r\nBut what if I had other timestamp keys such as `createdTimestamp` or `startTimestamp` in other places of the object? For instance:\r\n\r\n```\r\n{\r\n  &quot;domainId&quot;: &quot;hidden&quot;,\r\n  &quot;lastUsed&quot;: &quot;Thu Oct 04 2018&quot;,\r\n  &quot;lastUsedTimestamp&quot;: 1538673002460,\r\n  &quot;users&quot;: [\r\n    {\r\n      &quot;userId&quot;: &quot;hidden&quot;,\r\n      &quot;lastUsedTimestamp&quot;: 1538673002460\r\n    },\r\n    {\r\n      &quot;userId&quot;: &quot;hidden&quot;,\r\n      &quot;lastUsedTimestamp&quot;: 1536087726701\r\n    },\r\n    {\r\n      &quot;userId&quot;: &quot;hidden&quot;,\r\n      &quot;lastUsedTimestamp&quot;: 1536086675399,\r\n      &quot;createdTimestamp&quot;: 1536086675399\r\n    },\r\n    {\r\n      &quot;userId&quot;: &quot;hidden&quot;,\r\n      &quot;lastUsedTimestamp&quot;: 1536182646984,\r\n      &quot;startTimestamp&quot;: 1536182646984\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI tried\r\n```\r\nreduce (paths | select(.[-1] | endswith(&quot;Timestamp&quot;)) as $p \r\n  (.;setpath($p; getpath($p) / 1000 | todate))\r\n```\r\nor an equivalent with `test` but paths that end with an integer make it fail.\r\n\r\nHow can I work around this?",
        "link": "https://stackoverflow.com/questions/56020478/jq-setpaths-with-regex-on-paths-how-to-handle-paths-that-end-with-an-integer-w",
        "title": "jq: setpaths with regex on paths, how to handle paths that end with an integer which produce an error?"
    },
    {
        "tags": [
            "jq",
            "ansible-inventory"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1557239175,
                "post_id": 56024745,
                "comment_id": 98693309,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1557359117,
                "creation_date": 1557359117,
                "answer_id": 56050384,
                "question_id": 56024745,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you are searching for items found in the `._meta.hostvars` object, you can filter the objects by key/value by using something like `with_entries/1`.\r\n\r\n    $ jq &#39;._meta.hostvars | with_entries(select(.value.ansible_host | not))\r\n    &#39; prod-inventory_201905070920.json\r\n\r\nThis will in effect take the `hostvars` object and only keep properties that match that condition (does not have an `ansible_host` property value).",
                "title": "Printing objects without ansible_host"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1557359117,
        "creation_date": 1557238896,
        "question_id": 56024745,
        "body_markdown": "I&#39;m trying to use jq to process JSON from the VMware Ansible inventory module so I can produce a list of objects (VMs) that don&#39;t have ansible_host defined.\r\n\r\nThe closest I&#39;ve been able to get is:\r\n```\r\n{\r\n  &quot;config.cpuHotAddEnabled&quot;: true,\r\n  &quot;config.cpuHotRemoveEnabled&quot;: false,\r\n  &quot;config.hardware.numCPU&quot;: 1,\r\n  &quot;config.instanceUuid&quot;: &quot;500e4e98-50ec-a3a7-9d45-b0ac36c2d192&quot;,\r\n  &quot;config.name&quot;: &quot;tu-openldap-01&quot;,\r\n  &quot;config.template&quot;: false,\r\n  &quot;guest.guestId&quot;: &quot;rhel6_64Guest&quot;,\r\n  &quot;guest.guestState&quot;: &quot;notRunning&quot;,\r\n  &quot;guest.hostName&quot;: &quot;tu-openldap-01&quot;,\r\n  &quot;guest.ipAddress&quot;: null,\r\n  &quot;name&quot;: &quot;tu-openldap-01&quot;,\r\n  &quot;runtime.maxMemoryUsage&quot;: 2048\r\n}\r\n{\r\n  &quot;config.cpuHotAddEnabled&quot;: true,\r\n  &quot;config.cpuHotRemoveEnabled&quot;: false,\r\n  &quot;config.hardware.numCPU&quot;: 1,\r\n  &quot;config.instanceUuid&quot;: &quot;500efaa5-baac-163b-65c0-7ed2a19f1d7d&quot;,\r\n  &quot;config.name&quot;: &quot;tu1vcm7tst2001&quot;,\r\n  &quot;config.template&quot;: false,\r\n  &quot;guest.guestId&quot;: &quot;rhel7_64Guest&quot;,\r\n  &quot;guest.guestState&quot;: &quot;running&quot;,\r\n  &quot;guest.hostName&quot;: &quot;rhel7-template&quot;,\r\n  &quot;guest.ipAddress&quot;: null,\r\n  &quot;name&quot;: &quot;tu1vcm7tst2001&quot;,\r\n  &quot;runtime.maxMemoryUsage&quot;: 4096\r\n}\r\n```\r\nusing the following:\r\n```\r\njq &#39;._meta.hostvars[] | select(.ansible_host | not)&#39; prod-inventory_201905070920.json\r\n```\r\n\r\nThis is almost where I want it, but the problem is how do I print these plus the key for the object itself?\r\n\r\nIf I do:\r\n```\r\njq &#39;._meta.hostvars | select(.ansible_host | not)&#39; prod-inventory_201905070920.json\r\n```\r\n\r\nI get these:\r\n```\r\n&quot;tw1pttest1001_420e92f4-453e-1267-4331-d6253d771882&quot;: {\r\n    &quot;ansible_host&quot;: &quot;&lt;omitted&gt;&quot;,\r\n    &quot;config.cpuHotAddEnabled&quot;: true,\r\n    &quot;config.cpuHotRemoveEnabled&quot;: false,\r\n    &quot;config.hardware.numCPU&quot;: 2,\r\n    &quot;config.instanceUuid&quot;: &quot;500ef630-16c1-cb91-be9c-e9e667b551d9&quot;,\r\n    &quot;config.name&quot;: &quot;tw1pttest1001&quot;,\r\n    &quot;config.template&quot;: false,\r\n    &quot;guest.guestId&quot;: &quot;windows9Server64Guest&quot;,\r\n    &quot;guest.guestState&quot;: &quot;running&quot;,\r\n    &quot;guest.hostName&quot;: &quot;&lt;omitted&gt;&quot;,\r\n    &quot;guest.ipAddress&quot;: &quot;&lt;omitted&gt;&quot;,\r\n    &quot;name&quot;: &quot;tw1pttest1001&quot;,\r\n    &quot;runtime.maxMemoryUsage&quot;: 49152\r\n  },\r\n  &quot;tw1swsrm1001_420e18d2-0c96-0df5-e6c7-1ff8fc070cdb&quot;: {\r\n    &quot;ansible_host&quot;: &quot;&lt;omitted&gt;&quot;,\r\n    &quot;config.cpuHotAddEnabled&quot;: true,\r\n    &quot;config.cpuHotRemoveEnabled&quot;: false,\r\n    &quot;config.hardware.numCPU&quot;: 4,\r\n    &quot;config.instanceUuid&quot;: &quot;500e231d-1eda-4e66-3f4a-8c68392a70b5&quot;,\r\n    &quot;config.name&quot;: &quot;tw1swsrm1001&quot;,\r\n    &quot;config.template&quot;: false,\r\n    &quot;guest.guestId&quot;: &quot;windows9Server64Guest&quot;,\r\n    &quot;guest.guestState&quot;: &quot;running&quot;,\r\n    &quot;guest.hostName&quot;: &quot;&lt;omitted&gt;&quot;,\r\n    &quot;guest.ipAddress&quot;: &quot;&lt;omitted&gt;&quot;,\r\n    &quot;name&quot;: &quot;tw1swsrm1001&quot;,\r\n    &quot;runtime.maxMemoryUsage&quot;: 16384\r\n  },\r\n```\r\nAny suggestions?  I feel like it&#39;s something simple that I&#39;m missing.",
        "link": "https://stackoverflow.com/questions/56024745/printing-objects-without-ansible-host",
        "title": "Printing objects without ansible_host"
    },
    {
        "tags": [
            "nuget",
            "version",
            "artifactory",
            "jq",
            "jfrog-cli"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1559585416,
                "last_edit_date": 1559585416,
                "creation_date": 1557245372,
                "answer_id": 56026596,
                "question_id": 56024932,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use jq to sort version number strings.\r\n\r\nIf the strings are &quot;raw&quot; strings, one per line, then you could use this jq program:\r\n\r\n    def parse:\r\n     sub(&quot;alpha&quot;; &quot;alpha.&quot;)\r\n     | sub(&quot;beta&quot;; &quot;beta.&quot;) \r\n     | sub(&quot;gamma&quot;; &quot;gamma.&quot;)\r\n     | sub(&quot;prerelease&quot;; &quot;prerelease.&quot;)\r\n     | sub(&quot;debug&quot;); &quot;debug.&quot;)\r\n     | [splits(&quot;[-.]&quot;)]\r\n     | map(tonumber? // .) ;\r\n     \r\n    [inputs]\r\n    | sort_by(parse)[]\r\n\r\nThis jq program could be run like so:\r\n\r\n    jq -nrR -f program.jq versions.txt\r\n\r\nWith the sample version numbers, this would produce:\r\n\r\n```\r\n1.2.3.95\r\n1.2.3.99\r\n1.2.3.99-beta9\r\n1.2.3.99-beta10\r\n1.2.3.101\r\n1.2.3.103\r\n```\r\n\r\nIn your case, the result can be achieved without invoking jq a second time by modifying your program to use `parse` along the lines shown above.  The main part of the jq program would probably look something like this:\r\n\r\n    map(.props[&quot;nuget.version&quot;]) | sort_by(parse)[]\r\n\r\n(Of course the -n option is only needed when using `inputs` to read.)\r\n\r\n## Highest version number\r\n\r\nIf (as indicated in a comment is the case) you just want the highest version number, you could simply change the final `[]` to `[-1]`:\r\n\r\n    ... | sort_by(parse)[-1]",
                "title": "How to sort Artifactory package search result by version number with JFrog CLI?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1559585416,
        "creation_date": 1557239516,
        "last_edit_date": 1557306736,
        "question_id": 56024932,
        "body_markdown": "I need to get the **latest version** of a specific NuGet package in **Artifactory**.\r\nI use following JFrog CLI command to receive a list of all versions (later on with `--limit=1`), including JSON parsing with jq:\r\n\r\n    jfrog rt s myRepo/Path/ --props &quot;nuget.id=MyLib&quot; --sort-by=name --sort-order=desc  | jq -M -r &quot;.[] | .props.\\&quot;nuget.version\\&quot; | .[]&quot;\r\n\r\nThe above example results in raw string output like this:\r\n\r\n    1.2.3.101\r\n    1.2.3.103\r\n    1.2.3.95\r\n    1.2.3.99\r\n    1.2.3.99-beta10\r\n    1.2.3.99-beta9\r\n\r\nMy **target** is to get an output **sorted by version**:\r\n\r\n    1.2.3.95\r\n    1.2.3.99\r\n    1.2.3.99-beta9\r\n    1.2.3.99-beta10\r\n    1.2.3.101\r\n    1.2.3.103\r\n\r\nUnfortunately I can **not** use `--sort-by=created` as it can differ from version-sorting. Even if I do not use `--sort-by`option it does not work. Also the version numbers can contain letters like &quot;-beta&quot;.\r\n\r\nIn the Artifactory TreeView it is correct, but not in CLI.\r\n\r\nHow can I get a result sorted-by version number?",
        "link": "https://stackoverflow.com/questions/56024932/how-to-sort-artifactory-package-search-result-by-version-number-with-jfrog-cli",
        "title": "How to sort Artifactory package search result by version number with JFrog CLI?"
    },
    {
        "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": 1557251736,
                "post_id": 56027278,
                "comment_id": 98699700,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1557250326,
                "last_edit_date": 1557250326,
                "creation_date": 1557249808,
                "answer_id": 56027665,
                "question_id": 56027278,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. You need to expand arrays to access elements in them,\r\n2. You don&#39;t need sed at all.\r\n```\r\n$ jq -r &#39;.[].result.&quot;*value*&quot;[] | select(.Score.English) | &quot;Name: \\(.name)&quot;, &quot;Subject: \\(.Score.English)&quot;&#39; file\r\nName: ABC\r\nSubject: A+\r\nName: CDE\r\nSubject: A-\r\n```",
                "title": "jq filtering - Cannot index array with string &quot;Score&quot;"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1557250015,
                "creation_date": 1557250015,
                "answer_id": 56027708,
                "question_id": 56027278,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**EFG** **Score** is of length 0 that probably doesn&#39;t help :\r\n\r\n    &quot;sessionId&quot;: &quot;000001&quot;,\r\n    &quot;name&quot;: &quot;EFG&quot;,\r\n    &quot;Age&quot;: &quot;21&quot;,\r\n    &quot;Score&quot;: {}\r\n\r\nSo it chokes when trying to evaluate :\r\n\r\n    Subject: .result.&quot;*value*&quot;.Score.English ",
                "title": "jq filtering - Cannot index array with string &quot;Score&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1557358705,
        "creation_date": 1557248109,
        "last_edit_date": 1557251410,
        "question_id": 56027278,
        "body_markdown": "I am trying to find person name who has a subject and it score.\r\nBut i am getting index array.\r\nThis problem is different then other questions asked on Stackoverflow because it throws error for the parameter which is not in [] but in {}\r\n\r\n    jq -r &#39;.[] | select(.result.&quot;*value*&quot;.Score.English) | {Name: .result.&quot;*value*&quot;.name, Subject: .result.&quot;*value*&quot;.Score.English} | @text&#39; test.txt | sed &#39;s/^{\\|}$//g; s/,/\\n/&#39;\r\n\r\nINPUT JSON FILE\r\n\r\n    [{\r\n        &quot;host&quot;: &quot;testserver&quot;,\r\n        &quot;hostclass&quot;: &quot;Unknown&quot;,\r\n        &quot;result&quot;: {\r\n            &quot;*value*&quot;: [\r\n                {\r\n                    &quot;sessionId&quot;: &quot;000001&quot;,\r\n                    &quot;name&quot;: &quot;ABC&quot;,\r\n                    &quot;Age&quot;: &quot;21&quot;,\r\n                    &quot;Score&quot;: {\r\n                        &quot;English&quot;: &quot;A+&quot;,\r\n                        &quot;Mathematics&quot;: &quot;B-&quot;,\r\n                        &quot;String Theory&quot;: &quot;C+&quot;\r\n                    }\r\n                },\r\n                {\r\n                    &quot;sessionId&quot;: &quot;000001&quot;,\r\n                    &quot;name&quot;: &quot;CDE&quot;,\r\n                    &quot;Age&quot;: &quot;21&quot;,\r\n                    &quot;Score&quot;: {\r\n                        &quot;English&quot;: &quot;A-&quot;,\r\n                        &quot;German&quot;: &quot;B-&quot;,\r\n                        &quot;French&quot;: &quot;C+&quot;\r\n                    }\r\n                },\r\n                {\r\n                    &quot;sessionId&quot;: &quot;000001&quot;,\r\n                    &quot;name&quot;: &quot;EFG&quot;,\r\n                    &quot;Age&quot;: &quot;21&quot;,\r\n                    &quot;Score&quot;: {\r\n                    }\r\n                },\r\n                {\r\n                    &quot;sessionId&quot;: &quot;000001&quot;,\r\n                    &quot;name&quot;: &quot;XYZ&quot;,\r\n                    &quot;Age&quot;: &quot;21&quot;\r\n                }]\r\n       }\r\n    }]\r\n\r\nOUTPUT :\r\n\r\n    Name: ABC\r\n    Subject : A+\r\n    Name: CDE\r\n    Subject : A-\r\n\r\nERROR :\r\n\r\n    jq: error (at test.txt:39): Cannot index array with string &quot;Score&quot;\r\n\r\nhow can i fix this error?",
        "link": "https://stackoverflow.com/questions/56027278/jq-filtering-cannot-index-array-with-string-score",
        "title": "jq filtering - Cannot index array with string &quot;Score&quot;"
    },
    {
        "tags": [
            "json",
            "select",
            "slice",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1557254889,
                "post_id": 56028679,
                "comment_id": 98701100,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1293673,
                    "reputation": 551,
                    "user_id": 1245281,
                    "user_type": "registered",
                    "accept_rate": 45,
                    "profile_image": "https://www.gravatar.com/avatar/3f7090013f74882b3e4dd1279e51110c?s=256&d=identicon&r=PG",
                    "display_name": "RedBullet",
                    "link": "https://stackoverflow.com/users/1245281/redbullet"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1557255521,
                "post_id": 56028679,
                "comment_id": 98701375,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1606494824,
                "last_edit_date": 1606494824,
                "creation_date": 1557255910,
                "answer_id": 56029019,
                "question_id": 56028679,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want the result as an array, you could use `map`:\r\n\r\n    .dashboards | map(select(.type==&quot;standard&quot;)) | .[0:10]\r\n\r\nHowever, this is inefficient. For efficiency, it would be better to use `limit` as discussed below.\r\n\r\nIf you wanted the items as a stream, you could write:\r\n\r\n    limit(10; .dashboards[] | select(.type==&quot;standard&quot;))\r\n\r\n If you want the results as an array, simply wrap the above jq expression in square brackets.\r\n\r\n",
                "title": "how to filter array and slice results with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1606494824,
        "creation_date": 1557254360,
        "last_edit_date": 1557283171,
        "question_id": 56028679,
        "body_markdown": "Suppose I have the following data:\r\n```\r\n{\r\n   &quot;dashboards&quot;: [\r\n     {\r\n       &quot;name&quot;: &quot;first&quot;,\r\n       &quot;type&quot;: &quot;standard&quot;\r\n     },\r\n     {\r\n       &quot;name&quot;: &quot;second&quot;,\r\n       &quot;type&quot;: &quot;custom&quot;\r\n     }\r\n   ]\r\n}\r\n```\r\n(actually there&#39;s a lot more data than that, I am just showing what the structure of the data is)\r\n\r\nWhat I am trying to do is get the first 10 dashboards of type `standard`.\r\n\r\nI know I can get *all* the `standard` dashboards with:\r\n`jq &#39;.dashboards[] | select(.type == &quot;standard&quot;)&#39;`\r\n\r\nBut I can&#39;t figure out how to slice the resulting array...",
        "link": "https://stackoverflow.com/questions/56028679/how-to-filter-array-and-slice-results-with-jq",
        "title": "how to filter array and slice results with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1557283812,
                "creation_date": 1557283812,
                "answer_id": 56032866,
                "question_id": 56032762,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s assume the objects with &quot;Action&quot; keys are in an array.  Then you could sort the &quot;Action&quot; values that are arrays by writing:\r\n\r\n    map( .Action |= (if type==&quot;array&quot; then sort else . end) )\r\n\r\n\r\nOr if you want to ensure that `.Action` is always array-valued:\r\n\r\n    map( .Action |= (if type==&quot;array&quot; then sort else [.] end) )\r\n\r\n\r\n## .Statement\r\n\r\nSo you&#39;ll probably want to write something like:\r\n\r\n    jq &#39;.Statement[].Action |= (if type == &quot;array&quot; then sort else . end)&#39; file.json \r\n",
                "title": "How to convert intermittent string elements in a json to arrays using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1557293222,
        "creation_date": 1557282936,
        "last_edit_date": 1557293222,
        "question_id": 56032762,
        "body_markdown": "I have an IAM policy with Statement.Action elements that are both arrays and strings depending on the number of entries within them. \r\n\r\nFor example there are some such as \r\n \r\n\r\n        {\r\n            &quot;Sid&quot;: &quot;Name1&quot;,\r\n            &quot;Effect&quot;: &quot;Allow&quot;,\r\n            &quot;Action&quot;: [\r\n                &quot;logs:GetLogEvents&quot;,\r\n                &quot;ecs:DeleteCluster&quot;,\r\n                &quot;logs:PutRetentionPolicy&quot;,\r\n                &quot;logs:PutLogEvents&quot;,\r\n                &quot;s3:GetReplicationConfiguration&quot;\r\n            ],\r\n           &quot;Resource&quot;: &quot;arn:aws:cognito-idp:*:*:userpool/*&quot;,\r\n            &quot;Condition&quot;: {\r\n                &quot;ForAllValues:StringEquals&quot;: {\r\n                    &quot;aws:ResourceTag/VendorType&quot;: &quot;ABC&quot;\r\n                }\r\n            }\r\n        },\r\n\r\nand also Statement.Action elements such as\r\n\r\n        {\r\n            &quot;Sid&quot;: &quot;Name2&quot;,\r\n            &quot;Effect&quot;: &quot;Allow&quot;,\r\n            &quot;Action&quot;: &quot;cognito-identity:DeleteIdentityPool&quot;,\r\n            &quot;Resource&quot;: &quot;arn:aws:cognito-identity:*:*:identitypool/*&quot;,\r\n            &quot;Condition&quot;: {\r\n                &quot;ForAllValues:StringEquals&quot;: {\r\n                    &quot;aws:ResourceTag/VendorType&quot;: &quot;ABC&quot;\r\n                }\r\n            }\r\n        },\r\n\r\n\r\nEssentially i want to be able to sort the elements under Action.\r\n\r\nHowever since some of the Action items are string and not arrays when running the following command \r\n\r\n```\r\njq &#39;.Statement[].Action|=(. // [] | sort)&#39; file.json \r\n```\r\n\r\nI get an error \r\n\r\n```\r\njq: error (at file.json:277): string (&quot;cognito-id...) cannot be sorted, as it is not an array\r\n```\r\n\r\nThis is resolved if all Statement[].Action elements were in arrays and some weren&#39;t strings. \r\n\r\nSo if i change the above erroring entry in the json to the following it solved the problem.\r\n\r\n        {\r\n            &quot;Sid&quot;: &quot;Name2&quot;,\r\n            &quot;Effect&quot;: &quot;Allow&quot;,\r\n            &quot;Action&quot;: [\r\n                &quot;cognito-identity:DeleteIdentityPool&quot;\r\n            ],\r\n            &quot;Resource&quot;: &quot;arn:aws:cognito-identity:*:*:identitypool/*&quot;,\r\n            &quot;Condition&quot;: {\r\n                &quot;ForAllValues:StringEquals&quot;: {\r\n                    &quot;aws:ResourceTag/VendorType&quot;: &quot;ABC&quot;\r\n                }\r\n            }\r\n        },\r\n\r\n\r\nwhat combination of jq commands could i use to have entries where Statement[].Action is a string and not an array be converted to an array such as the above so i can then run sort on elements inside it.\r\n\r\nThanks for your help",
        "link": "https://stackoverflow.com/questions/56032762/how-to-convert-intermittent-string-elements-in-a-json-to-arrays-using-jq",
        "title": "How to convert intermittent string elements in a json to arrays using jq"
    },
    {
        "tags": [
            "reactjs",
            "compilation",
            "jq",
            "yarnpkg",
            "toplevel"
        ],
        "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": 1557371957,
                "post_id": 56051594,
                "comment_id": 98744447,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "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": 1557372222,
                "post_id": 56051594,
                "comment_id": 98744497,
                "content_license": "CC BY-SA 4.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"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1557372466,
                "post_id": 56051594,
                "comment_id": 98744553,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1557372730,
                "last_edit_date": 1557372730,
                "creation_date": 1557372353,
                "answer_id": 56051748,
                "question_id": 56051594,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The shell variables should be passed to jq in a more robust manner, e.g. along these lines:\r\n\r\n```\r\n\r\njq -c --arg city &quot;$city&quot; \\\r\n      --arg medium &quot;$medium&quot; \\\r\n      --arg direction &quot;$direction&quot; \\\r\n      --arg date &quot;$date&quot; \\\r\n      --arg time &quot;$time&quot; \\\r\n   &#39;.[$city][$medium][$direction][$date] += [$time]&#39;\r\n```\r\n\r\nAs @OguzIsmail points out, though, you would probably be better off avoiding all the messiness by doing everything with just `find` and `jq`.",
                "title": "jq: 1 compile error jq: error: schedule/0 is not defined at &lt;top-level&gt;, line 1: .Christchurch.bus-schedule.from[&quot;Weekday&quot;] |= . + [&quot;1646&quot;]"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1557524272,
        "creation_date": 1557370877,
        "last_edit_date": 1557524272,
        "question_id": 56051594,
        "body_markdown": "I have a react application which uses a .sh file to generate a part of the application. But I have come across an error which prevents the application from reading the data files.\r\n\r\nI&#39;ve looked at versioning, possible syntax changes in the .sh file which is `emap.sh`\r\n\r\n\r\n\r\nThis is the `.sh` file\r\n\r\n    #!/bin/bash\r\n    object=&#39;{}&#39;\r\n\r\n    find &#39;public/data&#39; -type f -name &#39;*.csv&#39; | while read -r filename;\r\n    do\r\n        filename=$(echo &quot;$filename&quot; | sed &#39;s/public\\/data\\///&#39; | sed &#39;s/ /\\//&#39;)\r\n        city=$(echo &quot;$filename&quot; | cut -d&#39;/&#39; -f1)\r\n        medium=$(echo &quot;$filename&quot; | cut -d&#39;/&#39; -f2)\r\n        direction=$(echo &quot;$filename&quot; | cut -d&#39;/&#39; -f3)\r\n        date=$(echo &quot;$filename&quot; | cut -d&#39;/&#39; -f4)\r\n        time=$(echo &quot;$filename&quot; | cut -d&#39;/&#39; -f5| head -c-5)\r\n        object=$(echo $object | jq -c &quot;.$city.$medium.$direction[\\&quot;$date\\&quot;] |= . + [\\&quot;$time\\&quot;]&quot;)\r\n        echo $object &gt; public/available.json\r\n    done\r\n\r\nIt should be successful so that when we yarn the application, it shows up having read the data, but we get a page without data in the area using the information that needs to be processed.",
        "link": "https://stackoverflow.com/questions/56051594/jq-1-compile-error-jq-error-schedule-0-is-not-defined-at-top-level-line-1",
        "title": "jq: 1 compile error jq: error: schedule/0 is not defined at &lt;top-level&gt;, line 1: .Christchurch.bus-schedule.from[&quot;Weekday&quot;] |= . + [&quot;1646&quot;]"
    },
    {
        "tags": [
            "json",
            "sh",
            "jq",
            "grafana",
            "prometheus"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1557809890,
                "creation_date": 1557809890,
                "answer_id": 56123269,
                "question_id": 56063869,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your data looks like it has a carriage return (the &#39;/r&#39;) character at the end of the line. jq is expecting a float value, which the parsed value is not, as it has this character added.\r\n\r\nhttps://stackoverflow.com/questions/1761051/difference-between-n-and-r",
                "title": "How to solve this error in prometheus ktext format parsing error in line 1: expected float as value, got &quot;41584\\r&quot;"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1557809890,
        "creation_date": 1557419457,
        "question_id": 56063869,
        "body_markdown": "when I pass the parameters from a sh to my server prometheus shows the error, the data I get from a json\r\n\r\nmy sh\r\n\r\n```bash\r\n#!/bin/bash\r\nREPORT=C:/gauge2/gauge/reports/json-report\r\nFILE=$REPORT/result.json     \r\n\r\n# Validate &amp; push the metrics\r\nif [ -f $FILE ]; then\r\n   echo &quot;File $FILE exists.&quot;\r\n   cat $REPORT/result.json | \\\r\n    # Extract a nice json from last report\r\n    jq -r &#39;.projectName as $project |.environment as $env | .specResults[] |&quot;ngt_lambda_qa {env=\\&quot;\\($env)\\&quot;, spec=\\&quot;\\(.specHeading|gsub(&quot;\\&quot;&quot;;&quot;\\\\\\&quot;&quot;))\\&quot;, result=\\&quot;\\(.executionStatus)\\&quot;} \\(.executionTime)&quot;&#39; | \\\r\n\r\n    # Send to the metric server\r\n    curl -v --data-binary @- localhost:9091/metrics/job/prometheus\r\n    name=`uname -n`\r\n    timestamp=`date +%s`\r\n    result=`jq -r &#39;.executionStatus&#39; $REPORT/result.json`\r\n    echo &quot;prometrics_exec{name=\\&quot;$name\\&quot;, result=\\&quot;$result\\&quot;} $timestamp&quot; | curl --data-binary @- localhost:9091/metrics/prueba\r\nelse\r\n   echo &quot;File $FILE does not exist.&quot;\r\nfi\r\nsleep 90\r\n```",
        "link": "https://stackoverflow.com/questions/56063869/how-to-solve-this-error-in-prometheus-ktext-format-parsing-error-in-line-1-expe",
        "title": "How to solve this error in prometheus ktext format parsing error in line 1: expected float as value, got &quot;41584\\r&quot;"
    },
    {
        "tags": [
            "json",
            "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": 1557424532,
                "post_id": 56064996,
                "comment_id": 98770036,
                "content_license": "CC BY-SA 4.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": 1557424623,
                "post_id": 56064996,
                "comment_id": 98770086,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1266843,
                    "reputation": 100730,
                    "user_id": 1223975,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://i.sstatic.net/lpyoU.jpg?s=256",
                    "display_name": "Alexander Mills",
                    "link": "https://stackoverflow.com/users/1223975/alexander-mills"
                },
                "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": 1557424765,
                "post_id": 56064996,
                "comment_id": 98770149,
                "content_license": "CC BY-SA 4.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": 1557424800,
                "post_id": 56064996,
                "comment_id": 98770166,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1557424493,
                "creation_date": 1557424493,
                "answer_id": 56065046,
                "question_id": 56064996,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nkbc get pods -o=json | jq -r &#39;.items[].name&#39;\r\n```\r\n\r\nUsing `-r` tells jq to write *raw* output, thus without quoting the names as JSON strings.",
                "title": "For each item in an array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1557424773,
        "creation_date": 1557424309,
        "last_edit_date": 1557424773,
        "question_id": 56064996,
        "body_markdown": "Say I have this command:\r\n\r\n    kbc get pods -o=json | jq -c \r\n\r\nwhich gives me something like:\r\n\r\n    {&quot;apiVersion&quot;:&quot;v1&quot;,&quot;items&quot;:[{&quot;name&quot;:&quot;a&quot;},{&quot;name&quot;:&quot;b&quot;},{&quot;name&quot;:&quot;c&quot;}]}\r\n\r\n\r\nhow can I echo the name for each element in the items array? Something like this:\r\n\r\n    kbc get pods -o=json | jq -c | jq &#39;.items[].name&#39; | cat",
        "link": "https://stackoverflow.com/questions/56064996/for-each-item-in-an-array-using-jq",
        "title": "For each item in an array using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1557434427,
                "last_edit_date": 1557434427,
                "creation_date": 1557428192,
                "answer_id": 56065939,
                "question_id": 56065822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re expanding `values_over_time` twice, thus 3 * 3 = 9 outputs are generated. Do something like this instead:\r\n```\r\n.[] | .key + &quot; &quot; + (.values_over_time.buckets[] | &quot;\\(.key_as_string) \\(.doc_count)&quot;)\r\n```\r\n\r\nCompare these two commands to see the difference clearly:\r\n```\r\n$ jq -nc &#39;[1,2,3] | [.[]*.[]]&#39;\r\n[1,2,3,2,4,6,3,6,9]\r\n```\r\n```\r\n$ jq -nc &#39;[1,2,3] | [.[]|.*.]&#39;\r\n[1,4,9]\r\n```",
                "title": "unexpected loop cycles with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1557430342,
                "creation_date": 1557430342,
                "answer_id": 56066383,
                "question_id": 56065822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The technical reason is that you&#39;re combining expressions that generate multiple results. And the way jq operates, it will generate results for every combination of those subexpressions.\r\n\r\nLooking at your filter and your input, here&#39;s how many results are generated by each subexpression:\r\n\r\n    (.[].key + &quot; &quot; + .[].values_over_time[][].key_as_string) + &quot; &quot; + (.[].values_over_time[][].doc_count|tostring)\r\n    (1         1     3)                                        1     (3                                 | 1)\r\n    (1 * 1 * 3 = 3)                                            1     (3 * 1 = 3)\r\n     3 * 1 * 3 = 9\r\n\r\nThis is why you must _always_ take care in using expressions that generate multiple results (e.g., `[]`).\r\n\r\nAs Oguz points out, you need to write it such that the input is expanded only once in the expression. Usually right at the beginning of the filter is best.\r\n\r\nThis could be done in many ways, I would write it like so:\r\n\r\n    .[] | &quot;\\(.key) \\(.values_over_time.buckets[] | &quot;\\(.key_as_string) \\(.doc_count)&quot;)&quot;\r\n    1   |   (1)     (3                           |   (1)               (1))\r\n    1   |   (1)     (3                           | 1 * 1 = 1)\r\n    1   |   (1)     (3 * 1 = 3)\r\n    1   | (1 * 3 = 3)\r\n    1 * 3 = 3",
                "title": "unexpected loop cycles with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1557461498,
        "creation_date": 1557427769,
        "last_edit_date": 1557461498,
        "question_id": 56065822,
        "body_markdown": "I&#39;m trying to print a table in bash to stdout from json with `jq`:\r\n```javascript\r\n[\r\n    {\r\n      &quot;key&quot;: &quot;name&quot;,\r\n      &quot;doc_count&quot;: 1000,\r\n      &quot;values_over_time&quot;: {\r\n        &quot;buckets&quot;: [\r\n          {\r\n            &quot;key_as_string&quot;: &quot;2019-05-01 11:00:00.000&quot;,\r\n            &quot;key&quot;: 1556708400000,\r\n            &quot;doc_count&quot;: 50\r\n          },\r\n          {\r\n            &quot;key_as_string&quot;: &quot;2019-05-02 12:00:00.000&quot;,\r\n            &quot;key&quot;: 1556798400000,\r\n            &quot;doc_count&quot;: 40\r\n          },\r\n          {\r\n            &quot;key_as_string&quot;: &quot;2019-05-02 13:00:00.000&quot;,\r\n            &quot;key&quot;: 1556802000000,\r\n            &quot;doc_count&quot;: 30\r\n          }\r\n        ]\r\n      }\r\n    }\r\n]\r\n```\r\n\r\nWith `jq -r &#39;(.[].key + &quot; &quot; + .[].values_over_time[][].key_as_string) + &quot; &quot; + (.[].values_over_time[][].doc_count|tostring)&#39;` I get these results:\r\n\r\n```\r\n&quot;name 2019-05-01 11:00:00.000 50&quot;\r\n&quot;name 2019-05-02 12:00:00.000 50&quot;\r\n&quot;name 2019-05-02 13:00:00.000 50&quot;\r\n&quot;name 2019-05-01 11:00:00.000 40&quot;\r\n&quot;name 2019-05-02 12:00:00.000 40&quot;\r\n&quot;name 2019-05-02 13:00:00.000 40&quot;\r\n&quot;name 2019-05-01 11:00:00.000 30&quot;\r\n&quot;name 2019-05-02 12:00:00.000 30&quot;\r\n&quot;name 2019-05-02 13:00:00.000 30&quot;\r\n```\r\n\r\nThere is something strange with additional loop level as I expect to see only 3 lines:\r\n```\r\n&quot;name 2019-05-01 11:00:00.000 50&quot;\r\n&quot;name 2019-05-02 12:00:00.000 40&quot;\r\n&quot;name 2019-05-02 13:00:00.000 30&quot;\r\n```\r\n\r\nRead `jq` docs but wasn&#39;t able to understand the right way to iterate in a proper in a neat way. Do you have any clues? \r\n\r\n[JQplay code sample][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/d9Lo9Wu--y",
        "link": "https://stackoverflow.com/questions/56065822/unexpected-loop-cycles-with-jq",
        "title": "unexpected loop cycles with jq"
    },
    {
        "tags": [
            "json",
            "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": 1557503143,
                "post_id": 56080834,
                "comment_id": 98800015,
                "content_license": "CC BY-SA 4.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": 1557503212,
                "post_id": 56080834,
                "comment_id": 98800042,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1557503183,
                "creation_date": 1557503183,
                "answer_id": 56080945,
                "question_id": 56080834,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Put `.` in the spot where you want your input data to be. In that case, that&#39;s as the value for which the `root` string is a key.\r\n\r\n```\r\njq &#39;{&quot;root&quot;: .}&#39; &lt;&lt;&lt;&#39;{&quot;option1&quot;: true}&#39;\r\n```\r\n\r\n...properly emits:\r\n\r\n```none\r\n{\r\n  &quot;root&quot;: {\r\n    &quot;option1&quot;: true\r\n  }\r\n}\r\n```",
                "title": "How can I insert a parent element to my json with jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1561040100,
                "last_edit_date": 1561040100,
                "creation_date": 1557504732,
                "answer_id": 56081300,
                "question_id": 56080834,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "let me offer you an alternative approach, using a walk-path based unix utility **[`jtc`][1]**:\r\n\r\n    bash $  jtc -u&#39;[^0]&#39; -T&#39;{ &quot;root&quot;: {} }&#39; -f file.json \r\n    bash $ \r\n    bash $ jtc file.json \r\n    {\r\n       &quot;root&quot;: {\r\n          &quot;option1&quot;: true\r\n       }\r\n    }\r\n    bash $ \r\n\r\nThe changes applied right into the file (`-f` ensures that)\r\n\r\nUPDATE: with the latest `jtc` version, template functionality has been extended, so for the same example to work, a slight change of template is required (`{}` needs to be spelled as `{{}}`):\r\n\r\n    bash $ jtc -u&#39;[^0]&#39; -T&#39;{&quot;root&quot;: {{}} }&#39; file.json\r\n    {\r\n       &quot;root&quot;: {\r\n          &quot;option1&quot;: true\r\n       }\r\n    }\r\n    bash $ \r\n\r\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` tool\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n\r\n\r\n",
                "title": "How can I insert a parent element to my json with jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1673277223,
                "creation_date": 1673277223,
                "answer_id": 75059297,
                "question_id": 56080834,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "How about plain `echo` and `cat`?\r\n\r\n`echo &quot;{\\&quot;root\\&quot;:$(cat file.json)}&quot; | jq`",
                "title": "How can I insert a parent element to my json with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1673277223,
        "creation_date": 1557502757,
        "last_edit_date": 1557504245,
        "question_id": 56080834,
        "body_markdown": "I want to insert new root element on my json with jq, my goal is to manipulate json hierarchy by adding one level before root one:\r\n\r\njson example:\r\n\r\n```json\r\n{\r\n &quot;option1&quot;:true\r\n}\r\n```\r\n\r\ni want to obtain:\r\n\r\n```json\r\n{\r\n &quot;root&quot;:\r\n {\r\n  &quot;option1&quot;:true\r\n }\r\n}\r\n```\r\n\r\nbut when i do:\r\n\r\n`$ echo &#39;{&quot;option1&quot;:true}&#39; | jq -r &#39;. + {&quot;root&quot;}&#39;`\r\n\r\nit inserts the element at the first level, and not before it:\r\n\r\n```json\r\n{\r\n &quot;root&quot;:null\r\n &quot;option1&quot;:true\r\n}\r\n```\r\n\r\nIs it even possible ?",
        "link": "https://stackoverflow.com/questions/56080834/how-can-i-insert-a-parent-element-to-my-json-with-jq",
        "title": "How can I insert a parent element to my json with jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "zsh"
        ],
        "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": 1557509864,
                "post_id": 56081494,
                "comment_id": 98802986,
                "content_license": "CC BY-SA 4.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": 1557509967,
                "post_id": 56081494,
                "comment_id": 98803037,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1611213897,
                "last_edit_date": 1611213897,
                "creation_date": 1557506743,
                "answer_id": 56081748,
                "question_id": 56081494,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can output each email-ID pair as a comma separated list from JQ, and use read them into variables in a while loop like so:\r\n```\r\nwhile IFS=&#39;,&#39; read -r email id; do\r\n  echo &quot;$email&quot;\r\n  echo &quot;$id&quot;\r\ndone &lt;&lt;EOF\r\n$(jq -r &#39;.values[] | &quot;\\(.email),\\(.id)&quot;&#39; file)\r\nEOF\r\n```",
                "title": "Extract values from JSON objects and assign them to shell variables in a loop"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1557605077,
                "last_edit_date": 1557605077,
                "creation_date": 1557547259,
                "answer_id": 56087066,
                "question_id": 56081494,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the variables don&#39;t have embedded carriage returns, you can save yourself a lot of IFS grief by having separate `read` commands for each variable, e.g.:\r\n\r\n    jq -r &#39;.values[] | (.email, .id)&#39;  input.json |\r\n    while IFS= read -r email ; do\r\n\t    IFS= read -r id \r\n        echo &quot;email=$email and id=$id&quot;\r\n    done\r\n\r\n",
                "title": "Extract values from JSON objects and assign them to shell variables in a loop"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1662426035,
        "creation_date": 1557505557,
        "last_edit_date": 1662426035,
        "question_id": 56081494,
        "body_markdown": "I am using `jq` like below to parse a json file - \r\n\r\nThe json file looks something like - \r\n\r\n    {\r\n      &quot;values&quot;: [\r\n        {\r\n          &quot;email&quot;: &quot;user1@domain.com&quot;,\r\n          &quot;id&quot;: &quot;USER1_ID&quot;\r\n        },{\r\n          &quot;email&quot;: &quot;user2@domain.com&quot;,\r\n          &quot;id&quot;: &quot;USER2_ID&quot;\r\n        },\r\n        .\r\n    ]\r\n    }\r\n\r\nI am able to print/ iterate through the ids like below\r\n    \r\n    for k in $(cat input.json | jq .values | jq .[].id); do\r\n        echo $k\r\n    done\r\n\r\nThis prints each individual id as expected.\r\n\r\nHowever, what I want is to access both the email and the id in the loop. \r\n\r\nI tried to assign values to SHELL variables like below - \r\n\r\n    emails=$(cat input.json | jq .values | jq .[].email)\r\n    ids=$(cat input.json | jq .values | jq .[].id)\r\n\r\nThis could work for the most part but `ids` can have spaces too which is breaking this. \r\n\r\nI could essentially have to 2 for loops one for `email` and the other for `id` and assign values to arrays in the loop\r\n\r\n \r\n\r\n       i=0\r\n        for k in $(cat input.json | jq .values | jq .[].id); do\r\n                ids[$i]=$k\r\n                i=$(($i +1)) \r\n            done\r\n\r\nand \r\n\r\n    i=0\r\n    for k in $(cat input.json | jq .values | jq .[].email); do\r\n            emails[$i]=$k\r\n            i=$(($i +1)) \r\n        done\r\n\r\nOnce I have both the values in arrays, I could parallely traverse both of them.\r\n\r\nI am not a shell expert so I wanted to know if there is any slick way of doing this with fewer loops/ lines of code.\r\n\r\nThanks for any help!",
        "link": "https://stackoverflow.com/questions/56081494/extract-values-from-json-objects-and-assign-them-to-shell-variables-in-a-loop",
        "title": "Extract values from JSON objects and assign them to shell variables in a loop"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1557734667,
                "last_edit_date": 1557734667,
                "creation_date": 1557734163,
                "answer_id": 56107945,
                "question_id": 56107616,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`man jq`:\r\n&gt; #..  \r\n&gt; Short-hand for recurse without arguments. This is intended to resemble the XPath `//` operator.  Note  that `..a`  does  not work; use `..|a` instead. In the example below we use `..|.a?` to find all the values of object keys &quot;a&quot; in any object found &quot;below&quot; `.`.\r\n&gt;\r\n    jq &#39;..|.a?&#39;\r\n       [[{&quot;a&quot;:1}]]\r\n    =&gt; 1\r\n\r\nAll you need to do is tweaking the example above a bit to suppress `null`s:\r\n``` lang-none\r\n$ jq &#39;..|(.text?)//empty&#39; file\r\nFound On:\r\nName of component\r\nThe Problem:\r\nDescription of the problem\r\n```",
                "title": "How can I get the values ​of all the specified properties in JSON by using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1557735680,
        "creation_date": 1557732741,
        "last_edit_date": 1557733892,
        "question_id": 56107616,
        "body_markdown": "I am new to jq and facing an issue while parsing my JSON\r\nI have a JSON like this\r\n\r\n```\r\n{\r\n  &quot;content&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;paragraph&quot;,\r\n      &quot;content&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;text&quot;,\r\n          &quot;text&quot;: &quot;Found On:&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;text&quot;,\r\n          &quot;text&quot;: &quot;Name of component&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;paragraph&quot;,\r\n      &quot;content&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;text&quot;,\r\n          &quot;text&quot;: &quot;The Problem:&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;paragraph&quot;,\r\n          &quot;content&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;text&quot;,\r\n              &quot;text&quot;: &quot;Description of the problem&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nWhat I want to get values of all “text” attributes. However, it can be seen that this JSON is a multi-layered nested structure.\r\nSo how could I achieve my\r\nexpected result:\r\n```\r\nFound On:\r\nName of component\r\nThe Problem:\r\nDescription of the problem\r\n```",
        "link": "https://stackoverflow.com/questions/56107616/how-can-i-get-the-values-of-all-the-specified-properties-in-json-by-using-jq",
        "title": "How can I get the values ​of all the specified properties in JSON by using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7188211,
                    "reputation": 122,
                    "user_id": 5489512,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/1h7LV.jpg?s=256",
                    "display_name": "gameshack_",
                    "link": "https://stackoverflow.com/users/5489512/gameshack"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1557746506,
                "post_id": 56108239,
                "comment_id": 98856122,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1557759452,
                "last_edit_date": 1557759452,
                "creation_date": 1557753229,
                "answer_id": 56113138,
                "question_id": 56108239,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "let me offer you an alternative solution - using a walk-path based unix utility **[`jtc`][1]**:\r\n\r\nbased, on your desired output, with `jtc` the query would look like:\r\n\r\n    bash $ &lt;file.json jtc -w&#39;[description]:&lt;.*; Since version.*&gt;R: [-1] &lt;act&gt;k [-1] &lt;path&gt;k [-1] &lt;pathname&gt;k&#39; -T&#39;{ &quot;path&quot;: [ {{pathname}}, {{path}}, {{act}}], &quot;version&quot;: { &quot;description&quot;: {{$0}}} }&#39;\r\n    {\r\n       &quot;path&quot;: [\r\n          &quot;paths&quot;,\r\n          &quot;/v4/config/info/defaults&quot;,\r\n          &quot;get&quot;\r\n       ],\r\n       &quot;version&quot;: {\r\n          &quot;description&quot;: &quot;SomeText; Since version 4.6.0 SomeMoreText&quot;\r\n       }\r\n    }\r\n    {\r\n       &quot;path&quot;: [\r\n          &quot;paths&quot;,\r\n          &quot;/v4/config/info/general&quot;,\r\n          &quot;get&quot;\r\n       ],\r\n       &quot;version&quot;: {\r\n          &quot;description&quot;: &quot;SomeText; Since version 4.6.0 SomeMoreText&quot;\r\n       }\r\n    }\r\n    {\r\n       &quot;path&quot;: [\r\n          &quot;GeneralSettings&quot;,\r\n          &quot;properties&quot;,\r\n          &quot;s3TagsEnabled&quot;\r\n       ],\r\n       &quot;version&quot;: {\r\n          &quot;description&quot;: &quot;Defines if S3 tags are enabled; Since version 4.9.0 NEW&quot;\r\n       }\r\n    }\r\n    bash $ \r\n\r\nGiven your Json is irregular (w.r.t walking `description` requirement) not sure, though if you need to see that last object or not. If you don&#39;t need it, then knowing the structure of your JSON it&#39;s easy to enhance the query to rule out false positive matches like that last one.\r\n\r\nEDIT:\r\nExplanations:\r\n\r\n`-T` option provides a Json template, where template items (enclosed into double curly braces `{{..}}`) get interpolated from the namespaces at the end of each walk (`-w`) if the walk was successful.\r\n\r\nNow the walk-path (`-w`) is the way to walk the source JSON: `jtc` let walking the Json up and down freely (using subscripts `[..]`) and performing recursive searches `&lt;..&gt;`. Though some of the items are `directives` - they don&#39;t do any searching/matching, instead they apply certain actions (the one-letter suffix in this notation `&lt;..&gt;S` defines whether it&#39;s a search or a directive)\r\n\r\nLet me break it down here (btw, all the lexemes are described in the link):\r\n\r\n- `[description]:&lt;.*; Since version.*&gt;R:` - performs an RE search of JSON strings containing `; Since version`, but due to RE spelling matches entire such string (note `.*` at the beginning and at the end of the RE expression). Now attached label `[description]:` ensures that such RE matching would occur only in those strings with the attached label (and not any others). `:` at the end  of the lexeme (aka quantifier) instructs to find all such occurrences (the quantifiers in both searches and subscripts compatible with Python notation).\r\n- `[-1]&lt;act&gt;k` - `[-1]` address a parent node of the found entry (from the previous walk step), and `&lt;act&gt;k` memorizes entry&#39;s label in the namespace `act` (for later template interpolation) - the suffix at the end of the search lexeme defines wether it&#39;s a search or a directive (in this case `k` is a directive to extract a label and memorize in the namespace)\r\n- the reset of the walk path is the same: `[-1]&lt;path&gt;k` will address a parent from the last found entry (which, in turn a parent of the found entry in the 1st step) and will memorize in the namespace its label (key) under the name `path` ( names are arbitrary in `jtc`)\r\n- `[-1]&lt;pathname&gt;k&#39;` - does pretty much the same thing, then the walk is over (well, for given iteration - if you recall the first walk lexeme is iterative -it finds each occurrence) and then template-interpolation is applied, which result in the printed item.\r\n\r\nYou can easily play with the query (removing each lexeme or adding yours, seeing how walking works) - I edited up the lexeme path breaking each lexemes with the spaces.\r\n\r\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` tool\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n",
                "title": "Need to filter all key/value pairs where the value contains a specific substring"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1557759452,
        "creation_date": 1557735321,
        "last_edit_date": 1557747320,
        "question_id": 56108239,
        "body_markdown": "I try to filter a JSON file for all &quot;description&quot; keys containing the value &quot;; Since version&quot; to print their path and the Version contained within that value. I do all this in a bash script.\r\n\r\nThe JSON I&#39;m filtering is from an API and has the &quot;description&quot; key on different paths.\r\n\r\nHere&#39;s an excerpt from the JSON the server\r\n\r\nSo far I grab the JSON from the server with curl and pipe it to jq applying the following filter to get a list of all paths which contain the value in their description: \r\n\r\n```curl $api | jq &#39;paths(objects and (.description|index(&quot;; Since version&quot;)))&#39;```\r\n\r\nThis returns a list with paths to the endpoints containing the searched value and looks like this:\r\n\r\n```\r\n[\r\n  &quot;paths&quot;,\r\n  &quot;/v4/user/profileAttributes/{key}&quot;,\r\n  &quot;delete&quot;\r\n]\r\n[\r\n  &quot;paths&quot;,\r\n  &quot;/v4/users/{user_id}/last_admin_rooms&quot;,\r\n  &quot;get&quot;\r\n]\r\n[\r\n  &quot;definitions&quot;,\r\n  &quot;GeneralSettings&quot;,\r\n  &quot;properties&quot;,\r\n  &quot;s3TagsEnabled&quot;\r\n]\r\n```\r\n\r\nI found this [filter][1] to return the value for a seemingly random key/value pair of &quot;description&quot; when adapted to the string I search for and not the whole list. Unfortunately I don&#39;t quite understand the entire filter as the author didn&#39;t explain it in his post. When adapted \r\n\r\n```\r\ncurl -s -N $api | jq &#39;. as $in\r\n| reduce paths(type == &quot;string&quot; and test(&quot;; Since version&quot;)) as $path ({};\r\n    ($in|getpath($path)) as $x\r\n    | if ($path[-1]|type) == &quot;string&quot;\r\n      then .[$path[-1]] = $x\r\n      else .[$path[-2]|tostring] += [$x]\r\n      end )&#39;\r\n```\r\n\r\nreturns \r\n\r\n```\r\n{\r\n  &quot;description&quot;: &quot;Some_Text_We_Dont_Care_About; Since version 4.10.2 Some_More_Text_We_Dont_Care_About&quot;\r\n}\r\n```\r\n\r\nI would be able to stitch the two filtered responses together if the second filter would return all entries instead of the (seamingly random) one. I posted both filters in here as maybe someone knows how to do it in a cleaner way.\r\n\r\nIdeally the end result would return a list with entries like this:\r\n\r\n```\r\n{\r\n  &quot;path&quot;: &quot;\r\n    [\r\n    &quot;paths&quot;,\r\n    &quot;/v4/users/{user_id}/last_admin_rooms&quot;,\r\n    &quot;get&quot;\r\n    ]&quot;\r\n  &quot;,\r\n  &quot;version&quot;: {\r\n    &quot;description&quot;: &quot;Some_Text_We_Dont_Care_About; Since version 4.10.2 Some_More_Text_We_Dont_Care_About&quot;\r\n  }\r\n}\r\n```\r\n\r\n\r\n\r\n**Here&#39;s a excerpt/example what the input looks like:**\r\n\r\n```\r\n{\r\n  &quot;info&quot;: {4 items},\r\n  &quot;host&quot;: &quot;some_hostname&quot;,\r\n  &quot;basePath&quot;: &quot;/api&quot;,\r\n  &quot;tags&quot;: [19 items],\r\n  &quot;paths&quot;: {\r\n    &quot;/v4/config/info/defaults&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;config&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Get default values&quot;,\r\n        &quot;description&quot;: &quot;SomeText; Since version 4.6.0 SomeMoreText&quot;,\r\n        &quot;operationId&quot;: &quot;getSystemDefaultsInfo&quot;,\r\n        &quot;produces&quot;: [\r\n          &quot;application/json;charset=UTF-8&quot;\r\n        ],\r\n      }\r\n    }\r\n    &quot;/v4/config/info/general&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;config&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Get general values&quot;,\r\n        &quot;description&quot;: &quot;SomeText; Since version 4.6.0 SomeMoreText&quot;,\r\n        &quot;operationId&quot;: &quot;getSystemDefaultsInfo&quot;,\r\n        &quot;produces&quot;: [\r\n          &quot;application/json;charset=UTF-8&quot;\r\n        ],\r\n      }\r\n    }\r\n  &quot;definitions&quot;: {\r\n  \t&quot;GeneralSettings&quot;: {\r\n      &quot;type&quot;: &quot;object&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;cryptoEnabled&quot;: {\r\n          &quot;type&quot;: &quot;boolean&quot;,\r\n          &quot;description&quot;: &quot;Activation status of encryption&quot;\r\n        },\r\n        &quot;s3TagsEnabled&quot;: {\r\n          &quot;type&quot;: &quot;boolean&quot;,\r\n          &quot;description&quot;: &quot;Defines if S3 tags are enabled; Since version 4.9.0 NEW&quot;\r\n        },\r\n        &quot;sharePasswordSmsEnabled&quot;: {\r\n          &quot;type&quot;: &quot;boolean&quot;,\r\n          &quot;description&quot;: &quot;Allow sending of share passwords via SMS&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/45026026/5489512",
        "link": "https://stackoverflow.com/questions/56108239/need-to-filter-all-key-value-pairs-where-the-value-contains-a-specific-substring",
        "title": "Need to filter all key/value pairs where the value contains a specific substring"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11482675,
                    "reputation": 172,
                    "user_id": 8416256,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2a36611f202973ef17dfdd0d081b8df2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ubarbaxor",
                    "link": "https://stackoverflow.com/users/8416256/ubarbaxor"
                },
                "reply_to_user": {
                    "account_id": 9223893,
                    "reputation": 2208,
                    "user_id": 6852290,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/7j7sj.jpg?s=256",
                    "display_name": "Spears",
                    "link": "https://stackoverflow.com/users/6852290/spears"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1557755640,
                "post_id": 56111140,
                "comment_id": 98861201,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user47589"
                },
                "edited": false,
                "score": 6,
                "creation_date": 1557756490,
                "post_id": 56111140,
                "comment_id": 98861737,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1557762116,
                "last_edit_date": 1557762116,
                "creation_date": 1557759254,
                "answer_id": 56114895,
                "question_id": 56111140,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq (as in [tag:jq]) is a &quot;JSON query language&quot; and might perhaps therefore have been called &quot;JQL&quot; by analogy with &quot;SQL&quot;, but jq is shorter :-)\r\n\r\nAlso note that jq is not only a JSON query language, but completely subsumes JSON: any valid JSON expression is a valid jq expression.  \r\n\r\nFurthermore, many valid jq expressions that are not valid JSON expressions are nevertheless structurally like JSON, e.g. `{a: 1}` and `{&quot;a&quot;: .}`.\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "What does &quot;jq&quot; stand for?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1557762116,
        "creation_date": 1557745848,
        "last_edit_date": 1557758709,
        "question_id": 56111140,
        "body_markdown": "Question title is quite explicit already.  \r\n\r\nAfter using it for _a while_ now, I figured it&#39;s weird not knowing what the name of one of my favourite tools actually stands for.  \r\nChecking the official website and GitHub didn&#39;t help much.  \r\nAlthough I assume it&#39;s &quot;JSON Query&quot; or something alike, it&#39;d be nice to know; but opening an issue feels a bit overkill...",
        "link": "https://stackoverflow.com/questions/56111140/what-does-jq-stand-for",
        "title": "What does &quot;jq&quot; stand for?"
    },
    {
        "tags": [
            "json",
            "wordpress",
            "bash",
            "jq",
            "github-api"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1557757232,
                "last_edit_date": 1557757232,
                "creation_date": 1557756625,
                "answer_id": 56114165,
                "question_id": 56113755,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Quoting from [this answer](https://stackoverflow.com/a/35062729/10248678):\r\n&gt; GitHub&#39;s UI is confusing, but this repository doesn&#39;t actually have any releases, which are a GitHub-specific concept. The &quot;releases&quot; you are seeing are actually just regular Git tags.\r\n\r\nYou&#39;ve faced the same issue. You need to request **tags** instead of **releases** from the api and it will work that way. E.g:\r\n```\r\ncurl -sS &#39;https://api.github.com/repos/WordPress/WordPress/tags&#39; |\r\njq -r &#39;.[0].name&#39;\r\n```\r\nThis shows `5.2` to me.",
                "title": "How to get latest stable wordpress release number from bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1666590393,
        "creation_date": 1557755246,
        "last_edit_date": 1666590393,
        "question_id": 56113755,
        "body_markdown": " 1. https://api.github.com/repos/WordPress/WordPress/releases/latest\r\n doesn&#39;t seem to work, so we are out of luck\r\n\r\n 2. using `xpath` package (specifically `wget -qO- https://wordpress.org/download/releases/ | xpath -e &#39;//table[contains(@class,&#39;latest&#39;)]/tbody/tr/td[1]&#39;` )  won&#39;t work, because the https://wordpress.org/download/releases/ is not really valid HTML page and writing bash workarounds for the official site seems like an overkill\r\n\r\n 3. `svn log https://core.svn.wordpress.org/tags --limit 1 | grep &#39;Tag&#39;`\r\nIs a way that works, but there&#39;s no chance this will always show latest stable tag.\r\n\r\nDo you maybe have any other ideas that are reliable to get the latest stable release?\r\n\r\n**Expected value** I&#39;m looking for (at the time of writing this post):\r\n\r\n`5.2`\r\n\r\nEDIT: someone marked the question as duplicate,but one of the answers cleared that out. The Wordpress github repository does NOT have releases, and latest stable release cannot be fetched using github API.\r\n`/tags` will show ALL tags, and I&#39;m only interested in stable ones.",
        "link": "https://stackoverflow.com/questions/56113755/how-to-get-latest-stable-wordpress-release-number-from-bash",
        "title": "How to get latest stable wordpress release number from bash"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "ascii-8bit"
        ],
        "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": 1557941444,
                "post_id": 56114199,
                "comment_id": 98938797,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 97993,
                    "reputation": 98361,
                    "user_id": 265521,
                    "user_type": "registered",
                    "accept_rate": 58,
                    "profile_image": "https://www.gravatar.com/avatar/34a66330977044d70165288c56740d4b?s=256&d=identicon&r=PG",
                    "display_name": "Timmmm",
                    "link": "https://stackoverflow.com/users/265521/timmmm"
                },
                "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": 1558015644,
                "post_id": 56114199,
                "comment_id": 98967486,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1557809011,
                "last_edit_date": 1557809011,
                "creation_date": 1557759079,
                "answer_id": 56114847,
                "question_id": 56114199,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq either produces JSON or (with the -r flag) UTF-8, but you could consider using `iconv` or equivalent, e.g.\r\n\r\n    $ jq -j --raw-output &#39;implode&#39; &lt;&lt;&lt; &#39;[0, 255, 128, 40, 127]&#39;  | iconv -c -f utf-8 -t ISO-8859-16\r\n    \r\nThe output apparently cannot be shown here, so consider instead:\r\n\r\n```\r\n$ jq -j --raw-output &#39;implode&#39; &lt;&lt;&lt; &#39;[0, 255, 128, 40, 127]&#39;  | iconv -c -f utf-8 -t ISO-8859-16 | xxd -ps\r\n00ff80287f\r\n\r\n$ jq -j --raw-output &#39;implode&#39; &lt;&lt;&lt; &#39;[0, 255, 128, 40, 127]&#39;  | xxd -ps\r\n00c3bfc280287f\r\n```\r\n\r\nIn any case, note that \r\nthe initial `.|` is unnecessary. ",
                "title": "jq implode array of byte integers to raw bytes"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1557847302,
        "creation_date": 1557756754,
        "last_edit_date": 1557847302,
        "question_id": 56114199,
        "body_markdown": "With `jq` I have an array of bytes, like `[0, 255, 128, 0, 127]` that I want to convert to a binary file.\r\n\r\nIt *almost* works like this:\r\n\r\n    jq --raw-output &#39;. | implode&#39; in.json &gt; out.bin\r\n\r\nBut unfortunately it interprets the input as Unicode code points, and writes the result as a UTF-8 string. Is there a binary version of `implode`?",
        "link": "https://stackoverflow.com/questions/56114199/jq-implode-array-of-byte-integers-to-raw-bytes",
        "title": "jq implode array of byte integers to raw bytes"
    },
    {
        "tags": [
            "json",
            "jq",
            "pretty-print"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1557795263,
                "creation_date": 1557795263,
                "answer_id": 56121631,
                "question_id": 56121575,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.` is the [basic JQ filter][1] (jq by default pretty-prints all output)\r\n\r\n`cat file.json | jq -c | jq .`\r\n\r\n`jq .` will decompress it\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Basicfilters",
                "title": "Decompress / decompact JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1557930328,
        "creation_date": 1557794754,
        "last_edit_date": 1557930328,
        "question_id": 56121575,
        "body_markdown": "I can compact JSON using `jq -c` like so:\r\n\r\n    cat file.json | jq -c \r\n\r\nwhich will output all the json on a single line..is there a command that can decompact/decompress it so it&#39;s more human readable again? Basically adding newlines in the right places?",
        "link": "https://stackoverflow.com/questions/56121575/decompress-decompact-json-using-jq",
        "title": "Decompress / decompact JSON using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1557844048,
                "last_edit_date": 1557844048,
                "creation_date": 1557843268,
                "answer_id": 56132520,
                "question_id": 56132077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following :\r\n\r\n    jq --raw-output &#39;.pages | group_by(.srcPath)[] | [.[0].srcPath, .[0].published, .[].references[]] | @csv&#39;\r\n\r\nWe group the pages by srcPath and map each group into an array that contains the srcPath and published of the first element of the group as well as the references of each element of the group. Each of these arrays will be a row in the CSV result.\r\n\r\n\r\n[Try it here !](https://jqplay.org/s/vcuiS2Hjrn)",
                "title": "Treat Entry As Primary Key Print Once, Print Associated Entry Array, As CSV, Drop Empties"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1557844048,
        "creation_date": 1557841838,
        "last_edit_date": 1557842483,
        "question_id": 56132077,
        "body_markdown": "I have records like these with sometimes duplicate `srcPath` entries, though with different `references`. \r\n\r\nFor example `/content/dam/foo/about-bar/photos/rayDavis.PNG` appears 3 times in one record, with different `references`. \r\n\r\nI&#39;d like to get the unique `srcPath` printed once, and the associated `references`. \r\n\r\nI also have empty records, \r\n\r\n    {\r\n      &quot;pages&quot;: []\r\n    }\r\n\r\n\r\nI don&#39;t want to see those. \r\n\r\nI&#39;d really like a csv with:\r\n\r\n`srcPath`, perhaps a different field like `published`, and first `reference`, second `reference`, third `reference`, etc. -- associated `references` array as consecutive comma separated values on the same line, like:\r\n\r\n\r\n\r\n    \r\n    &quot;/content/dam/foo/about-bar/pdf/theplan.pdf&quot;, true, &quot;/content/foo/en/about-bar/the-plan-and-vision/jcr:content/content2/image/link&quot;, &quot;/content/foo/en/about-bar/the-plan-and-vision/jcr:content/content2/textboximg/boxFtr&quot;, &quot;/content/foo/en/about-bar/the-plan-and-vision/jcr:content/content1/textboximg/text&quot;\r\n\r\n    &quot;/content/dam/foo/about-bar/photos/rayDavis.PNG&quot;, true, &quot;/content/foo/en/about-bar/jcr:content/content1B/promos_1/image/fileReference&quot;, &quot;/content/foo/en/about-bar/monkey-development/tales-of-giving/ray-moose-davis/jcr:content/content1/textboximg/fileReference&quot;, &quot;/content/foo/en/about-bar/monkey-development/tales-of-giving/jcr:content/content1/textboximg_2/fileReference&quot;\r\n    \r\n    &quot;/content/dam/foo/about-bar/pdf/foo_19thNewsletter.pdf&quot;, true, &quot;/content/foo/en/gremlins/stay-tuned/jcr:content/content3/textboximg/text&quot;\r\n    \r\n    &quot;/content/dam/foo/about-bar/pdf/barNews_fall1617.pdf&quot;, true, &quot;/content/foo/en/gremlins/jcr:content/content2C/textboximg_114671747/text&quot;, &quot;/content/dam/foo/about-bar/pdf/barNews_fall1617.pdf&quot;, &quot;/content/foo/en/gremlins/stay-tuned/jcr:content/content3/textboximg_0/text&quot;\r\n\r\nIn other words, unique `srcPath` entries with associated `references`. \r\n\r\nI imagine if I wanted `path` too, I wouldn&#39;t be able to have unique `srcPath` lines in the csv?\r\n\r\n\r\n\r\nDATA: \r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n    {\r\n      &quot;pages&quot;: [\r\n        {\r\n          &quot;srcPath&quot;: &quot;/content/dam/foo/about-bar/pdf/theplan.pdf&quot;,\r\n          &quot;srcTitle&quot;: &quot;theplan.pdf&quot;,\r\n          &quot;path&quot;: &quot;/content/foo/en/about-bar/the-plan-and-vision&quot;,\r\n          &quot;title&quot;: &quot;the Plan and Vision&quot;,\r\n          &quot;references&quot;: [\r\n            &quot;/content/foo/en/about-bar/the-plan-and-vision/jcr:content/content2/image/link&quot;,\r\n            &quot;/content/foo/en/about-bar/the-plan-and-vision/jcr:content/content2/textboximg/boxFtr&quot;,\r\n            &quot;/content/foo/en/about-bar/the-plan-and-vision/jcr:content/content1/textboximg/text&quot;\r\n          ],\r\n          &quot;published&quot;: false,\r\n          &quot;isPage&quot;: &quot;true&quot;\r\n        }\r\n      ]\r\n    }\r\n    \r\n    \r\n    \r\n    \r\n    \r\n    \r\n    {\r\n      &quot;pages&quot;: []\r\n    }\r\n    \r\n    \r\n    \r\n    {\r\n      &quot;pages&quot;: []\r\n    }\r\n    \r\n    \r\n    {\r\n      &quot;pages&quot;: [\r\n        {\r\n          &quot;srcPath&quot;: &quot;/content/dam/foo/about-bar/photos/rayDavis.PNG&quot;,\r\n          &quot;srcTitle&quot;: &quot;rayDavis.PNG&quot;,\r\n          &quot;path&quot;: &quot;/content/foo/en/about-bar&quot;,\r\n          &quot;title&quot;: &quot;About bar&quot;,\r\n          &quot;references&quot;: [\r\n            &quot;/content/foo/en/about-bar/jcr:content/content1B/promos_1/image/fileReference&quot;\r\n          ],\r\n          &quot;published&quot;: true,\r\n          &quot;isPage&quot;: &quot;true&quot;\r\n        },\r\n        {\r\n          &quot;srcPath&quot;: &quot;/content/dam/foo/about-bar/photos/rayDavis.PNG&quot;,\r\n          &quot;srcTitle&quot;: &quot;rayDavis.PNG&quot;,\r\n          &quot;path&quot;: &quot;/content/foo/en/about-bar/monkey-development/tales-of-giving/ray-moose-davis&quot;,\r\n          &quot;title&quot;: &quot;ray moose Davis&quot;,\r\n          &quot;references&quot;: [\r\n            &quot;/content/foo/en/about-bar/monkey-development/tales-of-giving/ray-moose-davis/jcr:content/content1/textboximg/fileReference&quot;\r\n          ],\r\n          &quot;published&quot;: true,\r\n          &quot;isPage&quot;: &quot;true&quot;\r\n        },\r\n        {\r\n          &quot;srcPath&quot;: &quot;/content/dam/foo/about-bar/photos/rayDavis.PNG&quot;,\r\n          &quot;srcTitle&quot;: &quot;rayDavis.PNG&quot;,\r\n          &quot;path&quot;: &quot;/content/foo/en/about-bar/monkey-development/tales-of-giving&quot;,\r\n          &quot;title&quot;: &quot;tales of Giving&quot;,\r\n          &quot;references&quot;: [\r\n            &quot;/content/foo/en/about-bar/monkey-development/tales-of-giving/jcr:content/content1/textboximg_2/fileReference&quot;\r\n          ],\r\n          &quot;published&quot;: true,\r\n          &quot;isPage&quot;: &quot;true&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    \r\n    {\r\n      &quot;pages&quot;: [\r\n        {\r\n          &quot;srcPath&quot;: &quot;/content/dam/foo/about-bar/pdf/foo_19thNewsletter.pdf&quot;,\r\n          &quot;srcTitle&quot;: &quot;foo_19thNewsletter.pdf&quot;,\r\n          &quot;path&quot;: &quot;/content/foo/en/gremlins/stay-tuned&quot;,\r\n          &quot;title&quot;: &quot;Stay tuned&quot;,\r\n          &quot;references&quot;: [\r\n            &quot;/content/foo/en/gremlins/stay-tuned/jcr:content/content3/textboximg/text&quot;\r\n          ],\r\n          &quot;published&quot;: true,\r\n          &quot;isPage&quot;: &quot;true&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    \r\n    {\r\n      &quot;pages&quot;: [\r\n        {\r\n          &quot;srcPath&quot;: &quot;/content/dam/foo/about-bar/pdf/barNews_fall1617.pdf&quot;,\r\n          &quot;srcTitle&quot;: &quot;barNews_fall1617.pdf&quot;,\r\n          &quot;path&quot;: &quot;/content/foo/en/gremlins&quot;,\r\n          &quot;title&quot;: &quot;gremlins&quot;,\r\n          &quot;references&quot;: [\r\n            &quot;/content/foo/en/gremlins/jcr:content/content2C/textboximg_114671747/text&quot;\r\n          ],\r\n          &quot;published&quot;: true,\r\n          &quot;isPage&quot;: &quot;true&quot;\r\n        },\r\n        {\r\n          &quot;srcPath&quot;: &quot;/content/dam/foo/about-bar/pdf/barNews_fall1617.pdf&quot;,\r\n          &quot;srcTitle&quot;: &quot;barNews_fall1617.pdf&quot;,\r\n          &quot;path&quot;: &quot;/content/foo/en/gremlins/stay-tuned&quot;,\r\n          &quot;title&quot;: &quot;Stay tuned&quot;,\r\n          &quot;references&quot;: [\r\n            &quot;/content/foo/en/gremlins/stay-tuned/jcr:content/content3/textboximg_0/text&quot;\r\n          ],\r\n          &quot;published&quot;: true,\r\n          &quot;isPage&quot;: &quot;true&quot;\r\n        }\r\n      ]\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/56132077/treat-entry-as-primary-key-print-once-print-associated-entry-array-as-csv-dro",
        "title": "Treat Entry As Primary Key Print Once, Print Associated Entry Array, As CSV, Drop Empties"
    },
    {
        "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": 6,
                "creation_date": 1557861290,
                "post_id": 56136673,
                "comment_id": 98905309,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 128894,
                    "reputation": 1810,
                    "user_id": 1899716,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/f93a542fe834d9e8986cadb0ab20f17c?s=256&d=identicon&r=PG",
                    "display_name": "nroose",
                    "link": "https://stackoverflow.com/users/1899716/nroose"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1738350477,
                "post_id": 56136673,
                "comment_id": 140032323,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1650461394,
                "last_edit_date": 1650461394,
                "creation_date": 1557862045,
                "answer_id": 56137321,
                "question_id": 56136673,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An empty array will not cause the error message you see.\r\n\r\n**EDIT:** the issue is the API returning retry later as [@peak says](https://stackoverflow.com/a/56137550/4248931). To fix this, just add sleep 1 as that seemed to fix it\r\n\r\nHere is an example of an empty array being returned but no parse error \r\n`curl -k -s https://api.earningscalendar.net/?date=20190303 | jq -r &#39;map([.ticker, .when] | join(&quot;, &quot;)) | join(&quot;\\n&quot;)&#39; | grep -w &quot;$1&quot;`\r\n\r\n```\r\nnewdate=`date +%Y%m%d`\r\ncurl -k -s https://api.earningscalendar.net/?date=$newdate | jq -r &#39;map([.ticker, .when] | join(&quot;, &quot;)) | join(&quot;\\n&quot;)&#39; | grep -w &quot;$1&quot;\r\n```\r\n\r\nOutput\r\n\r\n```\r\nACB, amc\r\nTLRY, amc\r\nCYBR, bmo\r\nNEWR, amc\r\nAEYE, amc\r\nA, amc\r\nUSAT, --\r\nRL, bmo\r\nHUD, bmo\r\nCATB, bmo\r\nROSE, amc\r\nPAGS, amc\r\nHDB, --\r\nKOOL, amc\r\nCPIX, amc\r\nNLST, amc\r\nAUPH, amc\r\nVCTR, amc\r\nONCE, --\r\nEVC, --\r\nFSM, amc\r\nJAPAY, --\r\nVLVLY, --\r\nRDSMY, --\r\nZLNDY, --\r\nGNMSF, --\r\nDOX, amc\r\nPORBF, --\r\nGDS, bmo\r\nEGHT, amc\r\nBEST, bmo\r\nTAC, bmo\r\nTIER, --\r\nGOSS, bmo\r\nAZZ, bmo\r\nTRWH, amc\r\nMDOMF, --\r\nAUTL, bmo\r\nROAN, amc\r\nCPLG, amc\r\nCTST, bmo\r\nDSSI, bmo\r\nIMXI, amc\r\nTCS, amc\r\nMIXT, bmo\r\nKDMN, --\r\nSFST, --\r\nALLT, bmo\r\nARA, --\r\nKMDA, bmo\r\nOCX, amc\r\nMXWL, --\r\nHYGS, bmo\r\nPANL, amc\r\nMTNB, bmo\r\nLIQT, bmo\r\nAPTX, bmo\r\nREED, amc\r\nMRBK, --\r\nUQM, amc\r\nGECC, bmo\r\nTGEN, bmo\r\nENT, amc\r\nMOGO, amc\r\nSLGG, amc\r\nEYEN, bmo\r\nHCAP, bmo\r\nWYY, amc\r\nBLRX, bmo\r\nSUNW, amc\r\nTST, bmo\r\nAYTU, bmo\r\nXELB, bmo\r\nONTX, bmo\r\nFTD, --\r\nTCON, amc\r\nCYTR, --\r\nYOGA, amc\r\nDYNT, bmo\r\nCYCC, amc\r\nDARE, amc\r\nESEA, --\r\nEMES, --\r\nASCMA, --\r\nNSPR, bmo\r\nOPGN, amc\r\nAGHC, --\r\nLIOPF, --\r\n```",
                "title": "parse error: Invalid numeric literal at line 1, column 6"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1557862868,
                "creation_date": 1557862868,
                "answer_id": 56137550,
                "question_id": 56136673,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To debug the problem, you could check the output produced by the &quot;curl&quot; command.  When I run it in a loop, without jq, the output is frequently &quot;Retry later&quot;, as though there is some kind of throttling.\r\n\r\nA similar alternative to consider would be to run a very basic jq program, e.g.\r\n\r\n    #!/bin/bash\r\n    for i in {1..15}\r\n    do\r\n        newdate=`/bin/date -v +&quot;$i&quot;d +%Y%m%d`\r\n        echo newdate=$newdate\r\n        curl -k -s &quot;https://api.earningscalendar.net/?date=$newdate&quot; | jq type\r\n    done\r\n\r\n\r\n\r\n  ",
                "title": "parse error: Invalid numeric literal at line 1, column 6"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1655563627,
                "last_edit_date": 1655563627,
                "creation_date": 1655306372,
                "answer_id": 72633925,
                "question_id": 56136673,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I had a similar issue and turns out the curl command was returning header info that was stored in the env var, but suppressed by echo so it didn&#39;t appear to me.\r\n\r\nChanging from ```$ curl -iX ...``` to ```$ curl -X ...``` discarded the header info and it started working.\r\n\r\nPlease see https://curl.se/docs/manpage.html for reference.",
                "title": "parse error: Invalid numeric literal at line 1, column 6"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 9,
        "last_activity_date": 1655563627,
        "creation_date": 1557859404,
        "last_edit_date": 1597209417,
        "question_id": 56136673,
        "body_markdown": "The 1 liner to grab the ticker works fine from commandline, but i get this error running in a script.\r\n\r\nI run the 1 liner that grabs TICKERD from commandline, that doesnt give me the error.\r\n\r\nBut, i believe it is because of empty data in the array?\r\n\r\n````\r\ncurl -k -s https://api.earningscalendar.net/?date=20190518\r\n[]\r\n````\r\n\r\n````\r\n#!/bin/bash\r\nfor i in {1..15}\r\ndo\r\nnewdate=`/bin/date -v +&quot;$i&quot;d +%Y%m%d`\r\nTICKERD=`curl -k -s https://api.earningscalendar.net/?date=$newdate | jq -r &#39;map([.ticker, .when] | join(&quot;, &quot;)) | join(&quot;\\n&quot;)&#39; | grep -w &quot;$1&quot;`\r\nTICKERA=`echo $TICKERD | cut -d, -f1`\r\nif [ &quot;$TICKERA&quot; == &quot;$1&quot; ]\r\nthen\r\necho $TICKERD &quot;is on&quot; $newdate\r\nexit\r\nfi\r\ndone\r\n````\r\nError Message : \r\n````\r\n./earnings.sh ADSK\r\nparse error: Invalid numeric literal at line 1, column 6\r\nparse error: Invalid numeric literal at line 1, column 6\r\nparse error: Invalid numeric literal at line 1, column 6\r\nparse error: Invalid numeric literal at line 1, column 6\r\nADSK, amc is on 20190523\r\n````",
        "link": "https://stackoverflow.com/questions/56136673/parse-error-invalid-numeric-literal-at-line-1-column-6",
        "title": "parse error: Invalid numeric literal at line 1, column 6"
    },
    {
        "tags": [
            "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": 1557908359,
                "post_id": 56144431,
                "comment_id": 98919223,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1577684,
                    "reputation": 2554,
                    "user_id": 1463751,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://www.gravatar.com/avatar/089f887e5f22d434203d42308a4baab9?s=256&d=identicon&r=PG",
                    "display_name": "Tom Klino",
                    "link": "https://stackoverflow.com/users/1463751/tom-klino"
                },
                "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": 1557909431,
                "post_id": 56144431,
                "comment_id": 98919762,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1577684,
                    "reputation": 2554,
                    "user_id": 1463751,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://www.gravatar.com/avatar/089f887e5f22d434203d42308a4baab9?s=256&d=identicon&r=PG",
                    "display_name": "Tom Klino",
                    "link": "https://stackoverflow.com/users/1463751/tom-klino"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1557912233,
                "post_id": 56144431,
                "comment_id": 98921386,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1557927078,
                "last_edit_date": 1557927078,
                "creation_date": 1557913622,
                "answer_id": 56146330,
                "question_id": 56144431,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JSON standard is quite explicit about which characters have to be escaped, and `[` is not one of them (though reverse solidus - `\\` is). So it&#39;s your script / software generating JSON violates the JSON standard - you can validate it on any of well-known online JSON validators, e.g., like this one: https://jsoncompare.com/#!/simple/ - it will produce the error too.\r\n\r\nIf you cannot enhance/fix your script generating that JSON, then you&#39;d need to ensure you double quote those non-compliant quotations before passing to JSON processor: e.g.\r\n\r\n    ... | sed -E &#39;s/\\\\([][])/\\\\\\\\\\1/g&#39; | ...\r\n",
                "title": "jq fails to parse when one of the values contains a backslash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1557951109,
                "creation_date": 1557951109,
                "answer_id": 56156937,
                "question_id": 56144431,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;ll need to fix whatever is generating that &quot;json&quot; string. Use something that produces compliant json.\r\n\r\nIf that&#39;s not an option for you, then you will have to modify it so that it is valid json. Fortunately `jq` can handle that. Read it in raw, fix the string then parse it.\r\n\r\nAssuming we just need to fix the `\\[` and `\\]` sequence:\r\n\r\n    $ ... | jq -R &#39;gsub(&quot;\\\\\\\\(?&lt;c&gt;[[\\\\]])&quot;; &quot;\\\\\\\\\\(.c)&quot;) | fromjson | &quot;your filter&quot;&#39;\r\n\r\nRemember, `&quot;sh -c pgrep -fl \\&quot;unicorn.* worker\\\\[.*?\\\\]\\&quot;&quot;` is a string with escapes... it represents the value:\r\n\r\n    sh -c pgrep -fl &quot;unicorn.* worker\\[.*?\\]&quot;\r\n\r\nSo it&#39;s absolutely correct to have &quot;both backslashes.&quot;",
                "title": "jq fails to parse when one of the values contains a backslash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1557951109,
        "creation_date": 1557907696,
        "last_edit_date": 1557912356,
        "question_id": 56144431,
        "body_markdown": "I have a json output, representing a linux command in one of it&#39;s values:\r\n\r\n```\r\n... ,&quot;proc.cmdline&quot;:&quot;sh -c pgrep -fl \\&quot;unicorn.* worker\\[.*?\\]\\&quot;&quot;, ...\r\n```\r\n\r\nIn some cases, the command contains a backslash, so the outputing json will contain a backslash too.\r\n\r\nI need to parse the output with jq, but it fails with an error:\r\n\r\n```\r\nparse error: Invalid escape at line 1, column 373\r\n```\r\nIt refers to this: `\\[`\r\n\r\nHowever, this is a part of the command, so it is expected to be there.\r\n\r\nIf a manually edit the line, converting `\\[` to `\\\\[`, then it passes. However the resulting output contains both backslashes:\r\n\r\n```\r\n...\r\n&quot;proc.cmdline&quot;: &quot;sh -c pgrep -fl \\&quot;unicorn.* worker\\\\[.*?\\\\]\\&quot;&quot;,\r\n...\r\n```\r\n\r\nNow, I can&#39;t be there to manually edit every time. This output is produced automatically by another software, and I need to parse it with jq every time it comes in.\r\n\r\nAlso, even if I was able to edit every `\\[` to `\\\\[`, (like by using something like `sed`) the output becomes a lie, the second `\\` is fake.\r\n\r\nAny ideas on how to work around this?\r\n\r\n-----\r\nEDIT: here is the full json for reference (received raw by the output of the program I&#39;m using (falco)):\r\n\r\n```\r\n{&quot;priority&quot;:&quot;Debug&quot;,&quot;rule&quot;:&quot;Run shell untrusted&quot;,&quot;time&quot;:&quot;2019-05-15T07:32:36.597411997Z&quot;, &quot;output_fields&quot;: {&quot;evt.time&quot;:1557905556597411997,&quot;proc.aname[2]&quot;:&quot;gitlab-mon&quot;,&quot;proc.aname[3]&quot;:&quot;runsv&quot;,&quot;proc.aname[4]&quot;:&quot;runsvdir&quot;,&quot;proc.aname[5]&quot;:&quot;wrapper&quot;,&quot;proc.aname[6]&quot;:&quot;docker-containe&quot;,&quot;proc.aname[7]&quot;:&quot;docker-containe&quot;,&quot;proc.cmdline&quot;:&quot;sh -c pgrep -fl \\&quot;unicorn.* worker\\[.*?\\]\\&quot;&quot;,&quot;proc.name&quot;:&quot;sh&quot;,&quot;proc.pcmdline&quot;:&quot;reactor.rb:249                                                                       &quot;,&quot;proc.pname&quot;:&quot;reactor.rb:249&quot;,&quot;user.name&quot;:null}}\r\n```",
        "link": "https://stackoverflow.com/questions/56144431/jq-fails-to-parse-when-one-of-the-values-contains-a-backslash",
        "title": "jq fails to parse when one of the values contains a backslash"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1557940155,
                "post_id": 56154422,
                "comment_id": 98938220,
                "content_license": "CC BY-SA 4.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": 1557940338,
                "post_id": 56154422,
                "comment_id": 98938289,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6429959,
                    "reputation": 220,
                    "user_id": 4983575,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/gEFA2.jpg?s=256",
                    "display_name": "Ashish Sharma",
                    "link": "https://stackoverflow.com/users/4983575/ashish-sharma"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1557940369,
                "post_id": 56154422,
                "comment_id": 98938305,
                "content_license": "CC BY-SA 4.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": 3,
                "creation_date": 1557940370,
                "post_id": 56154422,
                "comment_id": 98938306,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6429959,
                    "reputation": 220,
                    "user_id": 4983575,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/gEFA2.jpg?s=256",
                    "display_name": "Ashish Sharma",
                    "link": "https://stackoverflow.com/users/4983575/ashish-sharma"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1557940990,
                "post_id": 56154422,
                "comment_id": 98938601,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1559131400,
                "creation_date": 1559131400,
                "answer_id": 56360202,
                "question_id": 56154422,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this:\r\n\r\n`instanceUrl=$(echo $orgCreateResult | ./bash-scripts/jq-win64.exe .result.instanceUrl -r)`",
                "title": "JSON key value coming as blank when using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1559131400,
        "creation_date": 1557939992,
        "question_id": 56154422,
        "body_markdown": "I am using JQ to parse JSON returned by Salesforce CLI.\r\nMy bash script is:\r\n\r\n    orgCreateResult=$(sfdx force:org:display -u mockScreenOrg --json)\r\n    orgCreateStatus=$(echo $orgCreateResult | ./bash-scripts/jq-win64.exe .status -r)\r\n    echo &quot;orgCreateResult: &quot;\r\n    echo &quot;$orgCreateResult&quot;\r\n    echo &quot;orgCreateStatus: $orgCreateStatus&quot;\r\n    instanceUrl=$(echo $checkDevHubResult | ./bash-scripts/jq-win64.exe .result -r)\r\n    echo &quot;instanceUrl: $instanceUrl&quot;\r\n\r\nI am using bash terminal in VS Code on windows. Output I am getting from this script is :\r\n\r\n    orgCreateResult:\r\n    {\r\n      &quot;status&quot;: 0,\r\n      &quot;result&quot;: {\r\n        &quot;username&quot;: &quot;test-******@example.com&quot;,\r\n        &quot;devHubId&quot;: &quot;****@**.com&quot;,\r\n        &quot;id&quot;: &quot;************&quot;,\r\n        &quot;createdBy&quot;: &quot;*****@**.com&quot;,\r\n        &quot;createdDate&quot;: &quot;2019-05-13T14:15:32.000+0000&quot;,\r\n        &quot;expirationDate&quot;: &quot;2019-06-12&quot;,\r\n        &quot;status&quot;: &quot;Active&quot;,\r\n        &quot;edition&quot;: &quot;Developer&quot;,\r\n        &quot;orgName&quot;: &quot;HPESC&quot;,\r\n        &quot;accessToken&quot;: &quot;************************************&quot;,\r\n        &quot;instanceUrl&quot;: &quot;https://nosoftware-ruby-2532-dev-ed.cs6.my.salesforce.com&quot;,\r\n        &quot;clientId&quot;: &quot;PlatformCLI&quot;,\r\n        &quot;alias&quot;: &quot;mockScreenOrg&quot;\r\n      }\r\n    }\r\n    orgCreateStatus: 0\r\n    instanceUrl:\r\n\r\nI am able to read status field from JSON but it kinda fails with result object. I want to read instanceUrl field from JSON to use later in my script. Not sure if I am doing something wrong. I am very new to bash and JQ",
        "link": "https://stackoverflow.com/questions/56154422/json-key-value-coming-as-blank-when-using-jq",
        "title": "JSON key value coming as blank when using JQ"
    },
    {
        "tags": [
            "json",
            "unix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1558010212,
                "last_edit_date": 1558010212,
                "creation_date": 1558000502,
                "answer_id": 56165788,
                "question_id": 56164858,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use a comma (also, I&#39;ve simplified the key-value selectors to use the shorthand syntax):\r\n&lt;pre&gt;\r\n&lt;code&gt;jq -c &#39;.hits.hits[] | { index: { _index, _type, _id } }&lt;b&gt;,&lt;/b&gt; ._source&#39; main.json&lt;/code&gt;\r\n&lt;/pre&gt;",
                "title": "How to weave lines of two different jq statements together"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1558010212,
        "creation_date": 1557997708,
        "last_edit_date": 1558002406,
        "question_id": 56164858,
        "body_markdown": "I have the following jq statement:\r\n\r\n    cat main.json | jq .hits.hits[] | jq -c &#39;{&quot;index&quot;:{&quot;_index&quot;: ._index, &quot;_type&quot;: ._type, &quot;_id&quot;: ._id}}&#39;\r\n\r\nwhich gives me something like:\r\n\r\n    {&quot;index&quot;:{&quot;_index&quot;:&quot;main&quot;,&quot;_type&quot;:&quot;default&quot;,&quot;_id&quot;:&quot;64&quot;}}\r\n    {&quot;index&quot;:{&quot;_index&quot;:&quot;main&quot;,&quot;_type&quot;:&quot;default&quot;,&quot;_id&quot;:&quot;65&quot;}}\r\n\r\nAnd another jq statement:\r\n\r\n    cat main.json | jq .hits.hits[] | jq -c &#39;._source&#39;\r\n\r\nwhich gives me something like:\r\n\r\n    {&quot;mainContentOfPage&quot;:&quot;hidden&quot;,&quot;informationType&quot;:&quot;Product&quot;,&quot;url&quot;:&quot;hidden&quot;,&quot;_id&quot;:&quot;64&quot;}\r\n    {&quot;mainContentOfPage&quot;:&quot;hidden&quot;,&quot;informationType&quot;:&quot;Product&quot;,&quot;url&quot;:&quot;hidden&quot;,&quot;_id&quot;:&quot;65&quot;}\r\n\r\nNow I want to combine these statements so that I get their results on consecutive rows, like this:\r\n\r\n    {&quot;index&quot;:{&quot;_index&quot;:&quot;main&quot;,&quot;_type&quot;:&quot;default&quot;,&quot;_id&quot;:&quot;64&quot;}}\r\n    {&quot;mainContentOfPage&quot;:&quot;hidden&quot;,&quot;informationType&quot;:&quot;Product&quot;,&quot;url&quot;:&quot;hidden&quot;,&quot;_id&quot;:&quot;64&quot;}  \r\n    {&quot;index&quot;:{&quot;_index&quot;:&quot;main&quot;,&quot;_type&quot;:&quot;default&quot;,&quot;_id&quot;:&quot;65&quot;}}\r\n    {&quot;mainContentOfPage&quot;:&quot;hidden&quot;,&quot;informationType&quot;:&quot;Product&quot;,&quot;url&quot;:&quot;hidden&quot;,&quot;_id&quot;:&quot;65&quot;}\r\n\r\nwhich will allow me to index these using [Elasticsearch&#39;s Bulk API][1].\r\n\r\nHow can I combine the two statements to give me the result I want?\r\n\r\n  [1]: https://www.elastic.co/guide/en/elasticsearch/reference/6.5/docs-bulk.html",
        "link": "https://stackoverflow.com/questions/56164858/how-to-weave-lines-of-two-different-jq-statements-together",
        "title": "How to weave lines of two different jq statements together"
    },
    {
        "tags": [
            "json",
            "awk",
            "split",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1558006064,
                "last_edit_date": 1558006064,
                "creation_date": 1558005299,
                "answer_id": 56167259,
                "question_id": 56167046,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For each element in the array, print id and the element itself in two separate lines, thus you can grab the id from odd numbered lines and print even numbered lines to files named with id.\r\n```\r\njq -cr &#39;.[] | .id, .&#39; big.json | awk &#39;NR%2{f=$0&quot;.json&quot;;next} {print &gt;f;close(f)}&#39;\r\n```",
                "title": "jq, split a huge json of array and save into file named with a value"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1558040665,
                "last_edit_date": 1558040665,
                "creation_date": 1558040143,
                "answer_id": 56176483,
                "question_id": 56167046,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `.id` as part of a filename is fraught with risk.\r\n\r\nFirst, there is the potential problem of embedded newline characters.\r\n\r\nSecond, there is the problem of &quot;reserved&quot; characters, notably &quot;/&quot;.\r\n\r\nThird, Windows has numerous restrictions on file names -- see e.g. https://gist.github.com/doctaphred/d01d05291546186941e1b7ddc02034d3).\r\n\r\nAlso, if jq&#39;s -r option is used, as suggested in another posting on this page, then .id values of `&quot;1&quot;` and `1` will both be mapped to `1`, which will result in loss of data if &quot;&gt;&quot; is used in awk.\r\n\r\nSo here is a solution that illustrates how safety can be achieved in an OS X or *ix environment and that goes a long way towards a safe solution for Windows:\r\n\r\n    jq -c &#39;.[]\r\n           | (.id | if type == &quot;number&quot; then .\r\n                    else tostring | gsub(&quot;[^A-Za-z0-9-_]&quot;;&quot;+&quot;) end), .&#39; |\r\n    awk &#39;\r\n      function fn(s) { sub(/^\\&quot;/,&quot;&quot;,s); sub(/\\&quot;$/,&quot;&quot;,s); return s &quot;.json&quot;; }\r\n      NR%2{f=fn($0); next} \r\n      {print &gt;&gt; f; close(f);}\r\n    &#39; \r\n\r\n\r\nNotice especially the use of &quot;&gt;&gt;&quot; to avoid losing data in the case of file name collisions.\r\n\r\n",
                "title": "jq, split a huge json of array and save into file named with a value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1558063348,
                "creation_date": 1558063348,
                "answer_id": 56179143,
                "question_id": 56167046,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the problem description indicates the input array is huge, it might be worth considering using jq&#39;s streaming parser.  In general, this would be appropriate if the input JSON is too large to read into memory, or if reducing computer memory requirements is an important goal.\r\n\r\nIn brief, instead of invoking jq in the normal way, one adds the -n and --stream command-line options, and replaces the initial `.[]` by:\r\n\r\n    fromstream(1|truncate_stream(inputs))\r\n\r\nHandling the splitting can then be done as described elsewhere on this page.",
                "title": "jq, split a huge json of array and save into file named with a value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1558063348,
        "creation_date": 1558004511,
        "last_edit_date": 1558011498,
        "question_id": 56167046,
        "body_markdown": "i have a json containing an array of objects, every object contains a unique value in:\r\n\r\n    &quot;id&quot;:&quot;value&quot;\r\n\r\n\r\ni&#39;ve followed this [other answer][1] and i can split the whole document in multiple files using jq and awk\r\n\r\n    jq -c &quot;.[]&quot; big.json | gawk &#39;{print &gt; &quot;doc00&quot; NR &quot;.json&quot;;}&#39;\r\n\r\nin this way the output files are named sequentially.  \r\nhow i can name the files using the `id` value?\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/48801628",
        "link": "https://stackoverflow.com/questions/56167046/jq-split-a-huge-json-of-array-and-save-into-file-named-with-a-value",
        "title": "jq, split a huge json of array and save into file named with a value"
    },
    {
        "tags": [
            "jq",
            "slug",
            "home-assistant"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1558013634,
                "post_id": 56169821,
                "comment_id": 98966276,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7167781,
                    "reputation": 73,
                    "user_id": 5476347,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/01c88bdf18a022fa72e660eeb2b73d4c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Stigh Aarstein",
                    "link": "https://stackoverflow.com/users/5476347/stigh-aarstein"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1558014094,
                "post_id": 56169821,
                "comment_id": 98966561,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1558014189,
                "post_id": 56169821,
                "comment_id": 98966608,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7167781,
                    "reputation": 73,
                    "user_id": 5476347,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/01c88bdf18a022fa72e660eeb2b73d4c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Stigh Aarstein",
                    "link": "https://stackoverflow.com/users/5476347/stigh-aarstein"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1558015119,
                "post_id": 56169821,
                "comment_id": 98967200,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662110694,
                "last_edit_date": 1662110694,
                "creation_date": 1662033573,
                "answer_id": 73569007,
                "question_id": 56169821,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`slug: 07afd144` isn&#39;t valid JSON and as such cannot be parsed with `jq`. Furthermore, it doesn&#39;t contain a `data` property anywhere, so `.data.slug` doesn&#39;t make sense.\r\n\r\nIf the format is always this simple (property name, colon, space, value), then the value can be easily extracted with other common tools generally available on GNU+Linux systems:\r\n\r\n* `cut` (different invocations possible):\r\n\r\n  ```\r\n  cut -d&#39; &#39; -f2-\r\n  cut -c7-\r\n  ```\r\n\r\n* `awk`:\r\n\r\n  ```\r\n  awk &#39;{print $2}&#39;\r\n  ```\r\n\r\n* `sed`:\r\n\r\n  ```\r\n  sed &#39;s/^slug: //&#39;\r\n  ````\r\n\r\n* `perl:\r\n\r\n  ```\r\n  perl -lane &#39;print $F[0]&#39;\r\n  ```\r\n\r\n* or even `grep` (different invocations possible):\r\n\r\n  ```\r\n  grep -o &#39;[^ ]*$&#39;\r\n  grep -o &#39;[[:xdigit:]]*$&#39;\r\n  ```",
                "title": "jq in CLI create error when I want to parse the output"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662064187,
                "creation_date": 1662064187,
                "answer_id": 73575119,
                "question_id": 56169821,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` is a tool for parsing and transforming JSON documents. What you have shown is not legal JSON. It is however a legal YAML document and can be transformed with [`yq`](https://mikefarah.gitbook.io/yq/). `yq` uses jq-like syntax, but can handle JSON, YAML, XML, and CSV files.\r\n\r\n    slug=$(hassio snapshots new --name=&quot;${name}&quot; | yq &#39;.slug&#39;)",
                "title": "jq in CLI create error when I want to parse the output"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1662110694,
        "creation_date": 1558013494,
        "question_id": 56169821,
        "body_markdown": "Using Home Assistant 0.92 to test my CLI for creating automated backuping. After a successful backup, the command responds with an output and I need to catch that value. I&#39;m trying to use jq to parse it but only get an error.\r\n\r\n```\r\n$ hassio snapshots new --name&quot;Testbackup&quot;\r\n```\r\nThis gives an output of ```slug: 07afd144``` and I want to catch ```07afd144```\r\n\r\nTried following:\r\n```\r\n$ hassio snapshots new --name&quot;Testbackup&quot; | jq --raw-output &#39;.data.slug&#39;\r\n```\r\nThis gives an output of ```parse error: Invalid numeric literal at line 1, column 5```\r\n\r\nThe final result is planned to be:\r\n\r\n```slug=$(hassio snapshots new --name=&quot;${name}&quot; | jq --raw-output &#39;.data.slug&#39;)``` \r\n\r\nwhere ```${slug}=07afd144```\r\n\r\nWhat am I doing wrong?",
        "link": "https://stackoverflow.com/questions/56169821/jq-in-cli-create-error-when-i-want-to-parse-the-output",
        "title": "jq in CLI create error when I want to parse the output"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1558022759,
                "creation_date": 1558022759,
                "answer_id": 56172594,
                "question_id": 56172168,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I might be missing some simpler solution, but the following works :\r\n\r\n    map(select(. as $in | [&quot;a99&quot;,&quot;a101&quot;,&quot;a108&quot;] | contains([$in])))\r\n\r\nReplace the `[&quot;a99&quot;,&quot;a101&quot;,&quot;a108&quot;]` hardcoded array by your slurped variable.\r\n\r\nYou can [try it here](https://jqplay.org/s/hQ3ziN5WH8) !\r\n\r\n",
                "title": "jq 1.5 print items from array that is inside another array"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1558025482,
                "last_edit_date": 1558025482,
                "creation_date": 1558023165,
                "answer_id": 56172694,
                "question_id": 56172168,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can port `IN` function from jq 1.6 to 1.5 and use:\r\n```\r\ndef IN(s): any(s == .; .);\r\nmap(select(IN($filter_array[])))\r\n```\r\nOr even shorter:\r\n```\r\nmap(select(any($filter_array[]==.;.)))\r\n```",
                "title": "jq 1.5 print items from array that is inside another array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1558031804,
                "last_edit_date": 1558031804,
                "creation_date": 1558030359,
                "answer_id": 56174373,
                "question_id": 56172168,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the example, the arrays in the input stream are sorted (in jq&#39;s `sort` order), so it is worth noting that in such cases, a more efficient solution is possible using the `bsearch` built-in, or perhaps even better, the definition of `intersection/2` given at https://rosettacode.org/wiki/Set#Finite_Sets_of_JSON_Entities\r\n\r\nFor ease of reference, here it is:\r\n\r\n    def intersection($A;$B):\r\n      def pop:\r\n        .[0] as $i\r\n        | .[1] as $j\r\n        | if $i == ($A|length) or $j == ($B|length) then empty\r\n          elif $A[$i] == $B[$j] then $A[$i], ([$i+1, $j+1] | pop)\r\n          elif $A[$i] &lt;  $B[$j] then [$i+1, $j] | pop\r\n          else [$i, $j+1] | pop\r\n          end;\r\n      [[0,0] | pop];\r\n\r\nAssuming a jq invocation such as:\r\n\r\n    jq -c --argjson filter &#39;[&quot;a99&quot;,&quot;a101&quot;,&quot;a108&quot;]&#39; -f intersections.jq input.json\r\n\r\nan appropriate filter would be:\r\n\r\n    ($filter | sort) as $sorted\r\n    | intersection(.; $sorted)\r\n\r\n(Of course if $filter is already presented in jq&#39;s sort order, then the initial sort can be skipped, or replaced by a check.)\r\n\r\n## Output\r\n\r\n    [&quot;a101&quot;,&quot;a108&quot;]\r\n    [&quot;a108&quot;]\r\n    [&quot;a99&quot;]\r\n    [&quot;a108&quot;]\r\n\r\n## Unsorted arrays\r\n\r\nIn practice, jq&#39;s builtin `sort` filter is usually so fast that it might be worthwhile simply sorting the arrays in order to use `intersection` as defined above.\r\n",
                "title": "jq 1.5 print items from array that is inside another array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1558031804,
        "creation_date": 1558021141,
        "last_edit_date": 1558024500,
        "question_id": 56172168,
        "body_markdown": "Incoming json file contains json array per row eg:\r\n\r\n    [&quot;a100&quot;,&quot;a101&quot;,&quot;a102&quot;,&quot;a103&quot;,&quot;a104&quot;,&quot;a105&quot;,&quot;a106&quot;,&quot;a107&quot;,&quot;a108&quot;]\r\n    [&quot;a100&quot;,&quot;a102&quot;,&quot;a103&quot;,&quot;a106&quot;,&quot;a107&quot;,&quot;a108&quot;]\r\n    [&quot;a100&quot;,&quot;a99&quot;]\r\n    [&quot;a107&quot;,&quot;a108&quot;]\r\n\r\na &quot;filter array&quot; would be `[&quot;a99&quot;,&quot;a101&quot;,&quot;a108&quot;]` so I can `slurpfile` it\r\n\r\nTrying to figure out how to print only values that are inside &quot;filter array&quot;, eg the output:\r\n\r\n    [&quot;a101&quot;,&quot;a108&quot;]\r\n    [&quot;a108&quot;]\r\n    [&quot;a99&quot;]\r\n    [&quot;a108&quot;]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56172168/jq-1-5-print-items-from-array-that-is-inside-another-array",
        "title": "jq 1.5 print items from array that is inside another array"
    },
    {
        "tags": [
            "json",
            "group-by",
            "jq",
            "data-partitioning"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1558071890,
                "last_edit_date": 1558071890,
                "creation_date": 1558041594,
                "answer_id": 56176760,
                "question_id": 56176686,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One option is to use `reduce`:\r\n```\r\nreduce .[] as $x\r\n([]; if $x &lt; 5 then .[0] += [$x] else .[1] += [$x] end)\r\n```\r\nThis will produce:\r\n```\r\n[[1,2,3,4],[5,6,7]]\r\n```",
                "title": "jq: partition based on a filter"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1558043353,
                "creation_date": 1558043353,
                "answer_id": 56177030,
                "question_id": 56176686,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq has a built-in filter for grouping by some (possibly multi-valued) criterion:\r\n\r\n    jq -nc &#39;[1,2,3,4,5,6,7] | group_by(. &lt; 5)&#39;\r\n\r\nproduces:\r\n\r\n    [[5,6,7],[1,2,3,4]]",
                "title": "jq: partition based on a filter"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1558071890,
        "creation_date": 1558041111,
        "last_edit_date": 1558062864,
        "question_id": 56176686,
        "body_markdown": "Let&#39;s say I have the following: \r\n\r\n    jq &#39;map(select(. &gt;= 5))&#39;\r\n\r\n\r\ngiven `[1,2,3,4,5,6,7]` it returns: \r\n\r\n    [5,6,7]\r\n\r\n\r\nI also have \r\n\r\n    jq &#39;map(select(. &lt; 5))&#39;\r\n\r\nwhich given the same data, returns `[1,2,3,4]`. How can I do these complementary queries at the same time, so that I receive for example: \r\n\r\n    [1,2,3,4], [5,6,7]\r\n\r\n\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/56176686/jq-partition-based-on-a-filter",
        "title": "jq: partition based on a filter"
    },
    {
        "tags": [
            "json",
            "group-by",
            "jq",
            "data-partitioning"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1558072134,
                "post_id": 56179292,
                "comment_id": 98986309,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 182786,
                    "reputation": 1802,
                    "user_id": 9199853,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/ad56b490734b7a14b3825ed4d6b025e6?s=256&d=identicon&r=PG",
                    "display_name": "Maths noob",
                    "link": "https://stackoverflow.com/users/9199853/maths-noob"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1558076628,
                "post_id": 56179292,
                "comment_id": 98988025,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1558077318,
                "post_id": 56179292,
                "comment_id": 98988369,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 182786,
                    "reputation": 1802,
                    "user_id": 9199853,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/ad56b490734b7a14b3825ed4d6b025e6?s=256&d=identicon&r=PG",
                    "display_name": "Maths noob",
                    "link": "https://stackoverflow.com/users/9199853/maths-noob"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1558079413,
                "post_id": 56179292,
                "comment_id": 98989359,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1558079735,
                "post_id": 56179292,
                "comment_id": 98989514,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1558081640,
                "last_edit_date": 1558081640,
                "creation_date": 1558078099,
                "answer_id": 56181632,
                "question_id": 56179292,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since stackoverflow.com is not a coding service, I&#39;ll confine this response to the first question, with the hope that it will convince you that learning jq is worth the effort.\r\n\r\nLet&#39;s begin by refining the question about the counts of the lists \r\n&quot;which are/are not empty&quot; to emphasize that the first number in the answer should correspond to the number of empty lists (2), and the second number to the rest (3).  That is, the required answer should be `[2,3]`.\r\n\r\n## Solution using built-in filters\r\n\r\nThe next step might be to ask whether `group_by` can be used.  If the ordering did not matter, we could simply write:\r\n\r\n    group_by(length==0) | map(length)\r\n\r\nThis returns `[3,2]`, which is not quite what we want.  It&#39;s now worth checking the documentation about what `group_by` is supposed to do. On checking the details at https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions,\r\nwe see that by design `group_by` does indeed sort by the grouping value.\r\n\r\nSince in jq, `false &lt; true`, we could fix our first attempt by writing:\r\n\r\n    group_by(length &gt; 0) | map(length)\r\n\r\nThat&#39;s nice, but since `group_by` is doing so much work when all we really need is a way to count, it&#39;s clear we should be able to come up with a more efficient (and hopefully less opaque) solution.  \r\n\r\n## An efficient solution\r\n\r\n\r\nAt its core the problem boils down to counting, so let&#39;s define a generic `tabulate` filter for producing the counts of distinct string values.  Here&#39;s a def that will suffice for present purposes:\r\n\r\n    # Produce a JSON object recording the counts of distinct\r\n    # values in the given stream, which is assumed to consist \r\n    # solely of strings.\r\n    def tabulate(stream):\r\n      reduce stream as $s ({}; .[$s] += 1);\r\n\r\nAn efficient solution can now be written down in just two lines:\r\n\r\n    tabulate(.[] | length==0 | tostring )\r\n    | [.[&quot;true&quot;, &quot;false&quot;]]\r\n\r\n\r\nQED\r\n\r\n## p.s.\r\n\r\nThe function named `tabulate` above is sometimes called `bow` (for &quot;bag of words&quot;).  In some ways, that would be a better name, especially as it would make sense to reserve the name `tabulate` for similar functionality that would work for arbitrary streams.\r\n\r\n    \r\n\r\n",
                "title": "jq: groupby and nested json arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1558081640,
        "creation_date": 1558064773,
        "question_id": 56179292,
        "body_markdown": "Let&#39;s say I have: `[[1,2], [3,9], [4,2], [], []]`\r\n\r\nI would like to know the scripts to get: \r\n\r\n - The number of nested lists which are/are not non-empty. ie want to get: `[3,2]` \r\n\r\n - The number of nested lists which contain or not contain number 3. ie want to get: `[1,4]`\r\n\r\n - The number of nested lists for which the sum of the elements is/isn&#39;t less than `4`. ie want to get: `[3,2]`\r\n\r\n\r\nie basic examples of nested data partition.",
        "link": "https://stackoverflow.com/questions/56179292/jq-groupby-and-nested-json-arrays",
        "title": "jq: groupby and nested json arrays"
    },
    {
        "tags": [
            "json",
            "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": 2,
                "creation_date": 1558202701,
                "post_id": 56201393,
                "comment_id": 99025947,
                "content_license": "CC BY-SA 4.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": 1558204254,
                "post_id": 56201393,
                "comment_id": 99026340,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13833884,
                    "reputation": 61,
                    "user_id": 9985965,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d5993921d986829bc79c4aa8b26d6fad?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dotHello",
                    "link": "https://stackoverflow.com/users/9985965/dothello"
                },
                "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": 1558205541,
                "post_id": 56201393,
                "comment_id": 99026573,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1558203880,
                "last_edit_date": 1558203880,
                "creation_date": 1558202301,
                "answer_id": 56201527,
                "question_id": 56201393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. Quote all variable expansions,\r\n2. To make sure that `curlData` is a valid JSON value with properly escaped special-characters etc., use [tag:jq] for producing it.\r\n```\r\ncurlData=&quot;$(jq --arg name &quot;$repoName&quot; --arg desc &quot;$repoDescription&quot; -nc &#39;{name:$name,description:$desc}&#39;)&quot;\r\ncurl --data &quot;$curlData&quot; &quot;$apiURL&quot;\r\n```",
                "title": "Passing variables (containing spaces) to curl --data field"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1558203653,
                "creation_date": 1558203653,
                "answer_id": 56201715,
                "question_id": 56201393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have access to any form of package management, I highly recommend `jo`.\r\n```\r\ncurlData=$(jo name=&quot;$repoName&quot; description=&quot;$repoDescription&quot;)\r\ncurl -d &quot;$curlData&quot; &quot;$apiURL&quot;",
                "title": "Passing variables (containing spaces) to curl --data field"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1661082872,
                "creation_date": 1661082872,
                "answer_id": 73434171,
                "question_id": 56201393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I had similar issue, which was very difficult to even understand. I used the below construct in a number of curl commands present in my shell script. It always worked like a charm. Until one fine day I had to pass a variable which was string containing spaces (eg. modelName=&quot;Abc def&quot;).\r\n\r\n      curl -X &#39;PUT&#39; \\\r\n      &#39;http://localhost:43124/api/v1/devices/&#39;$Id&#39;&#39; \\\r\n      -H &#39;accept:*/*&#39; \\\r\n      -H &#39;Authorization:Bearer &#39;$token&#39;&#39; \\\r\n      -H &#39;Content-Type:application/json&#39; \\\r\n      -d &#39;{\r\n      &quot;modelName&quot;:&quot;&#39;$modelName&#39;&quot;,\r\n      &quot;serialNumber&quot;:&quot;&#39;$childSN&#39;&quot;\r\n    }&#39;\r\n\r\n\r\nWorked for me after the below change \r\n\r\n     curl -X &#39;PUT&#39; \\\r\n      &#39;http://localhost:43124/api/v1/devices/&#39;$Id&#39;&#39; \\\r\n      -H &#39;accept:*/*&#39; \\\r\n      -H &#39;Authorization:Bearer &#39;$token&#39;&#39; \\\r\n      -H &#39;Content-Type:application/json&#39; \\\r\n      -d &#39;{\r\n      &quot;modelName&quot;:&#39;\\&quot;&quot;$modelName&quot;\\&quot;&#39;,\r\n      &quot;serialNumber&quot;:&quot;&#39;$childSN&#39;&quot;\r\n    }&#39;\r\n\r\nI took help from the accepted answer by @oguz. Pasting this response , just in case anyone is in similar situation ",
                "title": "Passing variables (containing spaces) to curl --data field"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1666425257,
        "creation_date": 1558201314,
        "last_edit_date": 1666425257,
        "question_id": 56201393,
        "body_markdown": "Arguments containing spaces will not properly pass to the curl command.\r\nQuotes are not passed correctly in the --data field.\r\n\r\nIf I just echo the variable &#39;curlData&#39; that I use in the curl command I get everything as it should be; ex :\r\n\r\n    $echo $curlData\r\n    &#39;{&quot;name&quot;:&quot;jason&quot;,&quot;description&quot;,&quot;service&quot;}&#39;\r\n\r\nI don&#39;t understand why curl dont expend this &#39;curlData&#39; variable as expected:\r\n\r\n    curl --data &#39;{&quot;name&quot;:&quot;jason&quot;,&quot;description&quot;,&quot;service&quot;}&#39;\r\n\r\nHere&#39;s a sample of my code:\r\n\r\n    read -p &quot;Name : &quot; repoName\r\n    read -p &quot;Description []: &quot; repoDescription\r\n    \r\n    curlData=&quot;&#39;&quot;{&#39;&quot;&#39;name&#39;&quot;&#39;:&#39;&quot;&#39;$repoName&#39;&quot;&#39;,&#39;&quot;&#39;descripton&#39;&quot;&#39;:&#39;&quot;&#39;$repoDescription&#39;&quot;&#39;}&quot;&#39;&quot;\r\n    \r\n    curl --data $curlData $apiURL \r\n\r\nAnd the error:\r\n\r\n    curl: (3) [globbing] unmatched close brace/bracket in column 26\r\n\r\nThank your for your help, I feel i&#39;m in Quote-ception right now.\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56201393/passing-variables-containing-spaces-to-curl-data-field",
        "title": "Passing variables (containing spaces) to curl --data field"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 11,
                "last_activity_date": 1558214482,
                "creation_date": 1558214482,
                "answer_id": 56202936,
                "question_id": 56202911,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a `bash` feature which lets you redirect stdin from a literal string with the `&lt;&lt;&lt;` operator:\r\n\r\n```\r\n$ json=&#39;{&quot;field&quot;: 3}&#39;\r\n$ jq .field &lt;&lt;&lt; &quot;$json&quot;\r\n3\r\n```\r\n\r\nIt of course also works with inline JSON:\r\n\r\n```\r\n$ jq .field &lt;&lt;&lt; &#39;{&quot;field&quot;: 3}&#39;\r\n3\r\n```",
                "title": "jq read inline string, not from stdin"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1715771426,
                "last_edit_date": 1715771426,
                "creation_date": 1558215326,
                "answer_id": 56203023,
                "question_id": 56202911,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "``` none\r\n$ jq -n &#39;$in.foo&#39; --argjson in &#39;{&quot;foo&quot;:&quot;bar&quot;}&#39;\r\n&quot;bar&quot;\r\n$ jq -n &#39;$foo&#39; --arg foo &#39;bar&#39;\r\n&quot;bar&quot;\r\n```",
                "title": "jq read inline string, not from stdin"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1558217610,
                "last_edit_date": 1558217610,
                "creation_date": 1558217035,
                "answer_id": 56203180,
                "question_id": 56202911,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A third possibility is to read a string from the environment:\r\n\r\n    $ string=&#39;{&quot;field&quot;: 33}&#39; jq -n &#39;$ENV.string|fromjson.field&#39;\r\n    33\r\n\r\nThe fourth (and essentially only other) possibility is to use positional arguments (jq 1.5 and higher):\r\n\r\n\r\n    $ jq -n &#39;$ARGS.positional[0]|fromjson.field&#39; --args &#39;{&quot;field&quot;: 333}&#39;\r\n    333",
                "title": "jq read inline string, not from stdin"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": -3,
                "last_activity_date": 1563205951,
                "creation_date": 1563205951,
                "answer_id": 57043296,
                "question_id": 56202911,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple call using `-n` should be enough:\r\n\r\n    jq -nr &quot;${my_json}|.field&quot;\r\n\r\nexample:\r\n\r\n    &gt; jq -nr &#39;{foo: &quot;bar&quot;,baz: &quot;test&quot;}|.foo&#39;\r\n    bar\r\n\r\n\r\n",
                "title": "jq read inline string, not from stdin"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 13,
        "last_activity_date": 1715771426,
        "creation_date": 1558214130,
        "last_edit_date": 1559355372,
        "question_id": 56202911,
        "body_markdown": "This can read from a file:\r\n\r\n    jq &#39;.c | fromjson | .id&#39; my_file.json\r\n\r\nthis reads from stdin:\r\n\r\n    echo &quot;$my_json&quot; | jq -r &#39;.field&#39;\r\n\r\nwhat if I just want to read from a string like so:\r\n\r\n    jq &#39;.field&#39; &quot;$my_json&quot;\r\n\r\nhow to do that?",
        "link": "https://stackoverflow.com/questions/56202911/jq-read-inline-string-not-from-stdin",
        "title": "jq read inline string, not from stdin"
    },
    {
        "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": 2,
                "creation_date": 1558246500,
                "post_id": 56205157,
                "comment_id": 99032374,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14813778,
                    "reputation": 23,
                    "user_id": 11323451,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-uCb2UglihP0/AAAAAAAAAAI/AAAAAAAAAAA/AGDgw-h1F2R7szTNPCiS4tDGWexxiAUmCg/mo/s256-rj/photo.jpg",
                    "display_name": "Taskin Alam Jim",
                    "link": "https://stackoverflow.com/users/11323451/taskin-alam-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": 1558248364,
                "post_id": 56205157,
                "comment_id": 99032652,
                "content_license": "CC BY-SA 4.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": 1558249781,
                "post_id": 56205157,
                "comment_id": 99032869,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14813778,
                    "reputation": 23,
                    "user_id": 11323451,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-uCb2UglihP0/AAAAAAAAAAI/AAAAAAAAAAA/AGDgw-h1F2R7szTNPCiS4tDGWexxiAUmCg/mo/s256-rj/photo.jpg",
                    "display_name": "Taskin Alam Jim",
                    "link": "https://stackoverflow.com/users/11323451/taskin-alam-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": 1558280570,
                "post_id": 56205157,
                "comment_id": 99039993,
                "content_license": "CC BY-SA 4.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": 1558289571,
                "post_id": 56205157,
                "comment_id": 99042550,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14813778,
                    "reputation": 23,
                    "user_id": 11323451,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-uCb2UglihP0/AAAAAAAAAAI/AAAAAAAAAAA/AGDgw-h1F2R7szTNPCiS4tDGWexxiAUmCg/mo/s256-rj/photo.jpg",
                    "display_name": "Taskin Alam Jim",
                    "link": "https://stackoverflow.com/users/11323451/taskin-alam-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": 1558318505,
                "post_id": 56205157,
                "comment_id": 99048174,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1558509292,
                "last_edit_date": 1558509292,
                "creation_date": 1558319944,
                "answer_id": 56213704,
                "question_id": 56205157,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It would seem that the piece of the puzzle you&#39;re missing is the ability to pass values into jq using command-line options such as `--arg`.  The following should therefore get you over the hump:\r\n\r\n    while read -r ts ip\r\n    do\r\n      jq --arg ts &quot;$ts&quot; --arg ip &quot;$ip&quot; &#39;\r\n        select(.timestamp==$ts and .ip_str==$ip)\r\n      &#39; extract_3month_fromshodan.json\r\n    done &lt; &lt;(cat&lt;&lt;EOF\t  \r\n    2018-08-11T04:56:17.312039 126.100.105.198\r\n    EOF\r\n    )\r\n\r\n## inputfile.txt \r\nSo if `inputfile.txt` contains the ts-ip pairs as above, you could write:\r\n\r\n    while read -r ts ip\r\n    do\r\n      jq --arg ts &quot;$ts&quot; --arg ip &quot;$ip&quot; &#39;\r\n        select(.timestamp==$ts and .ip_str==$ip)\r\n      &#39; extract_3month_fromshodan.json\r\n    done &lt; inputfile.txt\r\n\r\n\r\n",
                "title": "How to get json banner by selecting key:value pair"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1558509292,
        "creation_date": 1558245542,
        "last_edit_date": 1558318289,
        "question_id": 56205157,
        "body_markdown": "I have a json banner file as &quot;extract_3month_fromshodan.json&quot; which have key-value for multiple tag i.e. ip_str=XXX.XX.XXX.XX, port=80, timestamp=&quot;2018-08-11T04:56:17.312039&quot;, data= &quot;210!connection successful&quot; etc. In this way the file has banner for almost 400 IP&#39;s.\r\n\r\nSample of source/json banner (extract_3month_fromshodan.json)  file:\r\n    \r\n    {\r\n      &quot;asn&quot;: &quot;AS17676&quot;,\r\n      &quot;hash&quot;: -619087650,\r\n      &quot;ip&quot;: 2120548325,\r\n      &quot;isp&quot;: &quot;Softbank BB&quot;,\r\n      &quot;transport&quot;: &quot;udp&quot;,\r\n      &quot;data&quot;: &quot;HTTP/1.1 200 OK\\r\\nCache-Control: max-age=120\\r\\nST:  upnp:rootdevice\\r\\nUSN: uuid:12342409-1234-1234-5678-ee1234cc5678::upnp:rootdevice\\r\\nEXT:\\r\\nServer: miniupnpd/1.0 UPnP/1.0\\r\\nLocation: http://192.168.2.1:52869/picsdesc.xml\\r\\n\\r\\n&quot;,\r\n      &quot;port&quot;: 1900,\r\n      &quot;hostnames&quot;: [\r\n      &quot;softbank126100255229.bbtec.net&quot;\r\n     ],\r\n      &quot;location&quot;: {\r\n      &quot;city&quot;: &quot;Toyota&quot;,\r\n      &quot;region_code&quot;: &quot;01&quot;,\r\n      &quot;area_code&quot;: null,\r\n      &quot;longitude&quot;: 137.14999999999998,\r\n      &quot;country_code3&quot;: &quot;JPN&quot;,\r\n      &quot;latitude&quot;: 35.08330000000001,\r\n      &quot;postal_code&quot;: &quot;457-0844&quot;,\r\n      &quot;dma_code&quot;: null,\r\n      &quot;country_code&quot;: &quot;JP&quot;,\r\n      &quot;country_name&quot;: &quot;Japan&quot;\r\n     },\r\n      &quot;timestamp&quot;: **&quot;2018-09-12T15:42:34.012436&quot;,**\r\n      &quot;domains&quot;: [\r\n      &quot;bbtec.net&quot;\r\n     ],\r\n      &quot;org&quot;: &quot;XXXXXX BB&quot;,\r\n      &quot;os&quot;: null,\r\n      &quot;_shodan&quot;: {\r\n      &quot;crawler&quot;: &quot;d264629436af1b777b3b513ca6ed1404d7395d80&quot;,\r\n      &quot;options&quot;: {},\r\n      &quot;module&quot;: &quot;upnp&quot;,\r\n      &quot;id&quot;: null\r\n     },\r\n      &quot;opts&quot;: {},\r\n      &quot;ip_str&quot;: **&quot;126.100.255.229&quot;**\r\n    }\r\n\r\n    {\r\n     &quot;asn&quot;: &quot;AS17676&quot;,\r\n     &quot;hash&quot;: 1371060454,\r\n     &quot;ip&quot;: 2120509894,\r\n     &quot;isp&quot;: &quot;Softbank BB&quot;,\r\n     &quot;transport&quot;: &quot;udp&quot;,\r\n     &quot;data&quot;: &quot;HTTP/1.1 200 OK\\r\\nCache-Control: max-age=1800\\r\\nST: upnp:rootdevice\\r\\nUSN: uuid:63041253-1019-2006-1228-00018efed688::upnp:rootdevice\\r\\nEXT:\\r\\nServer: OS 1.0 UPnP/1.0 Realtek/V1.3\\r\\nLocation: http://192.168.2.1:52881/simplecfg.xml\\r\\n\\r\\n&quot;,\r\n     &quot;port&quot;: 1900,\r\n     &quot;hostnames&quot;: [\r\n     &quot;softbank126100105198.bbtec.net&quot;\r\n    ],\r\n     &quot;location&quot;: {\r\n     &quot;city&quot;: &quot;Yamashitacho&quot;,\r\n     &quot;region_code&quot;: &quot;18&quot;,\r\n     &quot;area_code&quot;: null,\r\n     &quot;longitude&quot;: 130.55,\r\n     &quot;country_code3&quot;: &quot;JPN&quot;,\r\n     &quot;latitude&quot;: 31.58330000000001,\r\n     &quot;postal_code&quot;: &quot;892-0816&quot;,\r\n     &quot;dma_code&quot;: null,\r\n     &quot;country_code&quot;: &quot;JP&quot;,\r\n     &quot;country_name&quot;: &quot;Japan&quot;\r\n    },\r\n     &quot;timestamp&quot;: **&quot;2018-08-11T04:56:17.312039&quot;**,\r\n     &quot;domains&quot;: [\r\n     &quot;bbtec.net&quot;\r\n    ],\r\n     &quot;org&quot;: &quot;Softbank BB&quot;,\r\n     &quot;os&quot;: null,\r\n     &quot;_shodan&quot;: {\r\n     &quot;crawler&quot;: &quot;6ff540e4d43ec69d8de2a7b60e1de2d9ddb406dc&quot;,\r\n     &quot;options&quot;: {},\r\n     &quot;module&quot;: &quot;upnp&quot;,\r\n     &quot;id&quot;: null\r\n     },\r\n     &quot;opts&quot;: {},\r\n     &quot;ip_str&quot;: **&quot;126.100.105.198&quot;**\r\n    }\r\n\r\nNow I want to get another new json banner from the source json file above (extract_3month_fromshodan.json) by filtering  the parameter i.e. ip_str=&quot;126.100.105.198&quot; and timestamp=&quot;2018-08-11T04:56:17.312039&quot;. \r\nThe iterative values for each ip_str and timestamp are to come from separate .csv and/or .txt file. And the output (filtered banner) is needed to save as json format.\r\n\r\nWhat I have done so far :\r\n\r\n    jq &#39;. | select (.timestamp=&quot;2018-08-11T04:56:17.312039&quot;) | select(.ip_str==&quot;&quot;12X.10X.XXX.X9X&quot;)&#39; extract_3month_fromshodan.json &gt; all.json\r\n\r\nIn this way I need to get for almost 290 times of ip_str,timestamp values which are kept in a csv and or .txt file. What I have done is for single ip_str and timestamp. But I could not able to run the above command as a loop.\r\n\r\n\r\n\r\nExpected Output :\r\n\r\nI should get extracted/filtered json banner including all relevant fields w.r.t 290 IPs and timestamp (kept in csv or txt file) from the main json banner (containing more than 500 IPs). The extraction should be done automatically i.e. like a loop command by one/group of code. the values (timestamp and ip_str) for loop will come from .csv or .txt file.\r\n\r\nFor the mini use case here (filtering 1 out of two ), In input,I have input banner for two IPs i.e. 126.100.255.229 and 126.100.105.198. Now after running loop command I should get banner for ip_str=126.100.105.198 having timestamp = 2018-08-11T04:56:17.312039 as below. In real case I will have banner for more than 500 IPs and timestamp in one json file from I which I have to filtered for 290 IPs and timestamp.\r\n\r\nOutput :\r\n\r\n    {\r\n      &quot;asn&quot;: &quot;AS17676&quot;,\r\n      &quot;hash&quot;: 1371060454,\r\n      &quot;ip&quot;: 2120509894,\r\n      &quot;isp&quot;: &quot;Softbank BB&quot;,\r\n      &quot;transport&quot;: &quot;udp&quot;,\r\n      &quot;data&quot;: &quot;HTTP/1.1 200 OK\\r\\nCache-Control: max-age=1800\\r\\nST: upnp:rootdevice\\r\\nUSN: uuid:63041253-1019-2006-1228-00018efed688::upnp:rootdevice\\r\\nEXT:\\r\\nServer: OS 1.0 UPnP/1.0 Realtek/V1.3\\r\\nLocation:   http://192.168.2.1:52881/simplecfg.xml\\r\\n\\r\\n&quot;,\r\n      &quot;port&quot;: 1900,\r\n      &quot;hostnames&quot;: [\r\n      &quot;softbank126100105198.bbtec.net&quot;\r\n    ],\r\n      &quot;location&quot;: {\r\n      &quot;city&quot;: &quot;Yamashitacho&quot;,\r\n      &quot;region_code&quot;: &quot;18&quot;,\r\n      &quot;area_code&quot;: null,\r\n      &quot;longitude&quot;: 130.55,\r\n      &quot;country_code3&quot;: &quot;JPN&quot;,\r\n      &quot;latitude&quot;: 31.58330000000001,\r\n      &quot;postal_code&quot;: &quot;892-0816&quot;,\r\n      &quot;dma_code&quot;: null,\r\n      &quot;country_code&quot;: &quot;JP&quot;,\r\n      &quot;country_name&quot;: &quot;Japan&quot;\r\n    },\r\n      &quot;timestamp&quot;: &quot;2018-08-11T04:56:17.312039&quot;,\r\n      &quot;domains&quot;: [\r\n      &quot;bbtec.net&quot;\r\n    ],\r\n      &quot;org&quot;: &quot;Softbank BB&quot;,\r\n      &quot;os&quot;: null,\r\n      &quot;_shodan&quot;: {\r\n      &quot;crawler&quot;: &quot;6ff540e4d43ec69d8de2a7b60e1de2d9ddb406dc&quot;,\r\n      &quot;options&quot;: {},\r\n      &quot;module&quot;: &quot;upnp&quot;,\r\n      &quot;id&quot;: null\r\n     },\r\n      &quot;opts&quot;: {},\r\n      &quot;ip_str&quot;: **&quot;126.100.105.198&quot;**\r\n    }\r\n\r\nActual Result:\r\n \r\nI am getting the filtered output/json banner based on filter parameter (here in this case ip_str and timestamp) for one single combination by running the above code.\r\n     jq &#39;. | select (.timestamp=&quot;2018-08-11T04:56:17.312039&quot;) | select(.ip_str==&quot;126.100.105.198&quot;)&#39; extract_3month_fromshodan.json &gt; all.json\r\n\r\nActual Problem:\r\n\r\nBut the problem is I have to run the above code manually for 290 times for  IP&#39;s which is trouble some. So, how can I use this command so that it could run for other 290 times repetitively automatically.",
        "link": "https://stackoverflow.com/questions/56205157/how-to-get-json-banner-by-selecting-keyvalue-pair",
        "title": "How to get json banner by selecting key:value pair"
    },
    {
        "tags": [
            "json",
            "shell",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12576808,
                    "reputation": 798,
                    "user_id": 9211311,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cfdda75556cbed7daf30a26d7d027dce?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sumith08",
                    "link": "https://stackoverflow.com/users/9211311/sumith08"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1558256828,
                "post_id": 56206151,
                "comment_id": 99034253,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1558258627,
                "last_edit_date": 1558258627,
                "creation_date": 1558255728,
                "answer_id": 56206176,
                "question_id": 56206151,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. Don&#39;t use double quotes instead of single ones unless you want anything in the quoted string to be expanded,\r\n2. Use [tag:jq] for parsing JSON values, sed is a line-oriented tool and can&#39;t parse JSON syntax-wise.\r\n\r\nE.g:\r\n```\r\nid=$(curl -H &#39;Authorization:token xxxxxxxxxxxxxxxxxxxxxx&#39; -H &#39;Content-Type: application/json&#39; &#39;https://api.github.com/repos/octocat/Hello-World/releases/tags/v1.0.0&#39; |\r\n  jq -r &#39;.id&#39;)\r\necho &quot;$id&quot;\r\n```",
                "title": "Unable to extract specific value of json file using sed in shell script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1558257899,
                "creation_date": 1558257899,
                "answer_id": 56206443,
                "question_id": 56206151,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I corrected the sed command and it worked. \r\n\r\nThe double backslashes `\\\\` where escaping the command so I changed it to single \r\nbackslash `\\`\r\nBelow is the modified shell script.\r\n\r\n\r\n    release=$(curl -H &quot;Authorization:token xxxxxxxxxxxxxxxxxxxxxx&quot; -H &quot;Content-Type: application/json&quot; https://api.github.com/repos/octocat/Hello-World/releases/tags/v1.0.0)\r\n    id=$(echo &quot;$release&quot; | sed -n -e &#39;s/&quot;id&quot;:\\ \\([0-9]\\+\\),/\\1/p&#39; | head -n 1 | sed &#39;s/[[:blank:]]//g&#39;)\r\n    echo $id",
                "title": "Unable to extract specific value of json file using sed in shell script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1558272616,
                "creation_date": 1558272616,
                "answer_id": 56208302,
                "question_id": 56206151,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The double backslashes match a literal backslash, that is why your code did not work.\r\n\r\nYou may try this grep:\r\n\r\n    id=$(grep -o -m 1 &#39;&quot;id&quot;: [0-9]\\{1,\\},&#39; &lt;&lt;&lt; &quot;$release&quot; | sed &#39;s/&quot;id&quot;: //&#39; | sed &#39;s/,//&#39;)\r\n\r\n`-m 1` will get the first occurrence only (check https://stackoverflow.com/questions/14093452/grep-only-the-first-match-and-stop), `-o` will get the regex match text - `&quot;id&quot;:` + 1 or mor digits and a comma, and `sed &#39;s/&quot;id&quot;: //&#39; | sed &#39;s/,//&#39;` will remove `&quot;id&quot;:` and the comma from the return text.",
                "title": "Unable to extract specific value of json file using sed in shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1666425280,
        "creation_date": 1558255521,
        "last_edit_date": 1666425280,
        "question_id": 56206151,
        "body_markdown": "I am using sed command for extracting a value which I get from the output after doing curl. Below is my shell script.\r\n\r\n    #!/bin/bash\r\n    release=$(curl -H &quot;Authorization:token xxxxxxxxxxxxxxxxxxxxxx&quot; -H &quot;Content-Type: application/json&quot; https://api.github.com/repos/octocat/Hello-World/releases/tags/v1.0.0)\r\n    id=$(echo &quot;$release&quot; |sed -n -e &#39;s/&quot;id&quot;:\\\\ \\\\([0-9]\\\\+\\\\),/\\\\1/p&#39; | head -n 1 | sed &#39;s/[[:blank:]]//g&#39;)\r\n    echo $id\r\n\r\nThe output I got after curl is a json file. Below is the output\r\n\r\n    {\r\n     &quot;url&quot;: &quot;https://api.github.com/repos/octocat/Hello-World/releases/1&quot;,\r\n      &quot;html_url&quot;: &quot;https://github.com/octocat/Hello-World/releases/v1.0.0&quot;,\r\n      &quot;assets_url&quot;: &quot;https://api.github.com/repos/octocat/Hello- \r\n       World/releases/1/assets&quot;,\r\n       &quot;upload_url&quot;: &quot;https://uploads.github.com/repos/octocat/Hello- \r\n      World/releases/1/assets{?name,label}&quot;,\r\n      &quot;tarball_url&quot;: &quot;https://api.github.com/repos/octocat/Hello- \r\n      World/tarball/v1.0.0&quot;,\r\n      &quot;zipball_url&quot;: &quot;https://api.github.com/repos/octocat/Hello- \r\n     World/zipball/v1.0.0&quot;,\r\n     &quot;id&quot;: 1234332,\r\n      &quot;node_id&quot;: &quot;MDc6UmVsZWFzZTE=&quot;,\r\n      &quot;tag_name&quot;: &quot;v1.0.0&quot;,\r\n      &quot;target_commitish&quot;: &quot;master&quot;,\r\n      &quot;name&quot;: &quot;v1.0.0&quot;,\r\n      &quot;body&quot;: &quot;Description of the release&quot;,\r\n      &quot;draft&quot;: false,\r\n      &quot;prerelease&quot;: false,\r\n      &quot;created_at&quot;: &quot;2013-02-27T19:35:32Z&quot;,\r\n      &quot;published_at&quot;: &quot;2013-02-27T19:35:32Z&quot;,\r\n      &quot;author&quot;: {\r\n       &quot;login&quot;: &quot;octocat&quot;,\r\n       &quot;id&quot;: 1353322,\r\n       &quot;node_id&quot;: &quot;MDQ6VXNlcjE=&quot;,\r\n       &quot;avatar_url&quot;: &quot;https://github.com/images/error/octocat_happy.gif&quot;,\r\n       &quot;gravatar_id&quot;: &quot;&quot;,\r\n       &quot;url&quot;: &quot;https://api.github.com/users/octocat&quot;,\r\n       &quot;html_url&quot;: &quot;https://github.com/octocat&quot;,\r\n       &quot;followers_url&quot;: &quot;https://api.github.com/users/octocat/followers&quot;,\r\n       &quot;following_url&quot;: \r\n       &quot;https://api.github.com/users/octocat/following{/other_user}&quot;,\r\n       &quot;gists_url&quot;: &quot;https://api.github.com/users/octocat/gists{/gist_id}&quot;,\r\n       &quot;starred_url&quot;: &quot;https://api.github.com/users/octocat/starred{/owner} \r\n       {/repo}&quot;,\r\n       &quot;subscriptions_url&quot;: \r\n       &quot;https://api.github.com/users/octocat/subscriptions&quot;,\r\n       &quot;organizations_url&quot;: &quot;https://api.github.com/users/octocat/orgs&quot;,\r\n        &quot;repos_url&quot;: &quot;https://api.github.com/users/octocat/repos&quot;,\r\n        &quot;events_url&quot;: &quot;https://api.github.com/users/octocat/events{/privacy}&quot;,\r\n         &quot;received_events_url&quot;: \r\n       &quot;https://api.github.com/users/octocat/received_events&quot;,\r\n       &quot;type&quot;: &quot;User&quot;,\r\n       &quot;site_admin&quot;: false\r\n       },\r\n      &quot;assets&quot;: [\r\n       {\r\n       &quot;url&quot;: &quot;https://api.github.com/repos/octocat/Hello- \r\n       World/releases/assets/1&quot;,\r\n      &quot;browser_download_url&quot;: &quot;https://github.com/octocat/Hello- \r\n      World/releases/download/v1.0.0/example.zip&quot;,\r\n       &quot;id&quot;: 56432211,\r\n       &quot;node_id&quot;: &quot;MDEyOlJlbGVhc2VBc3NldDE=&quot;,\r\n       &quot;name&quot;: &quot;example.zip&quot;,\r\n       &quot;label&quot;: &quot;short description&quot;,\r\n       &quot;state&quot;: &quot;uploaded&quot;,\r\n       &quot;content_type&quot;: &quot;application/zip&quot;,\r\n       &quot;size&quot;: 1024,\r\n       &quot;download_count&quot;: 42,\r\n       &quot;created_at&quot;: &quot;2013-02-27T19:35:32Z&quot;,\r\n       &quot;updated_at&quot;: &quot;2013-02-27T19:35:32Z&quot;,\r\n       &quot;uploader&quot;: {\r\n         &quot;login&quot;: &quot;octocat&quot;,\r\n         &quot;id&quot;: 5663322,\r\n         &quot;node_id&quot;: &quot;MDQ6VXNlcjE=&quot;,\r\n         &quot;avatar_url&quot;: &quot;https://github.com/images/error/octocat_happy.gif&quot;,\r\n         &quot;gravatar_id&quot;: &quot;&quot;,\r\n         &quot;url&quot;: &quot;https://api.github.com/users/octocat&quot;,\r\n         &quot;html_url&quot;: &quot;https://github.com/octocat&quot;,\r\n         &quot;followers_url&quot;: &quot;https://api.github.com/users/octocat/followers&quot;,\r\n         &quot;following_url&quot;: \r\n         &quot;https://api.github.com/users/octocat/following{/other_user}&quot;,\r\n         &quot;gists_url&quot;: &quot;https://api.github.com/users/octocat/gists{/gist_id}&quot;,\r\n         &quot;starred_url&quot;: &quot;https://api.github.com/users/octocat/starred{/owner} \r\n        {/repo}&quot;,\r\n         &quot;subscriptions_url&quot;: \r\n         &quot;https://api.github.com/users/octocat/subscriptions&quot;,\r\n         &quot;organizations_url&quot;: &quot;https://api.github.com/users/octocat/orgs&quot;,\r\n         &quot;repos_url&quot;: &quot;https://api.github.com/users/octocat/repos&quot;,\r\n         &quot;events_url&quot;: \r\n         &quot;https://api.github.com/users/octocat/events{/privacy}&quot;,\r\n         &quot;received_events_url&quot;: \r\n         &quot;https://api.github.com/users/octocat/received_events&quot;,\r\n         &quot;type&quot;: &quot;User&quot;,\r\n         &quot;site_admin&quot;: false\r\n       }\r\n     }\r\n     ]\r\n    }\r\n\r\nThe sed command I posted above must work as it was working for another curl commands. \r\n\r\nThere are multiple occurrence of the `id` value but I want the value of the first `ID` to be stored in the `id` variable which is `&quot;id&quot;: 1234332` \r\n\r\nBut as output I am getting nothing. \r\n\r\nNeed help on this.",
        "link": "https://stackoverflow.com/questions/56206151/unable-to-extract-specific-value-of-json-file-using-sed-in-shell-script",
        "title": "Unable to extract specific value of json file using sed in shell script"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1558265761,
                "last_edit_date": 1558265761,
                "creation_date": 1558265444,
                "answer_id": 56207348,
                "question_id": 56207217,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\npaths(scalars) as $p | $p + [getpath($p)] | @csv\r\n```\r\n`paths(scalars)` finds paths to non-iterable values and lists them as arrays (e.g `[&quot;AE&quot;,&quot;424,4&quot;]`),  \r\n`getpath($p)` returns the value at path represented by `$p`.\r\n\r\nNote that `-r/--raw-output` option is required for proper CSV output.",
                "title": "flatten keyless json to csv format using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1558271713,
        "creation_date": 1558264357,
        "last_edit_date": 1558271713,
        "question_id": 56207217,
        "body_markdown": "How can I flatten the following json into csv format? The problem I am facing is that this json contains values in places of keys, and all the examples and tutorials that I have seen show how to handle json with keys and values. So I am not even sure where to begin.\r\n\r\nJSON: This is what I currently have\r\n```\r\n{\r\n  &quot;AE&quot;: {\r\n    &quot;424,2&quot;: &quot;Etisalat&quot;,\r\n    &quot;424,3&quot;: &quot;DU&quot;\r\n  },\r\n  &quot;AF&quot;: {\r\n    &quot;412,50&quot;: &quot;Etisalat&quot;\r\n  }\r\n}\r\n```\r\n\r\nCSV: This is what I would like to have as output\r\n```\r\n&quot;AE&quot;,&quot;424,2&quot;,&quot;Etisalat&quot;\r\n&quot;AE&quot;,&quot;424,3&quot;,&quot;DU&quot;\r\n&quot;AF&quot;,&quot;412,50&quot;,&quot;Etisalat&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/56207217/flatten-keyless-json-to-csv-format-using-jq",
        "title": "flatten keyless json to csv format using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1558349158,
                "post_id": 56219187,
                "comment_id": 99059032,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 979039,
                    "reputation": 3652,
                    "user_id": 999270,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/7d1f4ff0bfe281a0f58ab5905b330a22?s=256&d=identicon&r=PG",
                    "display_name": "Broshi",
                    "link": "https://stackoverflow.com/users/999270/broshi"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1558349654,
                "post_id": 56219187,
                "comment_id": 99059335,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1558350279,
                "post_id": 56219187,
                "comment_id": 99059668,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1558350550,
                "post_id": 56219187,
                "comment_id": 99059828,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 979039,
                    "reputation": 3652,
                    "user_id": 999270,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/7d1f4ff0bfe281a0f58ab5905b330a22?s=256&d=identicon&r=PG",
                    "display_name": "Broshi",
                    "link": "https://stackoverflow.com/users/999270/broshi"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1558350902,
                "post_id": 56219187,
                "comment_id": 99060012,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1558352314,
                "creation_date": 1558352314,
                "answer_id": 56220253,
                "question_id": 56219187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq 1.5 doesn&#39;t support `.key.[&quot;key&quot;]` syntax (1.6 does though). Drop the dot before `[$app]` and you&#39;re good to go:\r\n```\r\n.[$env].apps[$app].cloudfront_id\r\n```",
                "title": "jq Multiple Arguments"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1558352314,
        "creation_date": 1558348681,
        "last_edit_date": 1558350571,
        "question_id": 56219187,
        "body_markdown": "Given my JSON object in `data.json`:\r\n\r\n    {\r\n    \t&quot;prod&quot;: {\r\n    \t\t&quot;apps&quot;: {\r\n    \t\t\t&quot;myapp&quot;: {&quot;cloudfront_id&quot;:&quot;BINGO-PROD&quot;}\r\n    \t\t}\r\n    \t},\r\n    \t&quot;stg&quot;: {\r\n    \t\t&quot;apps&quot;: {\r\n    \t\t\t&quot;myapp&quot;: {&quot;cloudfront_id&quot;:&quot;BINGO-STG&quot;}\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nAnd given the following `jq` in bash:\r\n\r\n    #!/bin/bash\r\n\r\n    ENV=&quot;prod&quot;\r\n    APP=&quot;myapp&quot;\r\n    \r\n    OUTPUT=$(cat data.json | jq -rc \\\r\n    --arg env &quot;${ENV}&quot; \\\r\n    --arg app &quot;${APP}&quot; \\\r\n    &#39;.[$env] .apps .[$app] .bar&#39;)\r\n\r\nThis fails with the following error:\r\n\r\n    jq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .[$env] .apps .[$app] .cloudfront_id\r\n    jq: 1 compile error\r\n\r\n\r\n\r\nif I remove only the `[$app]` and replace it with `myapp` it works fine. i&#39;m running `jq-1.5` - any ideas why?",
        "link": "https://stackoverflow.com/questions/56219187/jq-multiple-arguments",
        "title": "jq Multiple Arguments"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "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": 1558359473,
                "post_id": 56220762,
                "comment_id": 99064771,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1558360790,
                "last_edit_date": 1558360790,
                "creation_date": 1558355318,
                "answer_id": 56221044,
                "question_id": 56220762,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Like that:\r\n\r\n    for id in $(jq -r &#39;.all[].id&#39; &lt;&lt;&lt; &quot;$json&quot;); do\r\n        echo &quot;$id&quot;\r\n    done\r\n\r\nNotice that `-r` option has to be used if you want to remove double quotes:\r\n\r\n  \r\n\r\n&gt;      &#183;   --raw-output / -r:\r\n&gt; \r\n&gt;            With this option, if the filter&#180;s result is a string then\r\n&gt;            it will be written directly to standard output rather than\r\n&gt;            being formatted as a JSON string with quotes. This can be\r\n&gt;            useful for making jq filters talk to non-JSON-based\r\n&gt;            systems.\r\n\r\nThe entire script could look like that:\r\n\r\n    #!/usr/bin/env bash\r\n    \r\n    json=&#39;{  \r\n       &quot;all&quot;:[  \r\n          {  \r\n                &quot;id&quot;:&quot;51a&quot;\r\n          },\r\n          {  \r\n                &quot;id&quot;:&quot;52b&quot;\r\n          },\r\n          {  \r\n                &quot;id&quot;:&quot;53c&quot;\r\n          }\r\n        ]\r\n    }&#39;\r\n    \r\n    for id in $(jq -r &#39;.all[].id&#39; &lt;&lt;&lt; &quot;$json&quot;); do\r\n        echo &quot;$id&quot;\r\n    done\r\n\r\nBut as noted in the comments, `for x in $(...)` is an antipattern and should not be used: https://mywiki.wooledge.org/DontReadLinesWithFor.\r\n\r\nTo assign two indices to 2 separate variables:\r\n\r\n    #!/usr/bin/env bash\r\n    \r\n    json=&#39;{\r\n       &quot;all&quot;:[\r\n          {\r\n                &quot;id&quot;:&quot;51a&quot;,\r\n    \t        &quot;name&quot;:&quot;Steve&quot;\r\n          },\r\n          {\r\n                &quot;id&quot;:&quot;52b&quot;,\r\n    \t        &quot;name&quot;:&quot;Phoebe&quot;\r\n          },\r\n          {\r\n                &quot;id&quot;:&quot;53c&quot;,\r\n    \t        &quot;name&quot;:&quot;Dino&quot;\r\n          }\r\n        ]\r\n    }&#39;\r\n    \r\n    jq -r &#39;.all[] | .id + &quot; &quot; + .name&#39; &lt;&lt;&lt; &quot;$json&quot; |\r\n        while read -r id name; do\r\n        \techo id: &quot;$id&quot;\r\n        \techo name: &quot;$name&quot;\r\n        done\r\n\r\n",
                "title": "jq error when looping through array: Cannot index array with string &quot;&lt;key&gt;&quot;"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1558357330,
                "creation_date": 1558357330,
                "answer_id": 56221575,
                "question_id": 56220762,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "and here&#39;s an alternative solution based on a walk-path unix tool for JSON: **[`jtc`][1]**:\r\n\r\n    bash $ for id in $(jtc -qq -w&#39;[all][:][id]&#39; &lt;&lt;&lt; &quot;$json&quot;); do  echo &quot;$id&quot;; done\r\n    51a\r\n    52b\r\n    53c\r\n    bash $ \r\n\r\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` tool\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n",
                "title": "jq error when looping through array: Cannot index array with string &quot;&lt;key&gt;&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1579031386,
        "creation_date": 1558354227,
        "last_edit_date": 1579031386,
        "question_id": 56220762,
        "body_markdown": "I&#39;m tryng to iterate over all element contain in the `all` index. Here is my json string : \r\n\r\n    {  \r\n       &quot;all&quot;:[  \r\n          {  \r\n                &quot;id&quot;:&quot;51a&quot;\r\n          },\r\n          {  \r\n                &quot;id&quot;:&quot;52b&quot;\r\n          },\r\n          {  \r\n                &quot;id&quot;:&quot;53c&quot;\r\n          }\r\n        ]\r\n    }\r\n\r\n\r\nI have tried to iterate with `jq` :\r\n\r\n    for id in $(jq &#39;.all.id | keys | .[]&#39; &lt;&lt;&lt; &quot;$json&quot;); do\r\n        echo &quot;$id&quot;\r\n    done\r\n\r\nBut I get this following error :\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:9): Cannot index array with string &quot;id&quot;\r\n\r\nI expect to get the following output :\r\n\r\n    51a\r\n    52b\r\n    53c",
        "link": "https://stackoverflow.com/questions/56220762/jq-error-when-looping-through-array-cannot-index-array-with-string-key",
        "title": "jq error when looping through array: Cannot index array with string &quot;&lt;key&gt;&quot;"
    },
    {
        "tags": [
            "group-by",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user11528490"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1558362334,
                "post_id": 56222287,
                "comment_id": 99066493,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1558364203,
                "post_id": 56222287,
                "comment_id": 99067575,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1558372475,
                "creation_date": 1558372475,
                "answer_id": 56225461,
                "question_id": 56222287,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming that by &quot;exists in serialnopool&quot; you mean &quot;occurs at least once in the set of serialnopool values&quot;, the following is a solution provided that your jq is version 1.5 or higher:\r\n\r\n    map(.serialnopool) as $snp\r\n    | (INDEX( group_by(.serialno)[]; .[0].serialno|tostring)\r\n       | map_values(map(.rowid))) as $dict\r\n    | (map(.serialno) | unique[]) as $sn\r\n    | if IN($sn; $snp[])\r\n      then &quot;\\($sn): &quot; + ($dict[$sn|tostring] | join(&quot;, &quot;))\r\n      else empty end\r\n\r\n\r\nThe main point of interest in this solution is the dictionary ($dict), which maps `.serialno|tostring` values to the corresponding `.rowid` values. \r\n\r\n\r\n\r\n      \r\n",
                "title": "groupby results of a matching function"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1558799903,
        "creation_date": 1558359995,
        "last_edit_date": 1558799903,
        "question_id": 56222287,
        "body_markdown": "given the below sample json, what i need to do, is to find if each value found in serialno, exists in serialnopool. If this holds TRUE, then i need a way, to have the values of serialno, that were found in serialnopool, grouped, along with their corresponding row ids.\r\n\r\nexample output of serialno value **11079851** that exists in serialnopool: \r\n\r\n**11079851: 098, 798**, etc, each serialno value would go on with its new line.\r\nFollows the sample json:\r\n   \r\n     [\r\n          {\r\n            &quot;rowid&quot;: &quot;098&quot;,\r\n            &quot;serialno&quot;: 11079851,\r\n            &quot;serialnopool&quot;: 11079851\r\n          },\r\n          {\r\n            &quot;rowid&quot;: 110,\r\n            &quot;serialno&quot;: 11089385,\r\n            &quot;serialnopool&quot;: 25853201\r\n          },\r\n          {\r\n            &quot;rowid&quot;: 118,\r\n            &quot;serialno&quot;: 11089385,\r\n            &quot;serialnopool&quot;: 22412115\r\n          },\r\n          {\r\n            &quot;rowid&quot;: 798,\r\n            &quot;serialno&quot;: 11079851,\r\n            &quot;serialnopool&quot;: 22412115\r\n          },\r\n          {\r\n            &quot;rowid&quot;: &quot;&quot;,\r\n            &quot;serialno&quot;: &quot;&quot;,\r\n            &quot;serialnopool&quot;: 5423\r\n          },\r\n          {\r\n            &quot;rowid&quot;: &quot;&quot;,\r\n            &quot;serialno&quot;: &quot;&quot;,\r\n            &quot;serialnopool&quot;: 5421312\r\n          }\r\n        ]\r\n\r\nHow could this be achieved with the use of jq?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56222287/groupby-results-of-a-matching-function",
        "title": "groupby results of a matching function"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1558369019,
                "last_edit_date": 1558369019,
                "creation_date": 1558363950,
                "answer_id": 56223435,
                "question_id": 56222913,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.path.to.anArrayOfObjs |= map(\r\n  select(.title == &quot;welcome&quot;).objA.objB.propA = &quot;new value&quot;\r\n)\r\n```\r\nTo modify multiple properties:\r\n```\r\n.path.to.anArrayOfObjs |= map(\r\n  select(.title == &quot;welcome&quot;).objA.objB |= (\r\n    .propA = &quot;new value&quot; | .propC = &quot;new value&quot;\r\n  )\r\n)\r\n```",
                "title": "How to modify (i.e. change part of, but keep the rest of JSON the same) a property in an array of objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1558389991,
        "creation_date": 1558362149,
        "last_edit_date": 1558372649,
        "question_id": 56222913,
        "body_markdown": "Note, I only want to change part of the JSON data in a large JSON blob.  Deep inside the JSON blob, there is an array of objects.  These objects have different properties, but I can identify the object I want to change by it&#39;s title.  I&#39;d like to use `jq` to do this.\r\n\r\nHere&#39;s an example JSON:\r\n\r\n```json\r\n{\r\n    &quot;propA&quot; : &quot;valA&quot;,\r\n    &quot;anArrayOfObjs&quot; : [\r\n        {\r\n            &quot;title&quot; : &quot;blah&quot;,\r\n            &quot;objA&quot; : {\r\n                &quot;objB&quot; : {\r\n                    &quot;propA&quot; : &quot;valA&quot;,\r\n                    &quot;propB&quot; : &quot;valB&quot;\r\n                }\r\n            }\r\n        },\r\n        {\r\n            &quot;title&quot; : &quot;welcome&quot;,\r\n            &quot;objA&quot; : {\r\n                &quot;objB&quot; : {\r\n                    &quot;propA&quot; : &quot;valA&quot;,\r\n                    &quot;propC&quot; : &quot;valC&quot;\r\n                }\r\n            }\r\n        },\r\n        {\r\n            &quot;objA&quot; : {\r\n                &quot;objB&quot; : {\r\n                    &quot;propA&quot; : &quot;valA&quot;,\r\n                    &quot;propD&quot; : &quot;valD&quot;\r\n                }\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI want to change the value of `objA.objB.propA` only for the object in `anArrayOfObjs` where `title == &quot;welcome&quot;`.\r\n\r\nthanks for any tips you can give.",
        "link": "https://stackoverflow.com/questions/56222913/how-to-modify-i-e-change-part-of-but-keep-the-rest-of-json-the-same-a-proper",
        "title": "How to modify (i.e. change part of, but keep the rest of JSON the same) a property in an array of objects using jq"
    },
    {
        "tags": [
            "iteration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1558378014,
                "last_edit_date": 1558378014,
                "creation_date": 1558373703,
                "answer_id": 56225703,
                "question_id": 56225179,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Reduce is just a reducing function for a given collection. Given an initial seed, it will update the value for each value and returns the final result.\r\n\r\nForeach is similar to reduce but is different in that it doesn&#39;t return the final result, but rather it returns all the intermediate results for each value instead.\r\n\r\nSince no iterations are made in the foreach call, no results are generated. Reduce on the other hand also has no iterations so no changes are made to the initial seed (`0`) which is then returned.\r\n\r\n&lt;hr&gt;\r\n\r\nIt&#39;s somewhat equivalent to the following python code if this helps:\r\n\r\n    def reduce(in, get_items, get_seed, update):\r\n        current = get_seed(in)\r\n        for item in get_items(in):\r\n            current = update(current, item)\r\n        return current\r\n\r\n    def foreach(in, get_items, get_seed, update, extract):\r\n        current = get_seed(in)\r\n        for item in get_items(in):\r\n            current = update(current, item)\r\n            yield extract(current, item)\r\n",
                "title": "Difference between reduce and foreach when empty is given as generator"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1558705654,
        "creation_date": 1558371102,
        "last_edit_date": 1558705654,
        "question_id": 56225179,
        "body_markdown": "I wrote following commands:\r\n```\r\njq -n &#39;reduce empty as $e (0; .)&#39;\r\n```\r\n```\r\njq -n &#39;foreach empty as $e (0; .; .)&#39;\r\n```\r\nand I was expecting both to yield nothing (or 0, I was expecting consistency between these similar structs). But instead, I got inconsistent results.\r\n```\r\n$ jq -n &#39;reduce empty as $e (0; .)&#39;\r\n0\r\n$ jq -n &#39;foreach empty as $e (0; .; .)&#39;\r\n$\r\n```\r\nManual says:\r\n&gt; **empty** returns no results. None at all. Not even null. It&#39;s useful on occasion. You&#39;ll know if you need it :)\r\n\r\nAnd I interpreted this like it&#39;s like a black hole that absorbs everything (I might be wrong). But when it is used as generator, `reduce` lets its initial value pass, while `foreach` doesn&#39;t. I don&#39;t know which one is acting logical but I&#39;m at `foreach`&#39;s side.\r\n\r\nI couldn&#39;t find any explanation to this difference, and couldn&#39;t think of one that makes sense. Can you guys help me understand why `reduce` and `foreach` behave different when generator is `empty`?",
        "link": "https://stackoverflow.com/questions/56225179/difference-between-reduce-and-foreach-when-empty-is-given-as-generator",
        "title": "Difference between reduce and foreach when empty is given as generator"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1558477116,
                "last_edit_date": 1558477116,
                "creation_date": 1558414376,
                "answer_id": 56231298,
                "question_id": 56231167,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    map( select ( .values | has(&quot;timestamp&quot;)? ))\r\n",
                "title": "How to filter missing inner key by using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1558429635,
                "last_edit_date": 1558429635,
                "creation_date": 1558425073,
                "answer_id": 56233608,
                "question_id": 56231167,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "and here&#39;s an alternative solution, using a walk-path unix tool for JSON: **[`jtc`][1]**:\r\n\r\n    bash $ &lt;file.json jtc -w&#39;&lt;timestamp&gt;l:[-2]&#39; -j\r\n    [\r\n       {\r\n          &quot;dimensions&quot;: &quot;helloworld&quot;,\r\n          &quot;metrics&quot;: &quot;sum(is_error)&quot;,\r\n          &quot;values&quot;: {\r\n             &quot;timestamp&quot;: 1558322460000,\r\n             &quot;value&quot;: &quot;0.0&quot;\r\n          }\r\n       },\r\n       {\r\n          &quot;dimensions&quot;: &quot;helloworld&quot;,\r\n          &quot;metrics&quot;: &quot;sum(is_error)&quot;,\r\n          &quot;values&quot;: {\r\n             &quot;timestamp&quot;: 1558322160000,\r\n             &quot;value&quot;: &quot;0.0&quot;\r\n          }\r\n       }\r\n    ]\r\n    bash $ \r\n\r\n- it finds each (all) label `timestamp`, then goes 2 levels up from the found json entry and prints found Json element. `-j` wraps all printed walks back into array.  \r\n\r\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` tool\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n",
                "title": "How to filter missing inner key by using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1559129084,
                "creation_date": 1559129084,
                "answer_id": 56359480,
                "question_id": 56231167,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Working example:\r\n`[ .[] | select (.values | has(&quot;timestamp&quot;)?) ]`\r\n\r\nhttps://jqplay.org/s/n5jsRsPMhW\r\n\r\nOr alternative:\r\n`[ .[] | select (.values.timestamp?) ]`\r\n\r\nhttps://jqplay.org/s/HRWV44YgUp\r\n\r\nP.S. [This one](https://jqplay.org/s/B1iS41Gk6t) was incorrect because of after .[] you are working with each item separately, not with array. So &#39;map&#39; function is unnecessary.",
                "title": "How to filter missing inner key by using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1682970609,
        "creation_date": 1558413443,
        "last_edit_date": 1682970609,
        "question_id": 56231167,
        "body_markdown": "Got a json input like this:\r\n\r\n```\r\n[ \r\n  {\r\n    &quot;dimensions&quot;: &quot;helloworld&quot;,\r\n    &quot;metrics&quot;: &quot;sum(is_error)&quot;,\r\n    &quot;values&quot;: {\r\n      &quot;timestamp&quot;: 1558322460000,\r\n      &quot;value&quot;: &quot;0.0&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;dimensions&quot;: &quot;helloworld&quot;,\r\n    &quot;metrics&quot;: &quot;sum(is_error)&quot;,\r\n    &quot;values&quot;: {\r\n      &quot;timestamp&quot;: 1558322160000,\r\n      &quot;value&quot;: &quot;0.0&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;dimensions&quot;: &quot;helloworld&quot;,\r\n    &quot;metrics&quot;: &quot;sum(is_error)&quot;,\r\n    &quot;values&quot;: &quot;3423.25&quot;\r\n  }\r\n]\r\n```\r\n\r\nThe third object doesnot have a timestamp on it. How could I return all the object only have a timestamp on it. Like the following:\r\n\r\n```\r\n[ \r\n  {\r\n    &quot;dimensions&quot;: &quot;helloworld&quot;,\r\n    &quot;metrics&quot;: &quot;sum(is_error)&quot;,\r\n    &quot;values&quot;: {\r\n      &quot;timestamp&quot;: 1558322460000,\r\n      &quot;value&quot;: &quot;0.0&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;dimensions&quot;: &quot;helloworld&quot;,\r\n    &quot;metrics&quot;: &quot;sum(is_error)&quot;,\r\n    &quot;values&quot;: {\r\n      &quot;timestamp&quot;: 1558322160000,\r\n      &quot;value&quot;: &quot;0.0&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nMany thanks in advance.\r\n\r\n\r\nCheers,\r\nVincent",
        "link": "https://stackoverflow.com/questions/56231167/how-to-filter-missing-inner-key-by-using-jq",
        "title": "How to filter missing inner key by using jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7602626,
                    "reputation": 777,
                    "user_id": 5766630,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6846bb9499910a599ff0556d22f43595?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "fibonachoceres",
                    "link": "https://stackoverflow.com/users/5766630/fibonachoceres"
                },
                "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": 1558421658,
                "post_id": 56232429,
                "comment_id": 99084463,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7602626,
                    "reputation": 777,
                    "user_id": 5766630,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6846bb9499910a599ff0556d22f43595?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "fibonachoceres",
                    "link": "https://stackoverflow.com/users/5766630/fibonachoceres"
                },
                "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": 1558421842,
                "post_id": 56232429,
                "comment_id": 99084555,
                "content_license": "CC BY-SA 4.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": 1558422226,
                "post_id": 56232429,
                "comment_id": 99084709,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1558422912,
                "last_edit_date": 1558422912,
                "creation_date": 1558421472,
                "answer_id": 56232634,
                "question_id": 56232429,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Going with your input JSON and assuming there are other properties in your `KeytoSearch` object along with the `_id` fields, you could just do below. \r\n\r\n    jq &#39;del(.KeytoSearch[]._id)&#39;\r\n\r\nSee [this jqplay.org](https://jqplay.org/s/imiI1HeQXU) snippet for a demo. The quotes around the property key containing `_` are not needed as confirmed in one of the comments below. Some meta-characters (e.g. `.` in the property key values needs be accessed with quotes as `&quot;.id&quot;`) needs to be quoted properly, but `_` is clearly not one of them.",
                "title": "Is there a way to delete the same key from a list of objects within a nested field?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1558422364,
                "last_edit_date": 1558422364,
                "creation_date": 1558422064,
                "answer_id": 56232778,
                "question_id": 56232429,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I&#39;ve tried combinations of map and del \r\n\r\nGood!  You were probably just missing the &#39;|=&#39; magic ingredient:\r\n\r\n    .Keytosearch |= map( del(._id) )",
                "title": "Is there a way to delete the same key from a list of objects within a nested field?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1558429669,
                "last_edit_date": 1558429669,
                "creation_date": 1558424773,
                "answer_id": 56233545,
                "question_id": 56232429,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "alternatively, you could use a walk-path unix tool for JSON: **[`jtc`][1]** and apply changes right into the sourse json file (`-f`):\r\n\r\n\r\n    bash $ jtc -fpw&#39;[KeytoSearch]&lt;_id&gt;l:&#39; file.json \r\n    bash $ \r\n    bash $ \r\n    bash $ jtc file.json \r\n    {\r\n       &quot;KeytoSearch&quot;: [\r\n          {\r\n             &quot;non_relevant_key1&quot;: &quot;val&quot;\r\n          },\r\n          {\r\n             &quot;non_relevant_key2&quot;: &quot;val&quot;\r\n          },\r\n          {\r\n             &quot;non_relevant_key3&quot;: &quot;val&quot;\r\n          }\r\n       ],\r\n       &quot;TopKey1&quot;: {\r\n          &quot;some_key&quot;: &quot;some_value&quot;\r\n       },\r\n       &quot;TopKey2&quot;: {\r\n          &quot;some_key2&quot;: &quot;some_value2&quot;\r\n       }\r\n    }\r\n    bash $ \r\n\r\nif given json snippet is a part of a larger JSON (and `[KeytoSearch]` is not addressable from the root), then replace it with the search lexeme: `&lt;KeytoSearch&gt;l`.\r\n\r\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` tool\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n\r\n\r\n",
                "title": "Is there a way to delete the same key from a list of objects within a nested field?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1558429669,
        "creation_date": 1558420590,
        "last_edit_date": 1558425075,
        "question_id": 56232429,
        "body_markdown": "I&#39;m setting up a devops pipeline so that certain data profiles stored in JSON format can be shifted across different servers. While downloading it from the current server I need to clean up all the protected keys and unique identifiers. I&#39;m looking for the cleanest way to do the following in JQ\r\n\r\nInput:\r\n```\r\n{\r\n   &quot;TopKey1&quot;:{\r\n      &quot;some_key&quot;:&quot;some_value&quot;\r\n   },\r\n   &quot;TopKey2&quot;:{\r\n      &quot;some_key2&quot;:&quot;some_value2&quot;\r\n   },\r\n   &quot;KeytoSearch&quot;:[\r\n      {\r\n         &quot;_id&quot;:&quot;sdf&quot;,\r\n         &quot;non_relevant_key1&quot;:&quot;val&quot;\r\n      },\r\n      {\r\n         &quot;_id&quot;:&quot;sdfdsdf&quot;,\r\n         &quot;non_relevant_key2&quot;:&quot;val&quot;\r\n      },\r\n      {\r\n         &quot;_id&quot;:&quot;sgf&quot;,\r\n         &quot;non_relevant_key3&quot;:&quot;val&quot;\r\n      }\r\n   ]\r\n}\r\n```\r\nOutput:\r\n```\r\n{\r\n   &quot;TopKey1&quot;:{\r\n      &quot;some_key&quot;:&quot;some_value&quot;\r\n   },\r\n   &quot;TopKey2&quot;:{\r\n      &quot;some_key2&quot;:&quot;some_value2&quot;\r\n   },\r\n   &quot;KeytoSearch&quot;:[\r\n      {\r\n         &quot;non_relevant_key1&quot;:&quot;val&quot;\r\n      },\r\n      {\r\n         &quot;non_relevant_key2&quot;:&quot;val&quot;\r\n      },\r\n      {\r\n         &quot;non_relevant_key3&quot;:&quot;val&quot;\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nIn python terms if this were a dictionary\r\n```\r\nfor json_object in dictionary[&quot;KeytoSearch&quot;]:\r\n  json_object.pop(&quot;_id&quot;)\r\n```\r\nI&#39;ve tried combinations of map and del but can&#39;t seem to figure out the nested indexing with this. The error messages I get are along the lines of `jq: error (at &lt;stdin&gt;:277): Cannot index string with string &quot;_id&quot;` which sort of tells me I haven&#39;t fundamentally understood how jq works or is to be used, but this is the route I need to go because using a Python script to clean up JSON objects is something I&#39;d rather avoid",
        "link": "https://stackoverflow.com/questions/56232429/is-there-a-way-to-delete-the-same-key-from-a-list-of-objects-within-a-nested-fie",
        "title": "Is there a way to delete the same key from a list of objects within a nested field?"
    },
    {
        "tags": [
            "json",
            "regex",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1558614876,
                "last_edit_date": 1558614876,
                "creation_date": 1558611697,
                "answer_id": 56274462,
                "question_id": 56274128,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "if you up to considering a non-jq solution, let me offer here one based on a walk-path unix utility **[`jtc`][1]**:\r\n\r\n    bash $ &lt;file.json jtc -w&#39;[dependencies]&lt;0\\.279\\.0\\-b1\\-abc\\-1234\\-0716\\.4567&gt;R:&#39; -u&#39;&quot;0.279.0-b1-abc-1234-0716.9856&quot;&#39;\r\n    {\r\n       &quot;dependencies&quot;: {\r\n          &quot;@gx/api&quot;: &quot;0.279.0-b1-abc-1234-0716.9856&quot;,\r\n          &quot;@gx/core&quot;: &quot;0.279.0-b1-abc-1234-0716.9856&quot;,\r\n          &quot;@gx/name&quot;: &quot;0.279.0-b1-abc-1234-0716.9856&quot;\r\n       },\r\n       &quot;license&quot;: &quot; See license.md&quot;\r\n    }\r\n    bash $ \r\n\r\nwalk-path (`-w`):\r\n\r\n- `[dependencies]` addresses (from root) the given record\r\n- `&lt;...&gt;R:` - a search lexeme, finds using RE (suffix `R`) all (quantifier `:`) entries matching the given reg.expression.\r\n\r\n`-u` will update (replace) all found matches.\r\n\r\n-- or --\r\n\r\nusing your REs, matching both labels and values:\r\n \r\n\r\n    bash $ &lt;file.json jtc -w&#39;[dependencies]&lt;@gx/[a-z]*&gt;L:&lt;^(\\d+\\.){2}[0-9]+(-[a-zA-Z0-9]*){4}\\.[0-9]*$&gt;R&#39; -u&#39;&quot;0.279.0-b1-abc-1234-0716.9856&quot;&#39;\r\n\r\n- same result\r\n\r\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` tool\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n\r\n\r\n",
                "title": "How to use regex to search the key and value and replace value with new value using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1558622055,
                "last_edit_date": 1558622055,
                "creation_date": 1558618862,
                "answer_id": 56276583,
                "question_id": 56274128,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq, there are many different approaches, with very different semantics, as can be seen from these solutions to the first problem (without regexes):\r\n\r\n    walk(if . == &quot;0.279.0-b1-abc-1234-0716.4567&quot; \r\n         then &quot;0.279.0-b1-abc-1234-0716.9856&quot; else . end)\r\n\r\nA more focused approach:\r\n\r\n     .dependencies |=\r\n       map_values(if . == &quot;0.279.0-b1-abc-1234-0716.4567&quot; \r\n                  then &quot;0.279.0-b1-abc-1234-0716.9856&quot; else . end)\r\n\r\n## regexes\r\n\r\nThe above approaches can all be used in the case of regex searches too, e.g. the last case would become:\r\n\r\n    .dependencies |= with_entries(\r\n      if (.key | test(&quot;@gx/[a-z]*&quot;))\r\n          and (.value | test(&quot;^(\\\\d+\\\\.){2}[0-9]+(-[a-zA-Z0-9]*){4}\\\\.[0-9]*$&quot;))\r\n      then .value = &quot;0.279.0-b1-abc-1234-0716.9856&quot; else . end)\r\n\r\nNote that the regex strings must be JSON strings, and hence the doubling of backslashes.\r\n\r\n## `if` without `else`\r\n\r\nIf you have a sufficiently recent version of jq, those dangling occurrences of &quot;else .&quot; can be dropped.",
                "title": "How to use regex to search the key and value and replace value with new value using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1558622055,
        "creation_date": 1558610537,
        "last_edit_date": 1558621831,
        "question_id": 56274128,
        "body_markdown": "    My json\r\n    {\r\n        &quot;license&quot;: &quot; See license.md&quot;,\r\n        &quot;dependencies&quot;: {\r\n            &quot;@gx/core&quot;: &quot;0.279.0-b1-abc-1234-0716.4567&quot;,\r\n            &quot;@gx/api&quot;: &quot;0.279.0-b1-abc-1234-0716.4567&quot;,\r\n            &quot;@gx/name&quot;: &quot;0.279.0-b1-abc-1234-0716.4567&quot;\r\n        }\r\n    }\r\n    \r\n    \r\n\r\nI want to replace &quot;0.279.0-b1-abc-1234-0716.4567&quot; with &quot;0.279.0-b1-abc-1234-0716.9856&quot; in all places.\r\n\r\n```   \r\n        jq &#39;.dependencies[].[&quot;@gx/core&quot;] |= (if . == &quot;0.279.0-b1-abc-1234-0716.4567&quot; then &quot;0.279.0-b1-abc-1234-0716.9856&quot; else . end)&#39; info.json\r\n ```   \r\n\r\n    jq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n        .dependencies[].[&quot;@gx/core&quot;] |= (if . == &quot;0.279.0-b1-abc-1234-0716.4567&quot; then &quot;0.279.0-b1-abc-1234-0716.9856&quot; else . end)                \r\n        jq: 1 compile error   \r\n    \r\n    I am looking for something like this\r\n       jq &#39;.dependencies[].[&quot;@gx/[a-z]*&quot;] |= (if . == &quot;^(\\d+\\.){2}[0-9]+(-[a-zA-Z0-9]*){4}\\.[0-9]*$&quot; then &quot;0.279.0-b1-abc-1234-0716.9856&quot; else . end)&#39; info.json \r\n\r\n",
        "link": "https://stackoverflow.com/questions/56274128/how-to-use-regex-to-search-the-key-and-value-and-replace-value-with-new-value-us",
        "title": "How to use regex to search the key and value and replace value with new value using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "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": 1558711592,
                "post_id": 56295554,
                "comment_id": 99203557,
                "content_license": "CC BY-SA 4.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": 1558711617,
                "post_id": 56295554,
                "comment_id": 99203579,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1558711727,
                "post_id": 56295554,
                "comment_id": 99203642,
                "content_license": "CC BY-SA 4.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": 1558711729,
                "post_id": 56295554,
                "comment_id": 99203643,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1558711750,
                "post_id": 56295554,
                "comment_id": 99203654,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1558711512,
        "creation_date": 1558711512,
        "question_id": 56295554,
        "body_markdown": "Im executing a &#39;curl&#39; operation and keeping the JSON response on a variable. Because I need to extract multiple values from this response I want to pass the variable to jq command instead of the curl operation (avoid multiple requests).\r\n\r\nWhat I have tried so far:\r\n\r\n    JSON=$(curl ${URL})\r\n    #Test1\r\n    PARAM=$(JSON | jq -r &#39;.param_one.val&#39;)\r\n    #Test2\r\n    PARAM=$( echo jq -r &#39;.param_one.val&#39; &lt;&lt; &quot;${JSON}&quot; ) \r\n    echo $PARAM #display result\r\n\r\nHow can I achieve this simple task?",
        "link": "https://stackoverflow.com/questions/56295554/pass-variable-to-jq",
        "title": "Pass variable to jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "variables",
            "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": 1713755123,
                "post_id": 56331695,
                "comment_id": 138153486,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1713657818,
                "last_edit_date": 1713657818,
                "creation_date": 1558989135,
                "answer_id": 56332166,
                "question_id": 56331695,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So not sure if this will help, but I use a JSON prettifier tool to get the arrays &amp; indices info that I need\r\n(the first one is a little more helpful to me)\r\n\r\n - [https://codebeautify.org/jsonviewer][1] \r\n - [http://jsonviewer.stack.hu/][2]\r\n\r\n\r\nand from there I wrote a bash script that takes in whatever I&#39;m getting data about as a variable, query it, and then use jq and awk to print whatever I&#39;m after\r\n\r\nHere&#39;s a line from the script showing the data I&#39;m looking for:\r\n\r\n    res=$(curl --silent &quot;https://api.oraclize.it/v1/query/eth_mainnet_${rec}/status&quot; | jq -r &quot;.result.checks[0].results&quot;)\r\n            echo &quot;$res&quot;|awk &#39;{print $2}&#39;\r\n\r\nThe -r flag makes jq output raw strings, not JSON-encoded. This is useful when assigning output to Bash variables. The jq command extracts a results array, and awk is used to print the second element of this array.\r\n\r\nIf I can provide anything further please feel free to reach out but maybe this will get you pointed in the right direction\r\n\r\n\r\n  [1]: https://codebeautify.org/jsonviewer\r\n  [2]: http://jsonviewer.stack.hu/",
                "title": "How do I assign the output of jq to variables?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1713657964,
                "creation_date": 1713657964,
                "answer_id": 78360057,
                "question_id": 56331695,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For any future readers. To assign the output of jq to a variable in a Bash script, you can use the following general syntax:\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;John&quot;,\r\n  &quot;age&quot;: 30\r\n}\r\n```\r\n\r\nTo extract the name and age and assign them to Bash variables. Here&#39;s how you could do it:\r\n\r\n```\r\nname=$(jq -r &#39;.name&#39; data.json)\r\nage=$(jq -r &#39;.age&#39; data.json)\r\n```\r\n\r\nUnfortunately, your original data provided by the link is not available any longer. You should have posted a minimal example as text.",
                "title": "How do I assign the output of jq to variables?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1713657964,
        "creation_date": 1558986368,
        "question_id": 56331695,
        "body_markdown": "I am attempting to parse NOAA NWS json data with jq.  My last computer class was as a senior in high school, &#39;67-68 semester.  Be gentle.\r\n\r\nI have figured out how to filter the data I want, but I&#39;d like it assigned to variables so I can use it farther down the road.  Using the original json name and index number as the variable&#39;s name is where I&#39;m aimed.  I can&#39;t find any documentation that even gives me a clue, but I&#39;m guessing this is something jq is used for all-the-time.\r\n\r\nHere are my data and filters:  https://jqplay.org/s/uRhNX-UglJ?fbclid=IwAR3lPxOj1fQcyzEOSrvf5x3WBQWXd0N1kwTc62Agmg1KANwkKL6hI-0vJOE",
        "link": "https://stackoverflow.com/questions/56331695/how-do-i-assign-the-output-of-jq-to-variables",
        "title": "How do I assign the output of jq to variables?"
    },
    {
        "tags": [
            "json",
            "jq",
            "indentation"
        ],
        "answers": [
            {
                "up_vote_count": 30,
                "is_accepted": true,
                "score": 30,
                "last_activity_date": 1559054187,
                "last_edit_date": 1559054187,
                "creation_date": 1559053838,
                "answer_id": 56344492,
                "question_id": 56339865,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is currently no way to instruct jq to preserve the indentation style *per se*, but the `--indent N` and `--tab` command-line options give limited control over the style of indentation.  Thus, in the particular case given, one could achieve the desired effect using `--indent 4`.",
                "title": "how to restrict indentation while using jq filters on json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 22,
        "last_activity_date": 1621560937,
        "creation_date": 1559038347,
        "last_edit_date": 1621560937,
        "question_id": 56339865,
        "body_markdown": "My input JSON file is:\r\n\r\n``` \r\n{\r\n\t&quot;name&quot;: &quot;abc&quot;,\r\n\t&quot;private&quot;: true,\r\n\t&quot;version&quot;: &quot;1.0.0&quot;,\r\n\t&quot;description&quot;: &quot;UI&quot;,\r\n\t&quot;dependencies&quot;: {\r\n\t\t&quot;xyz&quot;: &quot;9.11&quot;,\r\n\t\t&quot;abc&quot;: &quot;5.0.0&quot;\r\n\t}\r\n}\r\n```\r\n\r\nWhen I use `jq .name=xyz`, the output will be printed as:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;xyz&quot;,\r\n  &quot;private&quot;: true,\r\n  &quot;version&quot;: &quot;1.0.0&quot;,\r\n  &quot;description&quot;: &quot;UI&quot;,\r\n  &quot;dependencies&quot;: {\r\n    &quot;xyz&quot;: &quot;9.11&quot;,\r\n    &quot;abc&quot;: &quot;5.0.0&quot;\r\n  }\r\n}\r\n```\r\n\r\nThough my input file as proper indentation, after running the `jq` command the indentation is different.  \r\nHow can I restrict the indentation?\r\n\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/56339865/how-to-restrict-indentation-while-using-jq-filters-on-json-file",
        "title": "how to restrict indentation while using jq filters on json file"
    },
    {
        "tags": [
            "json",
            "bash",
            "awk",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1559088854,
                "last_edit_date": 1559088854,
                "creation_date": 1559087698,
                "answer_id": 56351407,
                "question_id": 56351164,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As a possibly simpler alternative, you could just use `jq`. So, if you had the json file, `myArray.json`\r\n\r\n    [ &quot;item1&quot; ]\r\n\r\nYou can add additional elements simply with\r\n\r\n    jq &#39;. + [&quot;item2&quot;]&#39; myArray.json\r\n\r\nwhich should result in\r\n\r\n    [\r\n      &quot;item1&quot;,\r\n      &quot;item2&quot;\r\n    ]\r\n\r\n",
                "title": "Conditionally insert a line in JSON array like file with awk"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1559097825,
                "creation_date": 1559097825,
                "answer_id": 56352393,
                "question_id": 56351164,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` is a great tool so I upvoted and accepted answer. Here&#39;s my ugly way.\r\n\r\n    [\r\n     item1\r\n     ,item2\r\n    ]   \r\n\r\nI needed to do conditional to skip first two lines after first item has been added. Run this line instead.\r\n\r\n    awk -v var=&quot;item2&quot; &#39;/\\]/ {print &quot;,&quot;var} 1&#39; myArray.json &gt;&gt; myArray-tmp.json",
                "title": "Conditionally insert a line in JSON array like file with awk"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1559121177,
                "last_edit_date": 1559121177,
                "creation_date": 1559118028,
                "answer_id": 56356048,
                "question_id": 56351164,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "also, one easy alternative - a walk-path based unix utility **[`jtc`][1]** to manipulate json.\r\n\r\nIn `jtc` there&#39;s an option to apply changes right into the source file - `-f` (without it, the result will only be printed to the console):\r\n\r\n    bash $ jtc myArray.json \r\n    [\r\n       &quot;item1&quot;\r\n    ]\r\n    bash $ \r\n    bash $ jtc -f -i&#39;&quot;item2&quot;&#39; myArray.json \r\n    bash $ \r\n    bash $ jtc myArray.json \r\n    [\r\n       &quot;item1&quot;,\r\n       &quot;item2&quot;\r\n    ]\r\n    bash $ \r\n\nNote: inserted element must be a valid JSON - hence double quotes (`”item2”` - that makes a valid JSON string) and to preserve them (escape shell interpolation) - there are outer single quotes around the argument\n\r\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` - shell cli tool for JSON operations\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n\r\n\r\n\r\n",
                "title": "Conditionally insert a line in JSON array like file with awk"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1559121177,
        "creation_date": 1559085264,
        "last_edit_date": 1559101782,
        "question_id": 56351164,
        "body_markdown": "I want to push items with `awk` to a `myArray.json` file like so\r\n\r\n    [\r\n     item1,\r\n     item2\r\n    ]\r\nTo add item1 I tried\r\n\r\n    echo -e &quot;[\\n]&quot; &gt; myArray.json # Create an empty JSON array with &quot;\\n&quot;\r\n    awk -v var=&quot;item1&quot; &#39;/\\]/ {print var} 1&#39; myArray.json &gt;&gt; myArray-tmp.json\r\n    mv myArray-tmp.json myArray.json\r\nIf I now comment out `echo -e &quot;[\\n]&quot; &gt; myArray.json` line (or conditionally skip it), set `var=&quot;item2&quot;` and run the script, item2 is added to the array. **I want to add a comma after first line, but not second**.",
        "link": "https://stackoverflow.com/questions/56351164/conditionally-insert-a-line-in-json-array-like-file-with-awk",
        "title": "Conditionally insert a line in JSON array like file with awk"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "jq",
            "wildcard"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 120990,
                    "reputation": 10429,
                    "user_id": 313756,
                    "user_type": "registered",
                    "accept_rate": 42,
                    "profile_image": "https://www.gravatar.com/avatar/5984cce01b50eb0b544f79fd57433779?s=256&d=identicon&r=PG",
                    "display_name": "lindes",
                    "link": "https://stackoverflow.com/users/313756/lindes"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1666667628,
                "post_id": 56355822,
                "comment_id": 130986067,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2928566,
                    "reputation": 302,
                    "user_id": 2509417,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/31849c37c32e51f40b10ecf4161e0698?s=256&d=identicon&r=PG",
                    "display_name": "Nimo Beeren",
                    "link": "https://stackoverflow.com/users/2509417/nimo-beeren"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1714144114,
                "post_id": 56355822,
                "comment_id": 138201532,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 28,
                "is_accepted": true,
                "score": 28,
                "last_activity_date": 1559118532,
                "last_edit_date": 1559118532,
                "creation_date": 1559117937,
                "answer_id": 56356012,
                "question_id": 56355822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t care about the keys in the object you&#39;re searching, you could just search the values of the object using `[]` which you could then filter to your desired results.\r\n\r\n    .details.addresses[][] | select(.version == 4).addr\r\n\r\nIf on the other hand you wanted to select keys that has a version 4, you could use `to_entries` to do this:\r\n\r\n    .details.addresses | to_entries[] | select(any(.value[]; .version == 4)).key",
                "title": "How to use jq wildcard"
            },
            {
                "up_vote_count": 17,
                "is_accepted": false,
                "score": 17,
                "last_activity_date": 1559133625,
                "creation_date": 1559133625,
                "answer_id": 56360906,
                "question_id": 56355822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If, as suggested by part of the question, you want to confine the search to key names starting with &quot;ext&quot;:\r\n\r\n\r\n    .details.addresses\r\n    | to_entries[]\r\n    | select(.key|startswith(&quot;ext&quot;))\r\n    | .value[]\r\n    | select(.version == 4)\r\n    | .addr\r\n\r\nTowards the other end of the spectrum of permissiveness:\r\n\r\n    .details.addresses\r\n    | ..\r\n    | objects\r\n    | select(.version==4)\r\n    | .addr\r\n\r\n\r\n",
                "title": "How to use jq wildcard"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 28,
        "last_activity_date": 1683142414,
        "creation_date": 1559117249,
        "last_edit_date": 1683142414,
        "question_id": 56355822,
        "body_markdown": "I have the following json: \r\n\r\n&lt;!-- language: json --&gt;\r\n    {  \r\n       &quot;details&quot;:{  \r\n          &quot;car&quot;: &quot;bmw&quot;,\r\n          &quot;addresses&quot;:{  \r\n             &quot;ext-118-21-8-0-29&quot;:[  \r\n                {  \r\n                   &quot;version&quot;:4,\r\n                   &quot;addr&quot;:&quot;89 Psr&quot;\r\n                },\r\n                {  \r\n                   &quot;version&quot;:6,\r\n                   &quot;addr&quot;:&quot;56 apT&quot;\r\n                }\r\n             ]\r\n          }\r\n       }\r\n    }\r\n\r\nThe key `ext-118-21-8-0-29` is dynamic it will change the next time and I don&#39;t know the exact value, that&#39;s why I need to use wildcard. I need to get the value of the key `addr` where version is `4`.\r\n\r\n\r\nI&#39;m expectig as output `89 Psr`\r\n\r\nI tried the following using the function `startswith()`.\r\n\r\n&lt;!-- language: sh --&gt;\r\n    jq &#39;.detail.addresses | select(startswith(&quot;ext&quot;))&#39;\r\n\r\nBut it end with an error.\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:0): startswith() requires string inputs\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56355822/how-to-use-jq-wildcard",
        "title": "How to use jq wildcard"
    },
    {
        "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": 1559198413,
                "post_id": 56370993,
                "comment_id": 99347658,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1559184769,
                "creation_date": 1559184769,
                "answer_id": 56371052,
                "question_id": 56370993,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In this command:\r\n\r\n    $ cat file.json | jq .document.page[].row | [&quot;#text&quot;, &quot;@x&quot;, &quot;@y&quot;] | @csv\r\n\r\nEverything after the `jq` is supposed to be the first argument to `jq`, which means you need to enclose it in quotation marks.  Moreover, `cat file.json |` is here a [Useless Use of Cat](http://porkmail.org/era/unix/award.html); just pass the filename as an argument to `jq`.  Hence, the correct command is:\r\n\r\n    $ jq &#39;.document.page[].row | [&quot;#text&quot;, &quot;@x&quot;, &quot;@y&quot;] | @csv&#39; file.json",
                "title": "Parsing Json file with jq tool"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1559198305,
                "last_edit_date": 1559198305,
                "creation_date": 1559197117,
                "answer_id": 56372673,
                "question_id": 56370993,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a simple (perhaps too simple?) approach that focuses on the embedded JSON objects that have a &quot;#text&quot; attribute:\r\n\r\n\r\n    [&quot;#text&quot;, &quot;@x&quot;, &quot;@y&quot;],       # the header\r\n    ( ..\r\n      | objects\r\n      | select(has(&quot;#text&quot;))  \r\n      | [.[&quot;#text&quot;, &quot;@x&quot;, &quot;@y&quot;]] # a row\r\n    ) \r\n    | @csv\r\n\r\nWhen given this program and the sample input, an invocation of `jq` using the -r option would produce:\r\n\r\n    &quot;#text&quot;,&quot;@x&quot;,&quot;@y&quot;\r\n    &quot;Text1&quot;,&quot;121.10&quot;,&quot;83.42&quot;\r\n    &quot;Text2&quot;,&quot;121.10&quot;,&quot;124.82&quot;\r\n    &quot;Text3&quot;,&quot;85.10&quot;,&quot;69.62&quot;\r\n    &quot;Text4&quot;,&quot;85.10&quot;,&quot;83.42&quot;\r\n    &quot;Text5&quot;,&quot;85.10&quot;,&quot;97.22&quot;\r\n\r\nIf you don&#39;t want the quotation marks and are willing to risk that the output is not strictly CSV, then one option would be to use `join(&quot;,&quot;)` instead of `@csv` at the end of the pipeline.\r\n\r\n## Variants\r\nYou might want to use `@tsv` instead of `@csv`.\r\n\r\nIf a more restrictive approach to selecting the relevant embedded objects is needed, then perhaps replacing `..` with `.. | .text?` will suffice. \r\n\r\nIf not, additional filters can be added depending on the detailed requirements.",
                "title": "Parsing Json file with jq tool"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1559197995,
                "creation_date": 1559197995,
                "answer_id": 56372896,
                "question_id": 56370993,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that uses a &quot;drill-down&quot; and therefore rather tedious approach:\r\n\r\n    [&quot;#text&quot;, &quot;@x&quot;, &quot;@y&quot;],\r\n    ( .document.page[]\r\n      | .row[]?\r\n      | .column\r\n      | (if type == &quot;array&quot; then .[] else . end)\r\n      | .text\r\n      | objects\r\n      | [.[&quot;#text&quot;, &quot;@x&quot;, &quot;@y&quot;]]\r\n    )\r\n    | @tsv\r\n\r\nThis would be used in conjunction with the -r command-line option.  \r\n\r\nI&#39;ve used `@tsv` as this produces output that resembles the given expected output.  As mentioned elsewhere on this page, there are other alternatives, e.g. using `join/1`. ",
                "title": "Parsing Json file with jq tool"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1559217988,
                "last_edit_date": 1559217988,
                "creation_date": 1559212850,
                "answer_id": 56376643,
                "question_id": 56370993,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "for those who are interested in the alternative solutions, here&#39;s how to achieve the same ask using a walk-path unix tool for JSON: **[`jtc`][1]**.\r\n\r\n    bash $ jtc -qq -w&#39;&lt;&gt;a&#39; -T&#39;&quot;#text\\t@x\\t@y&quot;&#39; -w&#39;&lt;@x&gt;l:&lt;x&gt;v[-1][@y]&lt;y&gt;v[-1][#text]&#39; -T&#39;&quot;{}\\t{x}\\t{y}&quot;&#39; file.json\r\n    #text   @x\t    @y\r\n    Text1   121.10  83.42\r\n    Text2   121.10  124.82\r\n    Text3   85.10   69.62\r\n    Text4   85.10   83.42\r\n    Text5   85.10   97.22\r\n    bash $ \r\n\r\nwalk path (`-w`) breakdown:\r\n\r\n- `&lt;@x&gt;l: &lt;x&gt;v` find each label `@x` and memorize found JSON value in the namespace `x`\r\n- `[-1][@y]&lt;y&gt;v` address a parent (from last found value), then address JSON by label `@y` and memorize its value in the namespace `y`\r\n- `[-1][#text]`do the same for `#text` label (note: not memorizing the last value)\r\n\r\n\\- `-T&#39;&quot;{}\\t{x}\\t{y}&quot;&#39;`: apply template with interpolation (`{}` will interpolate the last found value, hence there was no need memorizing it in the namespace)\r\n\r\n\\- `-qq` will *unquote* the resulting JSON string (dropping quotation marks and translating `\\t` into tabs)\r\n\r\n\\- first walk (`-w&#39;&lt;&gt;a&#39;`) is just a dummy one to trigger template interpolation for the header line.\r\n\r\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` - shell cli tool for JSON operations\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n\r\n",
                "title": "Parsing Json file with jq tool"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1559269692,
                "last_edit_date": 1559269692,
                "creation_date": 1559256974,
                "answer_id": 56386640,
                "question_id": 56370993,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Handling input2.json\r\n\r\nSince some context-dependent information is required for the second set of requirements corresponding to input2.json, the context cannot be ignored, and so the following solution uses a &quot;drill-down&quot; approach.  The following will be a bit difficult to understand unless you understand `foreach`, so let me just mention that the approach essentially uses a state variable {counter, page, row} to keep track of the three counters.\r\n\r\n    [&quot;counter&quot;, &quot;page&quot;, &quot;row&quot;, &quot;#text&quot;, &quot;@data&quot;, &quot;@fontName&quot;, &quot;@fontSize&quot;, &quot;@format&quot;, &quot;@height&quot;, &quot;@type&quot;, &quot;@width&quot;, &quot;@x&quot;, &quot;@y&quot;], \r\n    (foreach (.document.page[] | objects) as $page ({page: -1, counter: 0};\r\n      .page += 1\r\n      | foreach ($page | .row[]?) as $row (.row=-1;\r\n        .row += 1\r\n        | foreach ($row | (.column | (if type == &quot;array&quot; then .[] else . end )) | .text | objects) as $x (.;\r\n          .counter += 1\r\n          | .out = [.counter, .page, .row, $x[&quot;#text&quot;, &quot;@data&quot;, &quot;@fontName&quot;, &quot;@fontSize&quot;, &quot;@format&quot;, &quot;@height&quot;, &quot;@type&quot;, &quot;@width&quot;, &quot;@x&quot;, &quot;@y&quot;]]\r\n          ; . )\r\n          ; . )\r\n          ; .out )\r\n    )\r\n    | @tsv\r\n\r\n\r\nThis produces the desired TSV except for the very first line of data as that has no row. One way to include the first line is shown in my answer at https://stackoverflow.com/questions/56386521/relate-elements-in-table-form-from-json-file-with-jq",
                "title": "Parsing Json file with jq tool"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 1,
        "last_activity_date": 1559269692,
        "creation_date": 1559184230,
        "last_edit_date": 1559244108,
        "question_id": 56370993,
        "body_markdown": " I Have the following nested json file which I want to parse with jq tool and print in table form like I show at the end\r\n    \r\nThe input.json structure is like this:\r\n    \r\n    {\r\n     &quot;document&quot;:{\r\n      &quot;page&quot;:[\r\n         {\r\n            &quot;@index&quot;:&quot;0&quot;,\r\n            &quot;image&quot;:{\r\n               &quot;@data&quot;:&quot;ABC&quot;,\r\n               &quot;@format&quot;:&quot;png&quot;,\r\n               &quot;@height&quot;:&quot;620.00&quot;,\r\n               &quot;@type&quot;:&quot;base64encoded&quot;,\r\n               &quot;@width&quot;:&quot;450.00&quot;,\r\n               &quot;@x&quot;:&quot;85.00&quot;,\r\n               &quot;@y&quot;:&quot;85.00&quot;\r\n            }\r\n         },\r\n         {\r\n            &quot;@index&quot;:&quot;1&quot;,\r\n            &quot;row&quot;:[\r\n               {\r\n                  &quot;column&quot;:[\r\n                     {\r\n                        &quot;text&quot;:&quot;&quot;\r\n                     },\r\n                     {\r\n                        &quot;text&quot;:{\r\n                           &quot;#text&quot;:&quot;Text1&quot;,\r\n                           &quot;@fontName&quot;:&quot;Arial&quot;,\r\n                           &quot;@fontSize&quot;:&quot;12.0&quot;,\r\n                           &quot;@height&quot;:&quot;12.00&quot;,\r\n                           &quot;@width&quot;:&quot;71.04&quot;,\r\n                           &quot;@x&quot;:&quot;121.10&quot;,\r\n                           &quot;@y&quot;:&quot;83.42&quot;\r\n                        }\r\n                     }\r\n                  ]\r\n               },\r\n               {\r\n                  &quot;column&quot;:[\r\n                     {\r\n                        &quot;text&quot;:&quot;&quot;\r\n                     },\r\n                     {\r\n                        &quot;text&quot;:{\r\n                           &quot;#text&quot;:&quot;Text2&quot;,\r\n                           &quot;@fontName&quot;:&quot;Arial&quot;,\r\n                           &quot;@fontSize&quot;:&quot;12.0&quot;,\r\n                           &quot;@height&quot;:&quot;12.00&quot;,\r\n                           &quot;@width&quot;:&quot;101.07&quot;,\r\n                           &quot;@x&quot;:&quot;121.10&quot;,\r\n                           &quot;@y&quot;:&quot;124.82&quot;\r\n                        }\r\n                     }\r\n                  ]\r\n               }\r\n            ]\r\n         },\r\n         {\r\n            &quot;@index&quot;:&quot;2&quot;,\r\n            &quot;row&quot;:[\r\n               {\r\n                  &quot;column&quot;:{\r\n                     &quot;text&quot;:{\r\n                        &quot;#text&quot;:&quot;Text3&quot;,\r\n                        &quot;@fontName&quot;:&quot;Arial&quot;,\r\n                        &quot;@fontSize&quot;:&quot;12.0&quot;,\r\n                        &quot;@height&quot;:&quot;12.00&quot;,\r\n                        &quot;@width&quot;:&quot;363.44&quot;,\r\n                        &quot;@x&quot;:&quot;85.10&quot;,\r\n                        &quot;@y&quot;:&quot;69.62&quot;\r\n                     }\r\n                  }\r\n               },\r\n               {\r\n                  &quot;column&quot;:{\r\n                     &quot;text&quot;:{\r\n                        &quot;#text&quot;:&quot;Text4&quot;,\r\n                        &quot;@fontName&quot;:&quot;Arial&quot;,\r\n                        &quot;@fontSize&quot;:&quot;12.0&quot;,\r\n                        &quot;@height&quot;:&quot;12.00&quot;,\r\n                        &quot;@width&quot;:&quot;382.36&quot;,\r\n                        &quot;@x&quot;:&quot;85.10&quot;,\r\n                        &quot;@y&quot;:&quot;83.42&quot;\r\n                     }\r\n                  }\r\n               },\r\n               {\r\n                  &quot;column&quot;:{\r\n                     &quot;text&quot;:{\r\n                        &quot;#text&quot;:&quot;Text5&quot;,\r\n                        &quot;@fontName&quot;:&quot;Arial&quot;,\r\n                        &quot;@fontSize&quot;:&quot;12.0&quot;,\r\n                        &quot;@height&quot;:&quot;12.00&quot;,\r\n                        &quot;@width&quot;:&quot;435.05&quot;,\r\n                        &quot;@x&quot;:&quot;85.10&quot;,\r\n                        &quot;@y&quot;:&quot;97.22&quot;\r\n                     }\r\n                  }\r\n               }\r\n            ]\r\n         },\r\n         {\r\n            &quot;@index&quot;:&quot;3&quot;\r\n         }\r\n      ]\r\n     }\r\n    }\r\n    \r\nFollowing the answers of the following question (https://stackoverflow.com/questions/46956201/parsing-nested-json-with-jq) I&#39;ve tried this code but doesn&#39;t work\r\n\r\n    $ cat file.json | jq .document.page[].row | [&quot;#text&quot;, &quot;@x&quot;, &quot;@y&quot;] | @csv\r\n\r\nThe output I&#39;m trying to get is:\r\n\r\n    #text @x     @y\r\n    Text1 121.10 83.42\r\n    Text2 121.10 124.82\r\n    Text3 65.10  69.62\r\n    Text4 85.10  83.42\r\n    Text5 85.10  97.22\r\n    \r\nHow can achieve this?\r\n\r\nThanks\r\n\r\n**UPDATE**\r\n\r\nThanks so much for the help. I&#39;ve tried with a real file a bit longer.\r\n\r\nI was able to adapt the first peak&#39;s solution like below:\r\n\r\n\t[&quot;#text&quot;, &quot;@data&quot;, &quot;@fontName&quot;, &quot;@fontSize&quot;, &quot;@format&quot;, &quot;@height&quot;, &quot;@type&quot;, &quot;@width&quot;, &quot;@x&quot;, &quot;@y&quot;], \r\n\t( .. \r\n\t| objects \r\n\t| select(has(&quot;#text&quot;,&quot;@data&quot;)) \r\n\t| [.[&quot;#text&quot;, &quot;@data&quot;, &quot;@fontName&quot;, &quot;@fontSize&quot;, &quot;@format&quot;, &quot;@height&quot;, &quot;@type&quot;, &quot;@width&quot;, &quot;@x&quot;, &quot;@y&quot;]]\r\n\t)  \r\n\t| @tsv\r\n\r\nand with new input I get this table:\r\n\r\n\t+---------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| #text         | @data | @fontName | @fontSize | @format | @height | @type         | @width | @x     | @y     |\r\n\t+---------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t|               | ABC   |           |           | png     | 620     | base64encoded | 450    | 85     | 85     |\r\n\t+---------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| Text &#228; 1      |       | Tahoma    | 12        |         | 12      |               | 427.79 | 85.1   | 69.62  |\r\n\t+---------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| Text &#162;76      |       | Tahoma    | 12        |         | 12      |               | 270.5  | 85.1   | 690.72 |\r\n\t+---------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| Text % 5      |       | Tahoma    | 12        |         | 12      |               | 130.84 | 358.86 | 690.72 |\r\n\t+---------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| Text 7&#199;8      |       | Tahoma    | 12        |         | 12      |               | 115.95 | 85.1   | 704.52 |\r\n\t+---------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| Text • 2 W&#241;79 |       | Tahoma    | 8         |         | 8.04    |               | 398.16 | 121.1  | 68.06  |\r\n\t+---------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| Text          |       | Tahoma    | 12        |         | 12      |               | 101.5  | 85.1   | 83.42  |\r\n\t|   &#187; 1 A\\\\\\\\C&#211; |       |           |           |         |         |               |        |        |        |\r\n\t+---------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| Text 12       |       | Tahoma    | 12        |         | 12      |               | 312.26 | 189.83 | 83.42  |\r\n\t+---------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| Text 82       |       | Tahoma    | 12        |         | 12      |               | 44.99  | 85.1   | 97.22  |\r\n\t+---------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| Text 31       |       | Tahoma    | 8         |         | 8.04    |               | 381.83 | 133.1  | 95.66  |\r\n\t+---------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\r\nIf possible, how to add the follwing 3 columns (counter, page and row) to know the corresponding page and row for each line?\r\n\r\nThe expected output would be like this:\r\n\r\n\t+-------+------+-----+-------------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| counter | page | row | #text             | @data | @fontName | @fontSize | @format | @height | @type         | @width | @x     | @y     |\r\n\t+-------+------+-----+-------------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| 1     | 0    |     |                   | ABC   |           |           | png     | 620     | base64encoded | 450    | 85     | 85     |\r\n\t+-------+------+-----+-------------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| 2     | 1    | 0   | Text &#228; 1          |       | Tahoma    | 12        |         | 12      |               | 427.79 | 85.1   | 69.62  |\r\n\t+-------+------+-----+-------------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| 3     | 1    | 1   | Text &#162;76          |       | Tahoma    | 12        |         | 12      |               | 270.5  | 85.1   | 690.72 |\r\n\t+-------+------+-----+-------------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| 4     | 1    | 1   | Text % 5          |       | Tahoma    | 12        |         | 12      |               | 130.84 | 358.86 | 690.72 |\r\n\t+-------+------+-----+-------------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| 5     | 2    | 2   | Text 7&#199;8          |       | Tahoma    | 12        |         | 12      |               | 115.95 | 85.1   | 704.52 |\r\n\t+-------+------+-----+-------------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| 6     | 2    | 0   | Text • 2 W&#241;79     |       | Tahoma    | 8         |         | 8.04    |               | 398.16 | 121.1  | 68.06  |\r\n\t+-------+------+-----+-------------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| 7     | 2    | 1   | Text  &#187; 1 A\\\\\\\\C&#211; |       | Tahoma    | 12        |         | 12      |               | 101.5  | 85.1   | 83.42  |\r\n\t+-------+------+-----+-------------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| 8     | 2    | 1   | Text 12           |       | Tahoma    | 12        |         | 12      |               | 312.26 | 189.83 | 83.42  |\r\n\t+-------+------+-----+-------------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| 9     | 2    | 2   | Text 82           |       | Tahoma    | 12        |         | 12      |               | 44.99  | 85.1   | 97.22  |\r\n\t+-------+------+-----+-------------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\t| 10    | 2    | 2   | Text 31           |       | Tahoma    | 8         |         | 8.04    |               | 381.83 | 133.1  | 95.66  |\r\n\t+-------+------+-----+-------------------+-------+-----------+-----------+---------+---------+---------------+--------+--------+--------+\r\n\r\nThis is new more representative input file [input2.json][1].\t\r\n\r\nAnd seeing the Json structure in image below gives and idea about `page` number and `row` number present in json file and values within them.\r\n\r\n[![enter image description here][2]][2]\r\n\r\n\r\n  [1]: https://www.dropbox.com/s/7z47ybgckxubh3z/input2.json?raw=1\r\n  [2]: https://i.sstatic.net/qrhMw.jpg",
        "link": "https://stackoverflow.com/questions/56370993/parsing-json-file-with-jq-tool",
        "title": "Parsing Json file with jq tool"
    },
    {
        "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": 2,
                "creation_date": 1559229133,
                "post_id": 56373900,
                "comment_id": 99362153,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1559204375,
                "creation_date": 1559204375,
                "answer_id": 56374355,
                "question_id": 56373900,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This filter will select relays with `Running` and `Fast` flags and yield an array of objects containing only `nickname` and `fingerprint` fields, tweak it to meet your requirements.\r\n```\r\n.relays | map(select(.flags | index(&quot;Running&quot;) and index(&quot;Fast&quot;)) | { nickname, fingerprint })\r\n```",
                "title": "Filter elements of a JSON by their subelements&#39; contents in Windows shell using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1666590411,
        "creation_date": 1559202378,
        "last_edit_date": 1666590411,
        "question_id": 56373900,
        "body_markdown": "This may be asked elsewhere but I have trouble finding a similar case:\r\n\r\nTrying to filter the Tor network&#39;s relay consensus (https://onionoo.torproject.org/details) based on whether a relay is &quot;Running&quot; and if it has a &quot;Fast&quot; flag or not in order to make another json made up of the selected relays. Possibly even a more concise version that only lists certain elements of each relay (nickname, fingerprint, etc).\r\n\r\nI&#39;m trying to use this in a batch script, which makes JQ difficult to work with as it requires hoops to jump through in order to make it work with Windows&#39; shell. \r\n\r\nLooking through the Tutorial and manual, I&#39;m stumped. Anyone know of a solution?",
        "link": "https://stackoverflow.com/questions/56373900/filter-elements-of-a-json-by-their-subelements-contents-in-windows-shell-using",
        "title": "Filter elements of a JSON by their subelements&#39; contents in Windows shell using JQ?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559252869,
                "post_id": 56386009,
                "comment_id": 99372094,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559253123,
                "post_id": 56386009,
                "comment_id": 99372188,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user5047085"
                },
                "reply_to_user": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559254127,
                "post_id": 56386009,
                "comment_id": 99372520,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1559254791,
                "creation_date": 1559254791,
                "answer_id": 56386343,
                "question_id": 56386009,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes.  Also, there&#39;s no need to export `connection_info`.\r\n\r\nFor example:\r\n\r\n    #!/bin/bash\r\n    \r\n    connection_info=&#39;{\r\n      &quot;values&quot;: [\r\n        {&quot;host&quot;:&quot;xxx&quot;, &quot;port&quot;: 3939},\r\n        {&quot;host&quot;:&quot;yyy&quot;, &quot;port&quot;: 7373}\r\n      ]\r\n    }&#39;\r\n    \r\n    jq -n --argjson ci &quot;$connection_info&quot; -cr &#39;$ci | .values[] | &quot;\\(.host) \\(.port)&quot;&#39; |\r\n    while read -r host port ; do\r\n         timeout 10 telnet &quot;$host&quot; &quot;$port&quot; ||\r\n            echo &quot;Could not connect to host: $host port: $port&quot;\r\n    done;\r\n\r\n## Using stdin\r\n\r\nFor reference, your script could also be tweaked as follows:\r\n\r\n    #!/bin/bash\r\n    \r\n    connection_info=&#39;{\r\n      &quot;values&quot;: [\r\n        {&quot;host&quot;:&quot;xxx&quot;, &quot;port&quot;: 3939},\r\n        {&quot;host&quot;:&quot;yyy&quot;, &quot;port&quot;: 7373}\r\n      ]\r\n    }&#39;\r\n    \r\n    echo &quot;$connection_info&quot; | jq -cr &#39;.values[] | &quot;\\(.host) \\(.port)&quot;&#39; |\r\n    while read -r host port ; do\r\n         timeout 10 telnet &quot;$host&quot; &quot;$port&quot; ||\r\n            echo &quot;Could not connect to host: $host port: $port&quot;\r\n    done;\r\n\r\n",
                "title": "Read json from argument instead of stdin using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1559255938,
        "creation_date": 1559252688,
        "last_edit_date": 1559255938,
        "question_id": 56386009,
        "body_markdown": "Say I have JSON like so:\r\n\r\n    export connection_info = ` echo &#39;{\r\n      &quot;values&quot;: [\r\n        {&quot;host&quot;:&quot;xxx&quot;, &quot;port&quot;: 3939},\r\n        {&quot;host&quot;:&quot;yyy&quot;, &quot;port&quot;: 7373}\r\n      ]\r\n    }&#39;  | jq -c `\r\n\r\n\r\nAnd I want to read it like this:\r\n\r\n\r\n    #!/usr/bin/env bash\r\n    \r\n    echo &quot;$connection_info&quot; | jq -r &#39;.values[]&#39; |\r\n    \r\n      while read item; do\r\n    \r\n         timeout 10 telnet `jq -r &quot;$item&quot;` 9200 || {\r\n            echo &quot;Could not connect to host: $host port: $port&quot;\r\n         }\r\n      done;\r\n\r\nhow can parse the host and port from the item? Something like this:\r\n\r\nI could probably do:\r\n\r\n    host=`echo &quot;$item&quot; | jq -r &#39;.host&#39;`\r\n    port=`echo &quot;$item&quot; | jq -r &#39;.port&#39;`\r\n\r\n    timeout 10 telnet &quot;$host&quot; &quot;$port&quot; 9200 \r\n\r\nbut is there a way to do it without using stdin?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56386009/read-json-from-argument-instead-of-stdin-using-jq",
        "title": "Read json from argument instead of stdin using jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "tabulate"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1559291183,
                "last_edit_date": 1559291183,
                "creation_date": 1559261949,
                "answer_id": 56387171,
                "question_id": 56386521,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The irregularity of the input data makes the requirements a little opaque, but the following produces the desired output.\r\n\r\n    [&quot;counter&quot;, &quot;page&quot;, &quot;row&quot;, &quot;column&quot;, &quot;Abc&quot;],\r\n    (foreach (.document.page[] | objects) as $page ({page: -1, counter: 0};\r\n      .page += 1\r\n      | if ($page | (has(&quot;image&quot;) and (.image|has(&quot;Abc&quot;))))\r\n        then\r\n          .counter +=1\r\n          | .out = [.counter, .page, null, null, ($page|.image.Abc)]\r\n        else foreach ($page | .row[]?) as $row (.row=-1;\r\n          .row += 1\r\n          | foreach ($row | .column[]) as $column (.column=-1;\r\n              .column +=1\r\n    \t      | foreach ($column | .text | objects) as $x (.;\r\n                  .counter += 1\r\n                  | .out = [.counter, .page, .row, .column, $x[&quot;Abc&quot;]]\r\n                  ; . )\r\n               ; . )\r\n    \t  ; . )\r\n    \tend\r\n        ; .out )\r\n    )\r\n    | @tsv\r\n\r\n## Output\r\nSpecifically, with the -r command-line option, the output produced from the given input is as follows (tabs included):\r\n```\r\ncounter\tpage\trow\tcolumn\tAbc\r\n1\t0\t\t\t4\r\n2\t1\t0\t0\t2\r\n3\t1\t1\t0\t1\r\n4\t1\t1\t1\t9\r\n5\t1\t2\t0\t3\r\n6\t2\t0\t0\t2\r\n7\t2\t1\t0\t4\r\n8\t2\t1\t1\t9\r\n```\r\n",
                "title": "Relate elements in table form from Json file with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1559272212,
                "last_edit_date": 1559272212,
                "creation_date": 1559271247,
                "answer_id": 56388073,
                "question_id": 56386521,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following solution uses `paths` and has several advantages, including brevity, simplicity, and that it can easily be adapted to a handle data that is in a different format. \r\n\r\nFor clarity, we begin by defining a function that adds the row numbers:\r\n\r\n    # add a sequential id, starting at 1\r\n    def tsvRows(s):\r\n      foreach s as $s (0; .+1; [.] + $s)\r\n      | @tsv;\r\n    \r\n    ([&quot;counter&quot;, &quot;page&quot;, &quot;row&quot;, &quot;column&quot;, &quot;Abc&quot;] | @tsv),\r\n    tsvRows(paths as $p\r\n      | select($p[-1] == &quot;Abc&quot;)\r\n      | getpath($p) as $v\r\n      | $p\r\n      | .[2] as $page\r\n      | (if .[3] == &quot;row&quot; then .[4] else null end) as $row\r\n      | (if .[5] == &quot;column&quot; then .[6] else null end) as $column\r\n      | [$page, $row, $column, $v] )\r\n\r\n\r\n",
                "title": "Relate elements in table form from Json file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1559311721,
        "creation_date": 1559256070,
        "question_id": 56386521,
        "body_markdown": "I&#39;m new to `jq` and I have the following code to obtain tabulated the values for each element called `Abc`:\r\n\r\n\t[&quot;Abc&quot;], ( .. | objects | select(has(&quot;Abc&quot;)) | [.[&quot;Abc&quot;]] ) | @tsv\r\n\t\r\nThis is the current output I get:\r\n\r\n\t&quot;Abc&quot;\r\n\t&quot;4&quot;\r\n\t&quot;2&quot;\r\n\t&quot;1&quot;\r\n\t&quot;9&quot;\r\n\t&quot;3&quot;\r\n\t&quot;2&quot;\r\n\t&quot;4&quot;\r\n\t&quot;9&quot;\r\n\r\nI would like to add 4 columns to the left to show for each `Abc` value the corresponding page, row and column. Additionally if possible as first column add a counter from 1 to number of &quot;Abc&quot; elements.\r\n\r\nBelow I show the current output, compared with the desired output and the structure of the Json file in order to clarify:\r\n[![enter image description here][1]][1]\r\n\r\n\r\nThe input Json file is below:\r\n\r\n\t{\r\n\t  &quot;document&quot;: {\r\n\t\t&quot;page&quot;: [\r\n\t\t  {\r\n\t\t\t&quot;@index&quot;: &quot;0&quot;,\r\n\t\t\t&quot;image&quot;: {\r\n\t\t\t  &quot;Abc&quot;: &quot;4&quot;\r\n\t\t\t}\r\n\t\t  },\r\n\t\t  {\r\n\t\t\t&quot;@index&quot;: &quot;1&quot;,\r\n\t\t\t&quot;row&quot;: [\r\n\t\t\t  {\r\n\t\t\t\t&quot;column&quot;: [\r\n\t\t\t\t  {\r\n\t\t\t\t\t&quot;text&quot;: {\r\n\t\t\t\t\t  &quot;Abc&quot;: &quot;2&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t  }\r\n\t\t\t\t]\r\n\t\t\t  },\r\n\t\t\t  {\r\n\t\t\t\t&quot;column&quot;: [\r\n\t\t\t\t  {\r\n\t\t\t\t\t&quot;text&quot;: {\r\n\t\t\t\t\t  &quot;Abc&quot;: &quot;1&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t  },\r\n\t\t\t\t  {\r\n\t\t\t\t\t&quot;text&quot;: {\r\n\t\t\t\t\t  &quot;Abc&quot;: &quot;9&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t  }\r\n\t\t\t\t]\r\n\t\t\t  },\r\n\t\t\t  {\r\n\t\t\t\t&quot;column&quot;: [\r\n\t\t\t\t  {\r\n\t\t\t\t\t&quot;text&quot;: {\r\n\t\t\t\t\t  &quot;Abc&quot;: &quot;3&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t  }\r\n\t\t\t\t]\r\n\t\t\t  }\r\n\t\t\t]\r\n\t\t  },\r\n\t\t  {\r\n\t\t\t&quot;@index&quot;: &quot;2&quot;,\r\n\t\t\t&quot;row&quot;: [\r\n\t\t\t  {\r\n\t\t\t\t&quot;column&quot;: [\r\n\t\t\t\t  {\r\n\t\t\t\t\t&quot;text&quot;: {\r\n\t\t\t\t\t  &quot;Abc&quot;: &quot;2&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t  }\r\n\t\t\t\t]\r\n\t\t\t  },\r\n\t\t\t  {\r\n\t\t\t\t&quot;column&quot;: [\r\n\t\t\t\t  {\r\n\t\t\t\t\t&quot;text&quot;: {\r\n\t\t\t\t\t  &quot;Abc&quot;: &quot;4&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t  },\r\n\t\t\t\t  {\r\n\t\t\t\t\t&quot;text&quot;: {\r\n\t\t\t\t\t  &quot;Abc&quot;: &quot;9&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t  }\r\n\t\t\t\t]\r\n\t\t\t  }\r\n\t\t\t]\r\n\t\t  }\r\n\t\t]\r\n\t  }\r\n\t}\r\n\r\n\r\n\r\nI hope someone could help me. Thanks in advance.\r\n\r\n\r\n  [1]: https://i.sstatic.net/dMkaC.jpg",
        "link": "https://stackoverflow.com/questions/56386521/relate-elements-in-table-form-from-json-file-with-jq",
        "title": "Relate elements in table form from Json file with jq"
    },
    {
        "tags": [
            "cmd",
            "iteration",
            "conditional-statements",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1559453182,
                "last_edit_date": 1559453182,
                "creation_date": 1559452373,
                "answer_id": 56412368,
                "question_id": 56412209,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. The sample data is not quite valid JSON.  In the following, I&#39;ve assumed the superfluous commas can be removed.\r\n\r\n2. The first component (`.`) of your pipeline is harmless but not needed.\r\n\r\n3. Every occurrence of .[] expands the array, so when you write something like `if .[] ...` it is like a `for` loop.\r\nSo your jq program effectively has a for loop within a for loop within a for loop.\r\n\r\nPerhaps you meant:\r\n\r\n    .[]\r\n    | if (.nickname | length) &gt; 15 then &quot;\\(.nickname)\\t\\(.fingerprint)&quot; \r\n      else &quot;no&quot;\r\n      end\r\n\r\n## Debugging your own programs\r\n\r\nA useful debugging tool is the `debug` filter. It is like `tee /dev/stderr`.  You can use as many as you like, but in the present instance, you might start with:\r\n\r\n    if (.[].nickname | length) &gt;15 | debug\r\n    then &quot;\\(.[].nickname)\\t\\(.[].fingerprint)&quot;\r\n    else &quot;no&quot; \r\n    end\r\n\r\nWhen you want more than one `debug` in your program, it is sometimes useful to use an auxiliary function like so:\r\n\r\n    def mydebug(msg): (msg|debug) as $debug | . ;\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "Conditional doesn&#39;t work correctly when printing element values?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1559453351,
        "creation_date": 1559449784,
        "last_edit_date": 1559453351,
        "question_id": 56412209,
        "body_markdown": "Attempting to print data formatted in a specific way, but the conditional doesn&#39;t work correctly.\r\n\r\nI&#39;ve written a simple test:\r\n\r\n    jq -r &quot;. | if (.[].nickname | length) &gt;15 then \\&quot;\\(.[].nickname)\\t\\(.[].fingerprint)\\&quot; else \\&quot;no\\&quot; end&quot; running.json\r\n\r\nWhere running.json is this sample json:\r\n\r\n\t[\r\n\t  {\r\n\t\t&quot;nickname&quot;: &quot;FiverInstitute11&quot;,\r\n\t\t&quot;fingerprint&quot;: &quot;0011BD2J8D3J45D984EC4159C88FC066E5E3300E&quot;,\r\n\t  },\r\n\t  {\r\n\t\t&quot;nickname&quot;: &quot;Something13&quot;,\r\n\t\t&quot;fingerprint&quot;: &quot;0077BCBA7244DB3E6O2AD274H886170066684887&quot;,\r\n\t  },\r\n\t  {\r\n\t\t&quot;nickname&quot;: &quot;je8gvke8s2ff063CMbc&quot;,\r\n\t\t&quot;fingerprint&quot;: &quot;00B87ECU71DBF56805NE8469BAF3924A13AD7&quot;,\r\n\t  },\r\n\t  {\r\n\t\t&quot;nickname&quot;: &quot;test931&quot;,\r\n\t\t&quot;fingerprint&quot;: &quot;00DC112F7D469AD7E0E4B378D050490811BB20E5&quot;,\r\n\t  }\r\n\t]\r\n\r\nThe output never prints &quot;no&quot; even in the case that the conditional is false. Anyone know how this is fixed?",
        "link": "https://stackoverflow.com/questions/56412209/conditional-doesnt-work-correctly-when-printing-element-values",
        "title": "Conditional doesn&#39;t work correctly when printing element values?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1559471149,
                "creation_date": 1559471149,
                "answer_id": 56414178,
                "question_id": 56414157,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Like this:\r\n\r\n    jq -r &#39;.contexts[.current_context].mydata&#39; file.json\r\n\r\n\r\nYou could also use a variable:\r\n\r\n    jq -r &#39;.current_context as $cc|.contexts[$cc].mydata&#39; file.json",
                "title": "jq: How to look up a JSON object by name read from another object?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1559475244,
                "last_edit_date": 1559475244,
                "creation_date": 1559472555,
                "answer_id": 56414324,
                "question_id": 56414157,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "and here&#39;s an alternative to jq solution, based on a walk-path unix utility **[`jtc`][1]**:\r\n\r\n    bash $ jtc -w&#39;[current_context]&lt;cc&gt;v[^0]&lt;cc&gt;t[mydata]&#39; file.json\r\n    &quot;value2&quot;\r\n    bash $ \r\n\r\nwalk path (`-w`) breakdown:\r\n\r\n- `[current_context]&lt;cc&gt;v` - get to the `current_context` value and memorize it in the namespace `cc` (directive `&lt;cc&gt;v` does it)\r\n- `[^0]&lt;cc&gt;t[mydata]` - reset walk path back to root (`[^0]`) and recursively search for the label (tag) stored in the namespace (`&lt;cc&gt;t`), then address found JSON object by label `mydata`.\r\n\r\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` - shell cli tool for JSON operations\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n\r\n",
                "title": "jq: How to look up a JSON object by name read from another object?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1559475244,
        "creation_date": 1559470924,
        "question_id": 56414157,
        "body_markdown": "I have the following JSON: \r\n```json\r\n{\r\n    &quot;contexts&quot;: {\r\n        &quot;context1&quot;: {\r\n            &quot;mydata&quot;: &quot;value1&quot;\r\n        },\r\n        &quot;context2&quot;: {\r\n            &quot;mydata&quot;: &quot;value2&quot;\r\n        }\r\n    },\r\n    &quot;current_context&quot;: &quot;context2&quot;\r\n}\r\n```\r\n\r\nI&#39;d like to use `jq` to output the value of `mydata` for the context indicated by `current_context`. The above would output `value2`. If I change the JSON to have `&quot;current_context&quot;: &quot;context1&quot;`, I&#39;d get `value1`. \r\n\r\nGiven two invocations of jq, and the above JSON content in a file called `jq.json`, this works:\r\n\r\n```bash\r\njq -r --arg context &quot;$(jq -r &#39;.current_context&#39; jq.json)&quot; &#39;.contexts | to_entries[] | select(.key == $context) | .value.mydata&#39; jq.json\r\n```\r\n\r\nIs there a way to do this with a single invocation of jq?\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/56414157/jq-how-to-look-up-a-json-object-by-name-read-from-another-object",
        "title": "jq: How to look up a JSON object by name read from another object?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1559482006,
                "creation_date": 1559482006,
                "answer_id": 56415479,
                "question_id": 56415133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It does not need to be escaped, only quoted, e.g.\r\n\r\n    1, &quot;|&quot;, 2\r\n\r\nor\r\n\r\n    &quot;\\(input)|\\(input)&quot;",
                "title": "How to escape pipe character &quot;|&quot; for formatting purposes in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1559482006,
        "creation_date": 1559479234,
        "question_id": 56415133,
        "body_markdown": "I would like to escape the pipe character &quot;|&quot; in my output so that I can use it as a separator. Not sure how to escape it, though. Any insight?",
        "link": "https://stackoverflow.com/questions/56415133/how-to-escape-pipe-character-for-formatting-purposes-in-jq",
        "title": "How to escape pipe character &quot;|&quot; for formatting purposes in jq?"
    },
    {
        "tags": [
            "javascript",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559748812,
                "post_id": 56441926,
                "comment_id": 99518914,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14029358,
                    "reputation": 1005,
                    "user_id": 10133620,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a1d7d048a256558734a855437fa03d3d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bosskay972",
                    "link": "https://stackoverflow.com/users/10133620/bosskay972"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1559749196,
                "post_id": 56441926,
                "comment_id": 99519143,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1559750129,
                "post_id": 56441926,
                "comment_id": 99519670,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1559644279,
                "creation_date": 1559644279,
                "answer_id": 56442101,
                "question_id": 56441926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to get all `B` objects that are on `A`, you can use `Set` and `concat` to create an object with all the A values. Use `filter` to filter the object `B`\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    var obj = {&quot;A&quot;:[{&quot;AT&quot;:&quot;text&quot;},{&quot;AT&quot;:&quot;text2&quot;}],&quot;B&quot;:[{&quot;name&quot;:&quot;text&quot;,&quot;power&quot;:10},{&quot;name&quot;:&quot;text1&quot;,&quot;power&quot;:20},{&quot;name&quot;:&quot;text2&quot;,&quot;power&quot;:40}]}\r\n\r\n    var allAs = new Set([].concat(...obj.A.map(o =&gt; Object.values(o))));\r\n    var result = obj.B.filter(o =&gt; allAs.has(o.name));\r\n\r\n    console.log(result);\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\nYou can also use `flatMap` (available on Node 11.0.0) as:\r\n\r\n\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    var obj = {&quot;A&quot;:[{&quot;AT&quot;:&quot;text&quot;},{&quot;AT&quot;:&quot;text2&quot;}],&quot;B&quot;:[{&quot;name&quot;:&quot;text&quot;,&quot;power&quot;:10},{&quot;name&quot;:&quot;text1&quot;,&quot;power&quot;:20},{&quot;name&quot;:&quot;text2&quot;,&quot;power&quot;:40}]}\r\n\r\n    var allAs = new Set(obj.A.flatMap(o =&gt; Object.values(o)));\r\n    var result = obj.B.filter(o =&gt; allAs.has(o.name));\r\n\r\n    console.log(result);\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n",
                "title": "Is it possible to make nested query in jq with JSON object?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1559750103,
                "last_edit_date": 1559750103,
                "creation_date": 1559645383,
                "answer_id": 56442375,
                "question_id": 56441926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re piping `[.B[] | [.name , .power][]]`&#39;s product --which is to be an array of **strings**-- to `map(in([.A[].AT]))`, i.e input is changed and `.A` is lost, and you&#39;re trying to get `.A[].AT` from those **strings**. This is not the only issue but the reason why you get that error. You better do something like this:\r\n```\r\n( .B | map({(.name): .power}) | add ) as $b\r\n| .A | map(.AT | [., $b[.]]) | add\r\n```\r\nIf your input is too big using `reduce` you can get better performance:\r\n```\r\n( reduce .B[] as $b ({}; . + ($b | {(.name): .power})) ) as $b\r\n| reduce .A[].AT as $a ([]; . + [$a, $b[$a]])\r\n```\r\n\r\n---\r\nAs for your second question, by passing `results`, an array of objects, to `select(.name==&quot;bulba&quot;)`, as the error message states you&#39;re trying to index an array with a string. To filter objects under `results` move `select` into `map` like:\r\n```\r\nmap(select(.name == &quot;bulba&quot;) | .url.moves[].move.name | [., $b[.][]])\r\n```",
                "title": "Is it possible to make nested query in jq with JSON object?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1559750103,
        "creation_date": 1559643597,
        "last_edit_date": 1559749139,
        "question_id": 56441926,
        "body_markdown": "Here&#39;s my JSON:\r\n\r\n    {  \r\n       &quot;A&quot;:[  \r\n          {  \r\n             &quot;AT&quot;:&quot;text&quot;\r\n          },\r\n          {  \r\n             &quot;AT&quot;:&quot;text2&quot;\r\n          }\r\n       ],\r\n       &quot;B&quot;:[  \r\n          {  \r\n             &quot;name&quot;:&quot;text&quot;,\r\n             &quot;power&quot;:10\r\n          },\r\n          {  \r\n             &quot;name&quot;:&quot;text1&quot;,\r\n             &quot;power&quot;:20\r\n          },\r\n          {  \r\n             &quot;name&quot;:&quot;text2&quot;,\r\n             &quot;power&quot;:40\r\n          }\r\n       ]\r\n    }\r\n\r\nI want to have all B element with the same name as A element. So in this case the result would be `[&#39;text&#39;,10,&#39;text2&#39;,40]`. I try this query `[.B[] | [.name , .power][]]  | map(in([.A[].AT]))`but it doesn&#39;t work it&#39;s throw me an error:\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:23): Cannot index string with string &quot;A&quot;\r\n&gt;     exit status 5\r\n\r\nI don&#39;t know how to fix it but I think it&#39;s about the parent node, it doesn&#39;t recognize the nested query in the in function. So is it possible to make nested query in this language and how can handle a problem with nested query for other case like other function or other situation as pipe ?\r\n\r\nPS: I work in JAVASCRIPT (node.js)\r\n\r\nNew problem, I have this query:\r\n`( .Move | map({(.name): {accuracy : .url.accuracy, damage_class: .url.damage_class.name, power :  .url.power, priority: .url.priority, target: .url.target.name, type: .url.type.name, null}}) | add ) as $b | .results | select(.name==&quot;bulba&quot;) | map(.url.moves[].move.name | [., $b[.][]]) | add `\r\n\r\nand it&#39;s work perfectly without `select(.name==&quot;bulba&quot;)`\r\n\r\n&gt;jq: error (at &lt;stdin&gt;:158): Cannot index array with string &quot;name&quot;\r\n&gt;\r\n\r\nShould I show the JSON with this ?(because is a little bigger than the previous one)\r\nBut it&#39;s start with this:\r\n\r\n        {  \r\n       &quot;results&quot;:[  \r\n          {  \r\n             &quot;name&quot;:&quot;bulba&quot;,\r\n             &quot;url&quot;:{  \r\n                &quot;moves&quot;:[  \r\n                   {  \r\n                      &quot;move&quot;:{  \r\n                         &quot;name&quot;:&quot;flamiche&quot;\r\n                      }\r\n                   }\r\n                ]\r\n             }\r\n          },\r\n          {  \r\n             &quot;name&quot;:&quot;sala&quot;,\r\n             &quot;url&quot;:{  \r\n                &quot;moves&quot;:[  \r\n                   {  \r\n                      &quot;move&quot;:{  \r\n                         &quot;name&quot;:&quot;DAMSSSS&quot;\r\n                      }\r\n                   }\r\n                ]\r\n             }\r\n          }\r\n       ],\r\n       &quot;Move&quot;:[  \r\n          {  \r\n             &quot;name&quot;:&quot;flamiche&quot;,\r\n             &quot;url&quot;:{  \r\n                &quot;accuracy&quot;:50,\r\n                &quot;damage_class&quot;:{  \r\n                   &quot;name&quot;:&quot;physical&quot;\r\n                },\r\n                &quot;power&quot;:50,\r\n                &quot;priority&quot;:0,\r\n                &quot;target&quot;:{  \r\n                   &quot;name&quot;:&quot;foe&quot;\r\n                },\r\n                &quot;type&quot;:{  \r\n                   &quot;name&quot;:&quot;fire&quot;\r\n                }\r\n             }\r\n          },\r\n          {  \r\n             &quot;name&quot;:&quot;DAMSSSS&quot;,\r\n             &quot;url&quot;:{  \r\n                &quot;accuracy&quot;:90,\r\n                &quot;damage_class&quot;:{  \r\n                   &quot;name&quot;:&quot;status&quot;\r\n                },\r\n                &quot;power&quot;:null,\r\n                &quot;priority&quot;:2,\r\n                &quot;target&quot;:{  \r\n                   &quot;name&quot;:&quot;self&quot;\r\n                },\r\n                &quot;type&quot;:{  \r\n                   &quot;name&quot;:&quot;grass&quot;\r\n                }\r\n             }\r\n          }\r\n       ]\r\n    }\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56441926/is-it-possible-to-make-nested-query-in-jq-with-json-object",
        "title": "Is it possible to make nested query in jq with JSON object?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1559646237,
                "creation_date": 1559646237,
                "answer_id": 56442592,
                "question_id": 56442259,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "OK, as usual ... once you post a public question, you then manage to find a solution yourself ... ;)\r\n\r\nThis jq-call does what I need:\r\n\r\n    jq &#39;. ._meta.hostvars[].ansible_ssh_pass |= sub(&quot; .*&quot;;&quot;&quot; )&#39;",
                "title": "Conditionally changing JSON values in jq with sub() function"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1559661374,
        "creation_date": 1559644870,
        "last_edit_date": 1559661374,
        "question_id": 56442259,
        "body_markdown": "I need to alter some values in JSON data, and would like to include it in an already existing shell script. I&#39;m trying to do so using jq, and will need the &quot;sub()&quot; function to cut off a piece of a string value.\r\n\r\n\r\n\r\nUsing this command line:\r\n\r\n    jq &#39;._meta[][].ansible_ssh_pass | sub(&quot; .*&quot; ; &quot;&quot;)&#39;\r\n\r\nwith the data below will correctly replace the value (cutting off anything including the first space in the data), but only prints out the value, not the complete JSON structure.\r\n\r\nHere&#39;s sample JSON data:\r\n\r\n    {_meta&quot;: {\r\n        &quot;hostvars&quot;: {\r\n          &quot;10.1.1.3&quot;: {\r\n            &quot;hostname&quot;: &quot;core-gw1&quot;,\r\n            &quot;ansible_user&quot;: &quot;&quot;,\r\n            &quot;ansible_ssh_pass&quot;: &quot;test123 / ena: test2&quot;,\r\n            &quot;configsicherung&quot;: &quot;true&quot;,\r\n            &quot;os&quot;: &quot;ios&quot;,\r\n            &quot;managementpaket&quot;: &quot;&quot;\r\n          }\r\n        }\r\n    }}\r\n\r\nOutput should be something like this:\r\n\r\n    {&quot;_meta&quot;: {\r\n        &quot;hostvars&quot;: {\r\n          &quot;10.1.1.3&quot;: {\r\n            &quot;hostname&quot;: &quot;core-gw1&quot;,\r\n            &quot;ansible_user&quot;: &quot;&quot;,\r\n            &quot;ansible_ssh_pass&quot;: &quot;test123&quot;,\r\n            &quot;configsicherung&quot;: &quot;true&quot;,\r\n            &quot;os&quot;: &quot;ios&quot;,\r\n            &quot;managementpaket&quot;: &quot;&quot;\r\n          }\r\n        }\r\n    }}\r\n\r\nI assume I have to add some sort of &quot;if... then&quot; based arguments, but haven&#39;t been able to get jq to understand me ;) Manual is a bit sketchy and I haven&#39;t been able to find any example I could get to match up with what I need to do ...\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56442259/conditionally-changing-json-values-in-jq-with-sub-function",
        "title": "Conditionally changing JSON values in jq with sub() function"
    },
    {
        "tags": [
            "json",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1664195782,
                "last_edit_date": 1664195782,
                "creation_date": 1559648592,
                "answer_id": 56443190,
                "question_id": 56442850,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Because, `first`&#39;s input is a stream of objects and thus it is run once for each one. To run it once for entire stream specify `-n/--null-input` flag on the command line and access inputs using the `inputs` function. This way `first`&#39;s input will be `null` and its argument will be a stream of objects `select`ed from `inputs`, so it will be able to yield only the first one.\r\n``` json\r\n$ jq -n &#39;first(inputs | select(.updated_at == &quot;2019-06-03T16:36:53.194Z&quot;))&#39; file\r\n{\r\n  &quot;_id&quot;: &quot;a&quot;,\r\n  &quot;updated_at&quot;: &quot;2019-06-03T16:36:53.194Z&quot;\r\n}\r\n```",
                "title": "First match from json stream using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1664195782,
        "creation_date": 1559647219,
        "question_id": 56442850,
        "body_markdown": "why is `first(select(.updated_at==&quot;2019-06-03T16:36:53.194Z&quot;))` returning more than 1 result when input is\r\n\r\n```\r\n{&quot;_id&quot;:&quot;a&quot;,&quot;updated_at&quot;:&quot;2019-06-03T16:36:53.194Z&quot;}\r\n{&quot;_id&quot;:&quot;b&quot;,&quot;updated_at&quot;:&quot;2019-06-03T19:27:15.192Z&quot;}\r\n{&quot;_id&quot;:&quot;c&quot;,&quot;updated_at&quot;:&quot;2019-06-03T20:02:11.538Z&quot;}\r\n{&quot;_id&quot;:&quot;d&quot;,&quot;updated_at&quot;:&quot;2019-06-03T21:12:05.764Z&quot;}\r\n{&quot;_id&quot;:&quot;e&quot;,&quot;updated_at&quot;:&quot;2019-06-04T07:55:04.251Z&quot;}\r\n{&quot;_id&quot;:&quot;f&quot;,&quot;updated_at&quot;:&quot;2019-06-03T22:21:37.276Z&quot;}\r\n{&quot;_id&quot;:&quot;g&quot;,&quot;updated_at&quot;:&quot;2019-06-03T20:57:42.296Z&quot;}\r\n{&quot;_id&quot;:&quot;h&quot;,&quot;updated_at&quot;:&quot;2019-06-03T18:56:07.687Z&quot;}\r\n{&quot;_id&quot;:&quot;i&quot;,&quot;updated_at&quot;:&quot;2019-06-04T09:28:08.276Z&quot;}\r\n{&quot;_id&quot;:&quot;j&quot;,&quot;updated_at&quot;:&quot;2019-06-04T08:54:05.048Z&quot;}\r\n{&quot;_id&quot;:&quot;k&quot;,&quot;updated_at&quot;:&quot;2019-06-03T16:36:53.194Z&quot;}\r\n{&quot;_id&quot;:&quot;l&quot;,&quot;updated_at&quot;:&quot;2019-06-03T16:36:53.194Z&quot;}\r\n\r\n```\r\n\r\n[https://jqplay.org/s/2sm1pKQ2fS][1]\r\n\r\nI also tried using `nth` but it doesn&#39;t seem to have the expected behaviour either:\r\n\r\n[https://jqplay.org/s/DeSANQZtj7][2]\r\n\r\n\r\n  [1]: https://jqplay.org/s/2sm1pKQ2fS\r\n  [2]: https://jqplay.org/s/DeSANQZtj7",
        "link": "https://stackoverflow.com/questions/56442850/first-match-from-json-stream-using-jq",
        "title": "First match from json stream using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1559652724,
                "post_id": 56444091,
                "comment_id": 99482069,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1559652300,
                "creation_date": 1559652300,
                "answer_id": 56444177,
                "question_id": 56444091,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Looks like you want the following :\r\n\r\n    jq --raw-output &#39;.items[] | .node + &quot; &quot; + .result.stdout&#39; out.json\r\n\r\nYou can [try it here](https://jqplay.org/s/CAMSFmpe3W)",
                "title": "How to extract fields from a json string using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1559669650,
                "last_edit_date": 1559669650,
                "creation_date": 1559667853,
                "answer_id": 56448407,
                "question_id": 56444091,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "if interested in an alternative solution, there&#39;s anoter way of achieving the same - using a walk-path based unix utility **[`jtc`][1]**:\r\n\r\n    bash $ &lt;out.json jtc -w&#39;[items][:][node]&lt;n&gt;v[-1][result][stdout]&#39; -T&#39;&quot;{n} {}&quot;&#39; -qq\r\n    aaaa-cn001.me.com 3.10.0-957.12.1.el7.x86_64\r\n    \r\n    aaaa-cn002.me.com 3.10.0-957.10.1.el7.x86_64\r\n    \r\n    aaaa-cn003.me.com 3.10.0-957.10.1.el7.x86_64\r\n    \r\n    aaaa-cn004.me.com 3.10.0-957.12.1.el7.x86_64\r\n    \r\n    bash $ \r\n\r\nNote, an extra line occurs here, because `stdout` values carry trailing `\\n`, which upon unquoting JSON string (`-qq`) results in the extra spacer.\r\n\r\nIf you like to print w/o preserving that line, use this form then:\r\n\r\n    bash $ &lt;out.json jtc -w&#39;[items][:][node]&lt;n&gt;v[-1][result][stdout]:&lt;(.*)\\\\n&gt;R&#39; -T&#39;&quot;{n} {$1}&quot;&#39; -qq\r\n    aaaa-cn001.me.com 3.10.0-957.12.1.el7.x86_64\r\n    aaaa-cn002.me.com 3.10.0-957.10.1.el7.x86_64\r\n    aaaa-cn003.me.com 3.10.0-957.10.1.el7.x86_64\r\n    aaaa-cn004.me.com 3.10.0-957.12.1.el7.x86_64\r\n    bash $ \r\n\r\nPS&gt; Disclosure: I&#39;m the creator of the `jtc` - shell cli tool for JSON operations\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md\r\n\r\n\r\n",
                "title": "How to extract fields from a json string using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1559669650,
        "creation_date": 1559652020,
        "last_edit_date": 1559652579,
        "question_id": 56444091,
        "body_markdown": "How to extract two fields from a JSON file using jq?\r\n\r\nWhen I run &#39;jq &#39;.node&#39; out.json I get the word &#39;null&#39; in output \r\n\r\nHere is what I have in a file named out.json\r\n```\r\nhead out.json \r\n{ &quot;items&quot;: [ {&quot;node&quot;:&quot;aaaa-cn001.me.com&quot;,&quot;status&quot;:&quot;success&quot;,&quot;result&quot;:{&quot;stdout&quot;:&quot;3.10.0-957.12.1.el7.x86_64\\n&quot;,&quot;stderr&quot;:&quot;&quot;,&quot;exit_code&quot;:0}} , {&quot;node&quot;:&quot;aaaa-cn002.me.com&quot;,&quot;status&quot;:&quot;success&quot;,&quot;result&quot;:{&quot;stdout&quot;:&quot;3.10.0-957.10.1.el7.x86_64\\n&quot;,&quot;stderr&quot;:&quot;&quot;,&quot;exit_code&quot;:0}} , {&quot;node&quot;:&quot;aaaa-cn003.me.com&quot;,&quot;status&quot;:&quot;success&quot;,&quot;result&quot;:{&quot;stdout&quot;:&quot;3.10.0-957.10.1.el7.x86_64\\n&quot;,&quot;stderr&quot;:&quot;&quot;,&quot;exit_code&quot;:0}} , {&quot;node&quot;:&quot;aaaa-cn004.me.com&quot;,&quot;status&quot;:&quot;success&quot;,&quot;result&quot;:{&quot;stdout&quot;:&quot;3.10.0-957.12.1.el7.x86_64\\n&quot;,&quot;stderr&quot;:&quot;&quot;,&quot;exit_code&quot;:0}}\r\n\r\n```\r\n\r\n\r\nI would like the output to be this way:\r\n```\r\naaaa-cn001.me.com 3.10.0-957.12.1.el7.x86_64\r\naaaa-cn002.me.com 3.10.0-957.10.1.el7.x86_64\r\naaaa-cn003.me.com 3.10.0-957.10.1.el7.x86_64\r\naaaa-cn004.me.com 3.10.0-957.12.1.el7.x86_64\r\n```",
        "link": "https://stackoverflow.com/questions/56444091/how-to-extract-fields-from-a-json-string-using-jq",
        "title": "How to extract fields from a json string using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559661769,
                "post_id": 56446282,
                "comment_id": 99487260,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8776110,
                    "reputation": 4236,
                    "user_id": 6561343,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/jLApU.png?s=256",
                    "display_name": "JGK",
                    "link": "https://stackoverflow.com/users/6561343/jgk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559662070,
                "post_id": 56446282,
                "comment_id": 99487424,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1559663187,
                "last_edit_date": 1559663187,
                "creation_date": 1559662282,
                "answer_id": 56447025,
                "question_id": 56446282,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t know if this is the solution you are looking for because the requested output is not clear to me, but you can go with this one-liner\r\n\r\n    jq &#39;.[] | select(.&quot;num-of-connections&quot;&gt;0) | {&quot;owner&quot;: .&quot;owner&quot;, &quot;num-of-connections&quot;: .&quot;num-of-connections&quot;, &quot;last-disconnection-time&quot;: .&quot;last-disconnection-time&quot;}&#39; input.json\r\n\r\nor this\r\n\r\n    jq -r &#39;.[] | select(.&quot;num-of-connections&quot;&gt;0) | &quot;\\(.owner) \\(.&quot;num-of-connections&quot;) \\(.&quot;last-disconnection-time&quot;)&quot;&#39; input.json ",
                "title": "Iterate through JSON array and record certain values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1559662326,
                "creation_date": 1559662326,
                "answer_id": 56447040,
                "question_id": 56446282,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe this?\r\n\r\n    jq -r &#39;.[] | select(.&quot;num-of-connections&quot; &gt; 0) | &quot;User \\(.owner) has \\(.&quot;num-of-connections&quot;) open connections and last disconnected at \\(.&quot;last-disconnection-time&quot;).&quot;&#39; test.json\r\n\r\nwhich on your fixed up sample data prints out:\r\n\r\n    User johndoe has 1 open connections and last disconnected at 2019-05-30T21:47:36.682935Z.\r\n",
                "title": "Iterate through JSON array and record certain values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1559665415,
        "creation_date": 1559659698,
        "last_edit_date": 1559665415,
        "question_id": 56446282,
        "body_markdown": "I need to iterate through this JSON array and record the num-of-connections value if it is greater than 0, then, if it is greater than 0 record the owner and their last-disconnection-time and store them to be output to the console once the script is done.\r\n\r\n\r\n\r\nI have tried for loops and while loops but cannot figure out how to record certain values and get the other values to be output to the console at the end of the script. \r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot; : &quot;123456&quot;,\r\n    &quot;owner&quot; : &quot;johndoe&quot;,\r\n    &quot;x11-display&quot; : &quot;:9&quot;,\r\n    &quot;x11-authority&quot; : &quot;/run/user/1112/dcv/123456.xauth&quot;,\r\n    &quot;num-of-connections&quot; : 1,\r\n    &quot;creation-time&quot; : &quot;2019-05-28T14:42:24.027240Z&quot;,\r\n    &quot;last-disconnection-time&quot; : &quot;2019-05-30T21:47:36.682935Z&quot;\r\n  },\r\n  {\r\n    &quot;id&quot; : &quot;12345&quot;,\r\n    &quot;owner&quot; : &quot;johnsmith&quot;,\r\n    &quot;x11-display&quot; : &quot;:5&quot;,\r\n    &quot;x11-authority&quot; : &quot;/run/user/user/dcv/12345.xauth&quot;,\r\n    &quot;num-of-connections&quot; : 0,\r\n    &quot;creation-time&quot; : &quot;2019-05-14T14:12:14.989287Z&quot;,\r\n    &quot;last-disconnection-time&quot; : &quot;2019-05-31T18:58:42.851223Z&quot;\r\n  }\r\n]\r\n```\r\n\r\nWhat I want is a summary at the end of the script that says something like this . \r\n\r\nuser $owner has $num-of-connections open connections and last disconnected at $last-disconnection-time . \r\n\r\nI want this only if the num-of-connections is greater than 0. Any help would be much appreciated.",
        "link": "https://stackoverflow.com/questions/56446282/iterate-through-json-array-and-record-certain-values",
        "title": "Iterate through JSON array and record certain values"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1559723875,
                "last_edit_date": 1559723875,
                "creation_date": 1559667332,
                "answer_id": 56448286,
                "question_id": 56446693,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a  [stream-oriented][1] definition of &quot;unique&quot;:\r\n\r\n```\r\ndef unique(stream):\r\n  foreach stream as $s ({};\r\n     ($s|type) as $t\r\n     | ($s|tostring) as $y\r\n     | if .[$t][$y] then .emit = false\r\n       else .emit = true | (.item = $s) | (.[$t][$y] = true)\r\n       end;\r\n     if .emit then .item else empty end );\r\n```\r\n\r\nYou could use it with the -n command line option like so:\r\n\r\n    unique(inputs)\r\n\r\n### Programming Notes\r\n\r\nThe above stream-oriented version of &quot;unique&quot; does not entail a sort, and in that sense is more time-efficient than the built-in version. \r\n\r\nThe space required is linear in the number of distinct items.  If the items in the stream are known to be sorted (or arranged so that all items that are equal are adjacent), then `uniq` as defined below may be of interest.\r\n\r\n### uniq/1\r\n\r\nThe [jq Cookbook][2] gives this def for `uniq`, which behaves more like Linux `uniq`:\r\n\r\n```\r\ndef uniq(s):\r\n  foreach s as $x (null;\r\n    if . == null or .emitted != $x then {emit: true, emitted: $x}\r\n    else .emit = false\r\n    end;\r\n    if .emit then $x else empty end);\r\n```\r\n \r\n  [1]: https://github.com/pkoppstein/jq/wiki/A-Stream-oriented-Introduction-to-jq\r\n\r\n  [2]: https://github.com/stedolan/jq/wiki/Cookbook#remove-adjacent-matching-elements-from-a-list",
                "title": "Is it possible to use unique operator over a stream in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1559723875,
        "creation_date": 1559661117,
        "question_id": 56446693,
        "body_markdown": "The following code\r\n\r\n```\r\nfor i in {1..10}; do \r\n    echo &#39;{&quot;key&quot;:&#39;$(($RANDOM % 3))&#39;}&#39;\r\n    sleep 1 \r\ndone | jq -n &#39;[inputs]|unique&#39;\r\n``` \r\n\r\nwould print (if they all had appear):\r\n\r\n```\r\n[\r\n  {\r\n    &quot;key&quot;: 0\r\n  },\r\n  {\r\n    &quot;key&quot;: 1\r\n  },\r\n  {\r\n    &quot;key&quot;: 2\r\n  }\r\n]\r\n```\r\n\r\nThe problem is that you need to wait 10s to see the result (`10` * `sleep 1`). Is there a stream version were as soon as a new element appears it would flush it to stdout?\r\n",
        "link": "https://stackoverflow.com/questions/56446693/is-it-possible-to-use-unique-operator-over-a-stream-in-jq",
        "title": "Is it possible to use unique operator over a stream in jq"
    },
    {
        "tags": [
            "docker",
            "jq",
            "httpie"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1559701519,
                "creation_date": 1559701519,
                "answer_id": 56453537,
                "question_id": 56452639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is the dockerfile of the image you used, see [this](https://hub.docker.com/r/blacktop/httpie/dockerfile):\r\n\r\n    FROM alpine:latest\r\n\r\n    RUN apk add --no-cache jq httpie\r\n\r\n    ENTRYPOINT [ &quot;http&quot; ]\r\n    CMD [ &quot;--help&quot; ]\r\n\r\nFrom above, you can see it set an `entrypoint` with `http` for this image, so all your command used in `docker run` will be act as parameters for `http`, so of course you will fail.\r\n\r\nNext is a method for you to make use of it:\r\n\r\n    docker run -it --rm --entrypoint=/bin/sh blacktop/httpie -c &quot;http -b ifconfig.co/json | jq &#39;.ip&#39;&quot;\r\n\r\nSample output:\r\n\r\n    &quot;92.121.64.197&quot;\r\n\r\nAbove command will override the default `entrypoint` with `/bin/sh`, then you can use `jq` to parse output of `httpie` in pipeline.",
                "title": "How to use httpie and jq within docker?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 7,
        "last_activity_date": 1559701519,
        "creation_date": 1559692019,
        "question_id": 56452639,
        "body_markdown": "How to use httpid and jq within docker?\r\n\r\nI want to get the ip only in json result like &#39;34.10.12.40&#39;\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-shell --&gt;\r\n\r\n    docker run -it --rm blacktop/httpie -b ifconfig.co/json\r\n    {\r\n        &quot;country&quot;: &quot;United States&quot;,\r\n        &quot;country_eu&quot;: false,\r\n        &quot;country_iso&quot;: &quot;US&quot;,\r\n        &quot;hostname&quot;: &quot;lqwtx.com&quot;,\r\n        &quot;ip&quot;: &quot;34.10.12.40&quot;,\r\n        &quot;ip_decimal&quot;: 39585,\r\n        &quot;latitude&quot;: 35,\r\n        &quot;longitude&quot;: 105\r\n    }\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\nbut I&#39;ve tried some ways but does not work, like blow.\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-shell --&gt;\r\n\r\n    docker run -it --rm blacktop/httpie ash -c &quot;http -b ifconfig.co/json | jq &#39;.ip’”\r\n\r\n    docker run -it --rm blacktop/httpie -b ifconfig.co/json jq &#39;.ip&#39;\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56452639/how-to-use-httpie-and-jq-within-docker",
        "title": "How to use httpie and jq within docker?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4718259,
                    "reputation": 2640,
                    "user_id": 3816881,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/a1e18a15468fed98d94cd7ada4ff7656?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Mathyn",
                    "link": "https://stackoverflow.com/users/3816881/mathyn"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1559726735,
                "post_id": 56457558,
                "comment_id": 99507274,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10114488,
                    "reputation": 787,
                    "user_id": 7473629,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/10211845663367753/picture?type=large",
                    "display_name": "Anna Semj&#233;n",
                    "link": "https://stackoverflow.com/users/7473629/anna-semj%c3%a9n"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559727434,
                "post_id": 56457558,
                "comment_id": 99507629,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16076044,
                    "reputation": 41,
                    "user_id": 11603236,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-DjRKlaobIgc/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rfWHpbBEN7rE_SsRd8ZKN1kJmLP6Q/mo/s256-rj/photo.jpg",
                    "display_name": "Anjali",
                    "link": "https://stackoverflow.com/users/11603236/anjali"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559815870,
                "post_id": 56457558,
                "comment_id": 99541081,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16076044,
                    "reputation": 41,
                    "user_id": 11603236,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-DjRKlaobIgc/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rfWHpbBEN7rE_SsRd8ZKN1kJmLP6Q/mo/s256-rj/photo.jpg",
                    "display_name": "Anjali",
                    "link": "https://stackoverflow.com/users/11603236/anjali"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559816195,
                "post_id": 56457558,
                "comment_id": 99541262,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16076044,
                    "reputation": 41,
                    "user_id": 11603236,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-DjRKlaobIgc/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rfWHpbBEN7rE_SsRd8ZKN1kJmLP6Q/mo/s256-rj/photo.jpg",
                    "display_name": "Anjali",
                    "link": "https://stackoverflow.com/users/11603236/anjali"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559816283,
                "post_id": 56457558,
                "comment_id": 99541301,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16076044,
                    "reputation": 41,
                    "user_id": 11603236,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-DjRKlaobIgc/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rfWHpbBEN7rE_SsRd8ZKN1kJmLP6Q/mo/s256-rj/photo.jpg",
                    "display_name": "Anjali",
                    "link": "https://stackoverflow.com/users/11603236/anjali"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559816325,
                "post_id": 56457558,
                "comment_id": 99541320,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1559730294,
                "last_edit_date": 1559730294,
                "creation_date": 1559727550,
                "answer_id": 56457952,
                "question_id": 56457558,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "  https://stedolan.github.io/jq/manual/\r\n\r\n    jq &#39;.nextToken, .jobSummaryList[].jobName&#39; file",
                "title": "how to extract multiple values from json object using jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1559730294,
        "creation_date": 1559726124,
        "last_edit_date": 1559730229,
        "question_id": 56457558,
        "body_markdown": "I am trying to get multiple values from a json object.\r\n```\r\n{\r\n    &quot;nextToken&quot;: &quot;9i2x1mbCpfo5hQ&quot;,\r\n    &quot;jobSummaryList&quot;: [\r\n        {\r\n            &quot;jobName&quot;: &quot;012210&quot;,\r\n            &quot;jobId&quot;: &quot;0196f81cae73&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\nI want `nextToken`&#39;s value and `jobName` in one jq command.",
        "link": "https://stackoverflow.com/questions/56457558/how-to-extract-multiple-values-from-json-object-using-jq-command",
        "title": "how to extract multiple values from json object using jq command"
    },
    {
        "tags": [
            "module",
            "jq",
            "dependency-management"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1560352483,
                "last_edit_date": 1560352483,
                "creation_date": 1559811677,
                "answer_id": 56474197,
                "question_id": 56467959,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The support for modules in jq is currently (June 2019) still very minimal, though on github there is a module management system for jq: https://github.com/joelpurra/jqnpm\r\n\r\nWithout using such an external module management system, what can be done in jq itself?  Extending the given example, the following illustrates one approach to supporting version requirements. Notice the additional key named `dependencies` in the metadata of the `math` module. (Currently, this key cannot be named `deps` as jq overwrites it.)\r\n\r\n## Files\r\n### dependencies.jq\r\n```\r\n# Recursively check specified version constraints \r\n\r\nmodule { name: &quot;dependencies&quot;, version: &quot;0.0.2&quot; };\r\n\r\n# parents of a module as defined by its .deps\r\ndef parents:\r\n  . as $in\r\n  | if type == &quot;array&quot; then map(parents) | add\r\n    else modulemeta | .deps | map(.relpath)\r\n    end ;\r\n\r\n# ancestors of a single module or an array of modules.\r\n# The array of &quot;ancestors&quot; of a module includes itself.\r\ndef ancestors:\r\n  # input and $visited should be arrays of strings\r\n  def ancestors($visited):\r\n    . as $in\r\n    | ($in - $visited) as $new\r\n    | if $new == [] then $visited\r\n      else $new | parents | ancestors($visited + $new | unique)\r\n      end;\r\n  if type == &quot;array&quot; then . else [.] end\r\n  | ancestors([]) ;\r\n\r\ndef versionsort:\r\n  def parse:\r\n    sub(&quot;(?&lt;a&gt;(alpha|beta|gamma))&quot;; &quot;\\(.a).&quot;)\r\n    | [splits(&quot;[-.]&quot;)]\r\n    | map(tonumber? // .) ;\r\n  sort_by(parse);\r\n\r\n# Input: a module name\r\n# Emit empty if the constraints for the given module are satisfied, otherwise raise an error\r\ndef dependencies($version):\r\n  def le($y):  (. == $y) or ([.,$y] | . == versionsort);\r\n\r\n  modulemeta\r\n  | .version as $mv\r\n  | if (($mv == null) or ($version | le($mv))) then empty\r\n    else (&quot;module \\(.name) dependencies version \\($version) vs \\($mv)&quot; | error)\r\n    end ;\r\n\r\n# Input: a module name or array of module names\r\n# Check the module-version dependencies in .dependencies, proceeding up the chain as defined by .deps\r\ndef dependencies:\r\n  def check:\r\n    modulemeta\r\n    | select(has(&quot;dependencies&quot;))\r\n    | all( .dependencies | to_entries[];\r\n           .key as $m | .value as $v | ($m | dependencies($v) ))\r\n    | empty;\r\n  ancestors[] | check;\r\n\r\n```\r\n### util.jq\r\n```\r\nmodule { name: &quot;util&quot;, version: &quot;1.0.0&quot; };\r\n\r\ndef digitsum: tostring|split(&quot;&quot;)|map(tonumber)|add;\r\n```\r\n\r\n### math.jq\r\n```\r\nmodule { \r\n   name: &quot;math&quot;,\r\n   version: &quot;0.1.0&quot;,\r\n   dependencies: {&quot;util&quot;: &quot;1.0.0&quot;} };\r\n\r\ninclude &quot;util&quot; ;\r\n\r\ndef digitroot:\r\n  digitsum as $sum\r\n  | if $sum&lt;10 then $sum\r\n    else $sum|digitroot\r\n    end;\r\n```\r\n\r\n## Invocation\r\n\r\n```\r\njq -n -L . &#39;\r\n  include &quot;dependencies&quot;;\r\n  include &quot;math&quot;;\r\n\r\n  &quot;math&quot; | dependencies,\r\n  (123|digitroot) &#39;\r\n```",
                "title": "How to manage module dependencies in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1560352483,
        "creation_date": 1559768505,
        "question_id": 56467959,
        "body_markdown": "Since version 1.5 the [jq data processing language](https://stedolan.github.io/jq/) has a [library module system](https://stedolan.github.io/jq/manual/#Modules). A module consists of optional metadata and a set of functions. For instance\r\n\r\n~~~jq\r\nmodule { name: &quot;util&quot;, version: &quot;1.0.0&quot; };\r\ndef digitsum: tostring|split(&quot;&quot;)|map(tonumber)|add;\r\n~~~\r\n\r\nstored as file `util.jq` can be used like this:\r\n\r\n~~~bash\r\n$ echo &#39;789&#39; | jq -L. &#39;include &quot;util&quot;; digitsum&#39;\r\n24\r\n~~~\r\n\r\nModules can use other modules and the dependencies are tracked by the `modulemeta` directive but how to express and check for a minimum version of a module number? For instance:\r\n\r\n~~~\r\nmodule {\r\n  name: &quot;math&quot;,\r\n  version: &quot;0.1.0&quot;,\r\n};\r\n\r\ninclude &quot;util&quot;; # TODO: require at least version 1.0.0!\r\n\r\ndef digitroot:\r\n  (.|digitsum) as $sum |\r\n  if $sum&lt;10 then $sum else $sum|digitroot end;\r\n~~~",
        "link": "https://stackoverflow.com/questions/56467959/how-to-manage-module-dependencies-in-jq",
        "title": "How to manage module dependencies in jq"
    },
    {
        "tags": [
            "javascript",
            "node.js",
            "json",
            "promise",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 61252,
                    "reputation": 414734,
                    "user_id": 182668,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/b19917aa04a6839aef577f1117c71d48?s=256&d=identicon&r=PG",
                    "display_name": "Pointy",
                    "link": "https://stackoverflow.com/users/182668/pointy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559770030,
                "post_id": 56468234,
                "comment_id": 99527954,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14029358,
                    "reputation": 1005,
                    "user_id": 10133620,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a1d7d048a256558734a855437fa03d3d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bosskay972",
                    "link": "https://stackoverflow.com/users/10133620/bosskay972"
                },
                "reply_to_user": {
                    "account_id": 61252,
                    "reputation": 414734,
                    "user_id": 182668,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/b19917aa04a6839aef577f1117c71d48?s=256&d=identicon&r=PG",
                    "display_name": "Pointy",
                    "link": "https://stackoverflow.com/users/182668/pointy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559770154,
                "post_id": 56468234,
                "comment_id": 99527997,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 61252,
                    "reputation": 414734,
                    "user_id": 182668,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/b19917aa04a6839aef577f1117c71d48?s=256&d=identicon&r=PG",
                    "display_name": "Pointy",
                    "link": "https://stackoverflow.com/users/182668/pointy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559770402,
                "post_id": 56468234,
                "comment_id": 99528074,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14029358,
                    "reputation": 1005,
                    "user_id": 10133620,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a1d7d048a256558734a855437fa03d3d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bosskay972",
                    "link": "https://stackoverflow.com/users/10133620/bosskay972"
                },
                "reply_to_user": {
                    "account_id": 61252,
                    "reputation": 414734,
                    "user_id": 182668,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/b19917aa04a6839aef577f1117c71d48?s=256&d=identicon&r=PG",
                    "display_name": "Pointy",
                    "link": "https://stackoverflow.com/users/182668/pointy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559770504,
                "post_id": 56468234,
                "comment_id": 99528109,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14029358,
                    "reputation": 1005,
                    "user_id": 10133620,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a1d7d048a256558734a855437fa03d3d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bosskay972",
                    "link": "https://stackoverflow.com/users/10133620/bosskay972"
                },
                "reply_to_user": {
                    "account_id": 61252,
                    "reputation": 414734,
                    "user_id": 182668,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/b19917aa04a6839aef577f1117c71d48?s=256&d=identicon&r=PG",
                    "display_name": "Pointy",
                    "link": "https://stackoverflow.com/users/182668/pointy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559770865,
                "post_id": 56468234,
                "comment_id": 99528256,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14029358,
                    "reputation": 1005,
                    "user_id": 10133620,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a1d7d048a256558734a855437fa03d3d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bosskay972",
                    "link": "https://stackoverflow.com/users/10133620/bosskay972"
                },
                "reply_to_user": {
                    "account_id": 61252,
                    "reputation": 414734,
                    "user_id": 182668,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/b19917aa04a6839aef577f1117c71d48?s=256&d=identicon&r=PG",
                    "display_name": "Pointy",
                    "link": "https://stackoverflow.com/users/182668/pointy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559776020,
                "post_id": 56468234,
                "comment_id": 99529586,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 61252,
                    "reputation": 414734,
                    "user_id": 182668,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/b19917aa04a6839aef577f1117c71d48?s=256&d=identicon&r=PG",
                    "display_name": "Pointy",
                    "link": "https://stackoverflow.com/users/182668/pointy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559786734,
                "post_id": 56468234,
                "comment_id": 99531332,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1559797548,
                "creation_date": 1559797548,
                "answer_id": 56471159,
                "question_id": 56468234,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The whole point of asynchronous APIs is that you can&#39;t write\r\n\r\n    data = getResultsAsynchronously();\r\n    doStuffWith(data);\r\n    ...\r\n\r\n(Unless you use `await`, which is slightly magical.)\r\n\r\nInstead, traditional asynchronous APIs take a function to call when the result is ready:\r\n\r\n    getResultsAsynchronously(function (data) {\r\n        doStuffWith(data);\r\n        ...\r\n    });\r\n\r\nI.e. all the code that follows the original function call in the synchronous version is instead put into a callback function and passed into `getResultsAsynchronously`.\r\n\r\nPromises still follow this general pattern, but let you decouple starting the asynchronous operation itself from deciding how to handle the result. That is, you can start an asynchronous operation first and register a callback that handles the results later, in a second step:\r\n\r\n    promise = getResultsAsynchronously();\r\n    // and later:\r\n    promise.then(function (data) {\r\n        doStuffWith(data);\r\n        ...\r\n    });\r\n\r\nHowever, you don&#39;t have to separate the two steps if you don&#39;t want to:\r\n\r\n    getResultsAsynchronously().then(function (data) {\r\n        doStuffWith(data);\r\n        ...\r\n    });\r\n\r\n`.then` also returns a promise, to which you can attach further callbacks by calling `.then` or `.catch`.\r\n\r\nIn your code,\r\n\r\n    data = jq.run(filter, jsonPath).then(...).catch(...)\r\n\r\n`data` is just another promise, but one without any useful return value inside (because your `then` and `catch` callbacks don&#39;t return any value).\r\n\r\nTo fix your logic, it should look like this:\r\n\r\n    jq.run(filter, jsonPath).then((data) =&gt; {\r\n        fs.appendFile(&#39;./jqTest.txt&#39;, data + &quot;\\r\\n&quot;, (err) =&gt; {\r\n            if (err) throw err;\r\n            console.log(&quot;complete!&quot;)\r\n        });\r\n    }).catch((err) =&gt; {\r\n        console.error(err)\r\n    });\r\n\r\nTo recap: Asynchronous results are only available inside callback functions. You can&#39;t use the return value like with a synchronous operation.\r\n\r\nThat said, `async` / `await` let you convert asynchronous code into synchronous code (or at least something that looks synchronous). However, this trick only works &quot;on the inside&quot;: The external interface is still asynchronous, you can just write more normal looking code internally.\r\n\r\nFor example:\r\n\r\n    // await is only available inside async functions, so let&#39;s define one:\r\n    (async function () {\r\n    \r\n        // magic happens here:\r\n        let data = await jq.run(filter, jsonPath);\r\n    \r\n        fs.appendFile(&#39;./jqTest.txt&#39;, data + &quot;\\r\\n&quot;, (err) =&gt; {\r\n            if (err) throw err;\r\n            console.log(&quot;complete!&quot;)\r\n        });\r\n    \r\n    })();  // ... and invoke it immediately\r\n\r\nInternally, JavaScript rewrites\r\n\r\n    x = await f();\r\n    doStuffWith(x);\r\n    ...\r\n\r\ninto something that looks like\r\n\r\n    return f().then((x) =&gt; {\r\n        doStuffWith(x);\r\n        ...\r\n    });\r\n\r\ni.e. `await` lets you pull the contents of a callback function out into straight line code. Ultimately the whole `async` function still returns a promise, however.",
                "title": "Is there a synchronous function for jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1563962149,
        "creation_date": 1559769971,
        "last_edit_date": 1563962149,
        "question_id": 56468234,
        "body_markdown": "`jq.run(&#39;.&#39;, &#39;/path/to/file.json&#39;).then(console.log)` is asynchronous so when I try to use it I get this: `Promise { &lt;pending&gt; }` AND THEN I get the result, but it&#39;s too late... so how can I fix this ?\r\nI try to wait with `await` but I don&#39;t know where I can put this keyword. So here&#39;s my code:\r\n\r\n    const jq = require(&#39;node-jq&#39;)\r\n    const filter = &#39;[.root[].A[].AT]&#39;\r\n    const jsonPath = &#39;./simple.json&#39;\r\n     \r\n     data = jq.run(filter, jsonPath).then((output) =&gt; {\r\n        console.log(output)\r\n      }).catch((err) =&gt; {\r\n        console.error(err)\r\n      })\r\n    \r\n    fs.appendFile(&#39;./jqTest.txt&#39;, data + &quot;\\r\\n&quot;, function (err) {\r\n      if (err) throw err;\r\n      console.log(&quot;complete!&quot;)\r\n    });",
        "link": "https://stackoverflow.com/questions/56468234/is-there-a-synchronous-function-for-jq",
        "title": "Is there a synchronous function for jq?"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq",
            "reformatting"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1559792934,
                "creation_date": 1559792934,
                "answer_id": 56470658,
                "question_id": 56468581,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the nature of the input JSON has only been given by example, let&#39;s begin by defining a filter for linearizing `.NR`:\r\n\r\n    # Produce a stream of arrays\r\n    def linearize:\r\n      if type == &quot;array&quot; then .[] | linearize\r\n      else [ .N1, .N2, .SNR.NR_i, .SNR.NR_f]\r\n      end;\r\n\r\n\r\nThe relevant data can now be extracted while preserving the top-level groups as follows:\r\n\r\n    .Main.List.SubList.ND.RiS.RiN.NSE14\r\n    | [to_entries[]\r\n    | [.key]\r\n      + [.value | .. | objects | select(has(&quot;NR&quot;)) | .NR | [ linearize ]] ]\r\n\r\nBecause the input JSON is not uniform, it will help to ensure uniformity by augmenting the above pipeline with the following mapping:\r\n\r\n    | map(if length &gt; 2 then [.[0], [.[1:][][]]] else . end)\r\n\r\nThis produces a single JSON array structured like this:\r\n\r\n    [[&quot;MNRs&quot;,[[&quot;393&quot;,&quot;720&quot;,&quot;203&quot;,&quot;49994&quot;]],[[&quot;687&quot;,&quot;345&quot;,&quot;55005&quot;,&quot;1229996&quot;]]],\r\n     [&quot;GNRs&quot;, ...\r\n\r\nTo obtain the first data row of the table from this intermediate result, it will be worthwhile defining a function that will provide the necessary padding:\r\n\r\n    def row($i; $padding):\r\n      . as $in\r\n      | [range(0;$padding) | null] as $nulls\r\n      | reduce range(0; length) as $ix \r\n          ([]; . + ($in[$ix][1][$i] // $nulls));\r\n\r\n \r\nNow the first data row can be obtained by row(0;4), the second by row(1;4), etc.\r\n\r\nThe total number of data rows would be given by filtering the intermediate data structure through `map(.[1] | length) | max`; thus, the data rows can be obtained by tacking the following onto the previous pipeline:\r\n\r\n    | (map(.[1] | length) | max) as $rows\r\n    | range(0; $rows) as $r\r\n    | row($r; 4)\r\n    | @tsv\r\n\r\nUsing the -r command-line option and the given sample, the output would be:\r\n\r\n    393\t720\t203\t49994\t649\t111\t55400\t877\t748\t5624\t8746\t7773\r\n    687\t345\t55005\t1229996\t\t\t\t\t124\t54\t8847\t5526\r\n\r\nAdding the headers is left as an exercise :-)\r\n",
                "title": "How to tabulate nested JSON file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1559794518,
        "creation_date": 1559771925,
        "last_edit_date": 1559794518,
        "question_id": 56468581,
        "body_markdown": "I have the following JSON file that I would like to parse with jq tool that someone suggested me but I&#39;m new with it. There are 3 parents nodes \r\nwith the same children names. The parent nodes are MNRs, GNRs and MSNRs and each of them has children named N1, N2, NR_i, NR_f.\r\n\r\n\t{\r\n\t  &quot;Main&quot;: {\r\n\t\t&quot;Document&quot;: &quot;Doc.1&quot;,\r\n\t\t&quot;Cini&quot;: &quot;DDFR&quot;,\r\n\t\t&quot;List&quot;: {\r\n\t\t  &quot;SubList&quot;: {\r\n\t\t\t&quot;CdTa&quot;: &quot;ABC&quot;,\r\n\t\t\t&quot;NN&quot;: &quot;XYZ&quot;,\r\n\t\t\t&quot;ND&quot;: {\r\n\t\t\t  &quot;RiS&quot;: {\r\n\t\t\t\t&quot;RiN&quot;: {\r\n\t\t\t\t  &quot;NSE14&quot;: {\r\n\t\t\t\t\t&quot;MNRs&quot;: {\r\n\t\t\t\t\t  &quot;MRD&quot;: [\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t  &quot;NR&quot;: {\r\n\t\t\t\t\t\t\t&quot;N1&quot;: &quot;393&quot;,\r\n\t\t\t\t\t\t\t&quot;N2&quot;: &quot;720&quot;,\r\n\t\t\t\t\t\t\t&quot;SNR&quot;: {\r\n\t\t\t\t\t\t\t  &quot;NR_i&quot;: &quot;203&quot;,\r\n\t\t\t\t\t\t\t  &quot;NR_f&quot;: &quot;49994&quot;\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t  }\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t  &quot;NR&quot;: {\r\n\t\t\t\t\t\t\t&quot;N1&quot;: &quot;687&quot;,\r\n\t\t\t\t\t\t\t&quot;N2&quot;: &quot;345&quot;,\r\n\t\t\t\t\t\t\t&quot;SNR&quot;: {\r\n\t\t\t\t\t\t\t  &quot;NR_i&quot;: &quot;55005&quot;,\r\n\t\t\t\t\t\t\t  &quot;NR_f&quot;: &quot;1229996&quot;\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t  }\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t  ]\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;GNRs&quot;: {\r\n\t\t\t\t\t  &quot;RD&quot;: {\r\n\t\t\t\t\t\t&quot;NR&quot;: {\r\n\t\t\t\t\t\t  &quot;N1&quot;: &quot;649&quot;,\r\n\t\t\t\t\t\t  &quot;N2&quot;: &quot;111&quot;,\r\n\t\t\t\t\t\t  &quot;SNR&quot;: {\r\n\t\t\t\t\t\t\t&quot;NR_i&quot;: &quot;55400&quot;,\r\n\t\t\t\t\t\t\t&quot;NR_f&quot;: &quot;877&quot;\r\n\t\t\t\t\t\t  }\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t  }\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;MSNRs&quot;: {\r\n\t\t\t\t\t  &quot;NR&quot;: [\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t  &quot;N1&quot;: &quot;748&quot;,\r\n\t\t\t\t\t\t  &quot;N2&quot;: &quot;5624&quot;,\r\n\t\t\t\t\t\t  &quot;SNR&quot;: {\r\n\t\t\t\t\t\t\t&quot;NR_i&quot;: &quot;8746&quot;,\r\n\t\t\t\t\t\t\t&quot;NR_f&quot;: &quot;7773&quot;\r\n\t\t\t\t\t\t  }\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t  &quot;N1&quot;: &quot;124&quot;,\r\n\t\t\t\t\t\t  &quot;N2&quot;: &quot;54&quot;,\r\n\t\t\t\t\t\t  &quot;SNR&quot;: {\r\n\t\t\t\t\t\t\t&quot;NR_i&quot;: &quot;8847&quot;,\r\n\t\t\t\t\t\t\t&quot;NR_f&quot;: &quot;5526&quot;\r\n\t\t\t\t\t\t  }\r\n\t\t\t\t\t\t}\r\n\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;NSE12&quot;: {\r\n\t\t\t\t\t&quot;MBB&quot;: &quot;990&quot;,\r\n\t\t\t\t\t&quot;MRB&quot;: &quot;123&quot;\r\n\t\t\t\t  },\r\n\t\t\t\t  &quot;MGE13&quot;: {\r\n\t\t\t\t\t&quot;TBB&quot;: &quot;849&quot;,\r\n\t\t\t\t\t&quot;TRB&quot;: &quot;113&quot;\r\n\t\t\t\t  }\r\n\t\t\t\t}\r\n\t\t\t  }\r\n\t\t\t}\r\n\t\t  }\r\n\t\t}\r\n\t  }\r\n\t}\r\n\r\nWith this code I get the following\r\n\r\n\t.Main.List.SubList.ND.RiS.RiN.NSE14.MNRs.MRD\r\n\r\n\t[\r\n\t  {\r\n\t\t&quot;NR&quot;: {\r\n\t\t  &quot;N1&quot;: &quot;393&quot;,\r\n\t\t  &quot;N2&quot;: &quot;720&quot;,\r\n\t\t  &quot;SNR&quot;: {\r\n\t\t\t&quot;NR_i&quot;: &quot;203&quot;,\r\n\t\t\t&quot;NR_f&quot;: &quot;49994&quot;\r\n\t\t  }\r\n\t\t}\r\n\t  },\r\n\t  {\r\n\t\t&quot;NR&quot;: {\r\n\t\t  &quot;N1&quot;: &quot;687&quot;,\r\n\t\t  &quot;N2&quot;: &quot;345&quot;,\r\n\t\t  &quot;SNR&quot;: {\r\n\t\t\t&quot;NR_i&quot;: &quot;55005&quot;,\r\n\t\t\t&quot;NR_f&quot;: &quot;1229996&quot;\r\n\t\t  }\r\n\t\t}\r\n\t  }\r\n\t]\r\n\t\r\nAnd with these commands I get the a columns of individual values for each children and others null.\r\n\r\n\t.. | .N1?\r\n\t.. | .N2?\r\n\t.. | .NR_i?\r\n\t.. | .NR_f?\r\n\r\nI&#39;m far from my desired output since I&#39;d like to extract the children for each parent and tabulate in the\r\nform below.\r\n\t\r\n\t+------+------+-------+---------+-----+-----+-------+------+-----+------+------+------+\r\n\t|             MNRs              |          GNRs            |           MSNRs          |\r\n\t+------+------+-------+---------+-----+-----+-------+------+-----+------+------+------+\r\n\t| N1   | N2   | NR_i  | NR_f    | N1  | N2  | NR_i  | NR_f | N1  | N2   | NR_i | NR_f |\r\n\t+------+------+-------+---------+-----+-----+-------+------+-----+------+------+------+\r\n\t| 393  | 720  | 203   | 49994   | 649 | 111 | 55400 | 877  | 748 | 5624 | 8746 | 7773 |\r\n\t+------+------+-------+---------+-----+-----+-------+------+-----+------+------+------+\r\n\t| 687  | 345  | 55005 | 1229996 |     |     |       |      | 124 | 54   | 8847 | 5526 |\r\n\t+------+------+-------+---------+-----+-----+-------+------+-----+------+------+------+ \r\n\r\nMay someone help me with this. Thanks in advance.",
        "link": "https://stackoverflow.com/questions/56468581/how-to-tabulate-nested-json-file-with-jq",
        "title": "How to tabulate nested JSON file with jq"
    },
    {
        "tags": [
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1559816239,
                "last_edit_date": 1559816239,
                "creation_date": 1559815769,
                "answer_id": 56475383,
                "question_id": 56475052,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In `jq` you can always contain the results to an array using the `[..]` that put the results to an array for the subsequent functions to operate on. Your given requirement could be simply done as\r\n\r\n    jq &#39;[.[] | select(.platform | contains(&quot;Unix&quot;))] | sort_by(.version) | limit(5;.[])&#39;\r\n\r\nSee it working on [jq playground](https://jqplay.org/s/APxS1JnCmI) tested on v1.6\r\n\r\nand with added `reverse()` function, introduce an another level of array nesting. Use `reverse[]` to dump the objects alone\r\n\r\n    jq &#39;[[.[] | select(.platform | contains(&quot;Unix&quot;))] | sort_by(.version) | limit(5;.[]) ] | reverse&#39;\r\n",
                "title": "Merge multiple jq invocations to sort and limit the content of a stream of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1559816239,
        "creation_date": 1559814673,
        "last_edit_date": 1559815185,
        "question_id": 56475052,
        "body_markdown": "I have a json stream of updates for products, and I&#39;m trying to get the last X versions sorted by version (they are sorted by release date currently).\r\n\r\nIt looks like jq can&#39;t sort a stream of objects directly, `sort_by` only works on arrays, and I couldn&#39;t find a way to collect a stream into an array that doesn&#39;t involve piping the output of `jq -c` to `jq -s`.\r\n\r\nMy current solution:\r\n\r\n```bash\r\n&lt; xx \\\r\n    jq -c &#39;.[] | select(.platform | contains(&quot;Unix&quot;))&#39; \\\r\n    | jq -cs &#39;sort_by(.version) | reverse | .[]&#39; \\\r\n    | head -5 \\\r\n    | jq -C . \\\r\n    | less\r\n```\r\n\r\nI expected to be able to use \r\n```bash\r\njq &#39;.[] | select(...) | sort_by(.version) | limit(5) | reverse&#39;\r\n```\r\n\r\nbut I couldn&#39;t find a thing that `limit`s and `sort_by` doesn&#39;t work on non arrays.\r\n\r\nI am testing this on atlassian&#39;s json for releases: https://my.atlassian.com/download/feeds/archived/bamboo.json",
        "link": "https://stackoverflow.com/questions/56475052/merge-multiple-jq-invocations-to-sort-and-limit-the-content-of-a-stream-of-objec",
        "title": "Merge multiple jq invocations to sort and limit the content of a stream of objects"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1559819646,
                "last_edit_date": 1559819646,
                "creation_date": 1559817794,
                "answer_id": 56475945,
                "question_id": 56475138,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Combine `Fruits` arrays, group it by `id`, select groups with 2 elements because we want *fruits* present in both files. For each selected group; add `name` field from **first** group element to **second**, and collect results in an array.\r\n```\r\njq -n &#39;[inputs.Fruits[]]\r\n| reduce (group_by(.id)[] | select(length==2)) as $f\r\n  ([]; . + [$f[1] + ($f[0] | {name})])&#39; file1.json file2.json\r\n```\r\nNote that the order files are given on the command line is important, the file with `name`s should be given before the other.\r\n\r\n---\r\nCombining objects with same `id` and extracting a subset of fields is way much easier though:\r\n```\r\njq -n &#39;[inputs.Fruits[]]\r\n| group_by(.id)\r\n| map(select(length==2) | add | {name, id, weight})\r\n&#39; file1.json file2.json",
                "title": "jq: extract a specific key from one object to another"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1559833600,
                "creation_date": 1559833600,
                "answer_id": 56480374,
                "question_id": 56475138,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s plenty of ways this could be constructed. Here&#39;s another way:\r\n\r\n    $ jq &#39;.Fruits |= (. + input.Fruits | [group_by(.id)[] | add | {name,weight,id}])&#39; \\\r\n    file1.json file2.json\r\n    {\r\n      &quot;Fruits&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Orange&quot;,\r\n          &quot;weight&quot;: 7,\r\n          &quot;id&quot;: 28748\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Apple&quot;,\r\n          &quot;weight&quot;: 5,\r\n          &quot;id&quot;: 652090\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "jq: extract a specific key from one object to another"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1559833600,
        "creation_date": 1559814940,
        "last_edit_date": 1559817073,
        "question_id": 56475138,
        "body_markdown": "I have two JSON files.\r\n\r\nfile1.json:\r\n\r\n    {\r\n      &quot;Fruits&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Apple&quot;,\r\n        &quot;something_else&quot;: 123,\r\n        &quot;id&quot;: 652090\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Orange&quot;,\r\n        &quot;something_else&quot;: 456,\r\n        &quot;id&quot;: 28748\r\n      }\r\n    ]}\r\n\r\nfile2.json:\r\n\r\n    {\r\n      &quot;Fruits&quot;: [\r\n      {\r\n        &quot;weight&quot;: 5,\r\n        &quot;id&quot;: 652090\r\n      },\r\n      {\r\n        &quot;weight&quot;: 7,\r\n        &quot;id&quot;: 28748\r\n      }\r\n    ]}\r\n\r\nI want to combine objects from both files if they have a common key &#39;id&#39;, but to extract only &#39;name&#39; property from file1. How do I do that using jq?\r\n\r\nThis is what I want to get:\r\n\r\n    {\r\n      &quot;Fruits&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Apple&quot;,\r\n        &quot;weight&quot;: 5,\r\n        &quot;id&quot;: 652090\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Orange&quot;,\r\n        &quot;weight&quot;: 7,\r\n        &quot;id&quot;: 28748\r\n      },\r\n    ]}",
        "link": "https://stackoverflow.com/questions/56475138/jq-extract-a-specific-key-from-one-object-to-another",
        "title": "jq: extract a specific key from one object to another"
    },
    {
        "tags": [
            "arrays",
            "json",
            "amazon-dynamodb",
            "transformation",
            "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": 1559836404,
                "post_id": 56480943,
                "comment_id": 99552684,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1559835871,
                "creation_date": 1559835871,
                "answer_id": 56481023,
                "question_id": 56480943,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following :\r\n\r\n    .[] | { Environment: .Environment.S, Severity: .Severity.S, Category: (.Category.L | map(.S)) }\r\n\r\nOutput :\r\n\r\n    {\r\n      &quot;Environment&quot;: &quot;NonProd&quot;,\r\n      &quot;Severity&quot;: &quot;Critical&quot;,\r\n      &quot;Category&quot;: [\r\n        &quot;Data&quot;,\r\n        &quot;EMR&quot;\r\n      ]\r\n    }\r\n\r\n[Try it here](https://jqplay.org/s/xo3bzj0rOz) !\r\n",
                "title": "Using jq to convert list of map into an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1559861540,
        "creation_date": 1559835574,
        "last_edit_date": 1559861540,
        "question_id": 56480943,
        "body_markdown": "I am struggling to get formatted output from an aws dynamodb scan command. \r\nAn item in the dynamodb table looks like below:\r\n\r\n    {\r\n       &quot;labels&quot;: {\r\n        &quot;Category&quot;: [\r\n          &quot;Data&quot;,\r\n          &quot;EMR&quot;\r\n        ],\r\n       &quot;Environment&quot;: &quot;NonProd&quot;,\r\n       &quot;Severity&quot;: &quot;Critical&quot;\r\n       },\r\n      &quot;subscriber_id&quot;: &quot;blah@blah.com&quot;,\r\n      &quot;subscriber_type&quot;: &quot;email&quot;\r\n    }\r\n\r\nWhen I run the query: \r\n\r\n    aws dynamodb scan --table-name dummy_table --region region_name -- \r\n    profile default --query &quot;Items[?subscriber_id.S == \r\n    &#39;blah@blah.com&#39;].labels.M[]&quot;\r\n\r\n I get the output as below:\r\n\r\n    [\r\n    {\r\n        &quot;Environment&quot;: {\r\n            &quot;S&quot;: &quot;NonProd&quot;\r\n        },\r\n        &quot;Severity&quot;: {\r\n            &quot;S&quot;: &quot;Critical&quot;\r\n        },\r\n           &quot;Category&quot;: {\r\n                &quot;L&quot;: [\r\n                    {\r\n                       &quot;S&quot;: &quot;Data&quot;\r\n                    },\r\n                   {\r\n                        &quot;S&quot;: &quot;EMR&quot;\r\n                   }\r\n                ]\r\n           }\r\n        }\r\n    ]\r\n\r\nDesired output is:\r\n\r\n        {\r\n            &quot;Category&quot;: [\r\n            &quot;Data&quot;,\r\n            &quot;EMR&quot;\r\n            ],\r\n           &quot;Environment&quot;: &quot;NonProd&quot;,\r\n           &quot;Severity&quot;: &quot;Critical&quot;\r\n        }\r\n\r\nTo achieve the desired output, I tried to manipulate using jq.\r\n\r\nUpdated query: \r\n\r\n        aws dynamodb scan --table-name dummy_table --region \r\n     region_name -- \r\n       profile default --query &quot;Items[?subscriber_id.S == \r\n       &#39;blah@blah.com&#39;].labels.M[]&quot; |\r\n       jq -r &#39;.[] \r\n         | to_entries[] \r\n         | [{key:.key, value:.value[]}] \r\n         | from_entries&#39; | jq -s add\r\n\r\nOutput is:\r\n\r\n    {\r\n      &quot;Environment&quot;: &quot;NonProd&quot;,\r\n      &quot;Severity&quot;: &quot;Critical&quot;,\r\n      &quot;Category&quot;: [\r\n        {\r\n          &quot;S&quot;: &quot;Data&quot;\r\n        },\r\n        {\r\n          &quot;S&quot;: &quot;EMR&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nAs you see it&#39;s close, but it&#39;s not processing the Category list. Any help with getting the desired output is appreciated.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/56480943/using-jq-to-convert-list-of-map-into-an-array",
        "title": "Using jq to convert list of map into an array"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11199572,
                    "reputation": 2786,
                    "user_id": 8217112,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-FB7l5icjoDo/AAAAAAAAAAI/AAAAAAAACPA/jgQiuzBBY3c/s256-rj/photo.jpg",
                    "display_name": "noah",
                    "link": "https://stackoverflow.com/users/8217112/noah"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1559865263,
                "post_id": 56486272,
                "comment_id": 99562709,
                "content_license": "CC BY-SA 4.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": 2,
                "creation_date": 1559866463,
                "post_id": 56486272,
                "comment_id": 99562875,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1266843,
                    "reputation": 100730,
                    "user_id": 1223975,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://i.sstatic.net/lpyoU.jpg?s=256",
                    "display_name": "Alexander Mills",
                    "link": "https://stackoverflow.com/users/1223975/alexander-mills"
                },
                "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": 1559866958,
                "post_id": 56486272,
                "comment_id": 99562959,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 35,
                "is_accepted": false,
                "score": 35,
                "last_activity_date": 1559866813,
                "last_edit_date": 1559866813,
                "creation_date": 1559866355,
                "answer_id": 56486525,
                "question_id": 56486272,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `@tsv` to generated tab-separated values as output:\r\n\r\n```\r\njq -r &#39;[.user, .cmd] | @tsv&#39; &lt;yourfile\r\n```\r\n\r\n...emits, given your input file:\r\n\r\n```\r\nalex\techo &#39;123&#39;\r\njohn\techo &#39;456&#39;\r\nalex\techo &#39;789&#39;\r\n```\r\n\r\n---\r\n\r\n...though if you&#39;re filtering for only your user account, you can just print `cmd` directly, since the user value is known:\r\n\r\n```\r\njq -r &#39;select(.user == &quot;alex&quot;) | .cmd&#39; \r\n```",
                "title": "How to concat multiple fields to same line with jq"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1559873006,
                "last_edit_date": 1559873006,
                "creation_date": 1559866396,
                "answer_id": 56486533,
                "question_id": 56486272,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When you write `.user .cmd` you are asking for the &quot;cmd&quot; field of the JSON object at `.user`. To obtain both the .user and .cmd values, you could use the &quot;,&quot; operator:\r\n\r\n    .user, .cmd\r\n\r\nThe above, however, will produce two lines.  There are many options for emitting multiple values on a single line.  You might wish to consider using string interpolation; or wrapping the values in square brackets and then using one of `@csv`, `@tsv`, or `join/1`; or using the -j command-line option.\r\n\r\nThis is all pretty clearly explained in the standard jq documentation (see e.g. https://stackoverflow.com/tags/jq/info), as is the use of `select` for making a selection.",
                "title": "How to concat multiple fields to same line with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 16,
        "last_activity_date": 1559873006,
        "creation_date": 1559863855,
        "question_id": 56486272,
        "body_markdown": "If I run:\r\n\r\n    cat &lt;file&gt; | jq \r\n\r\nI get:\r\n\r\n    {\r\n      &quot;user&quot;: &quot;alex&quot;,\r\n      &quot;num&quot;: &quot;486&quot;,\r\n      &quot;time&quot;: &quot;Thu Jun  6 16:26:06 PDT 2019&quot;,\r\n      &quot;pwd&quot;: &quot;/Users/alex/codes/ores/prompt-command&quot;,\r\n      &quot;pid&quot;: 11047,\r\n      &quot;exit_code&quot;: 0,\r\n      &quot;cmd&quot;: &quot;echo &#39;123&#39;&quot;\r\n    }\r\n    {\r\n      &quot;user&quot;: &quot;john&quot;,\r\n      &quot;num&quot;: &quot;487&quot;,\r\n      &quot;time&quot;: &quot;Thu Jun  6 16:26:24 PDT 2019&quot;,\r\n      &quot;pwd&quot;: &quot;/Users/alex/codes/ores/prompt-command&quot;,\r\n      &quot;pid&quot;: 11108,\r\n      &quot;exit_code&quot;: 5,\r\n      &quot;cmd&quot;: &quot;echo &#39;456&#39;&quot;\r\n    }\r\n    {\r\n      &quot;user&quot;: &quot;alex&quot;,\r\n      &quot;num&quot;: &quot;488&quot;,\r\n      &quot;time&quot;: &quot;Thu Jun  6 16:26:59 PDT 2019&quot;,\r\n      &quot;pwd&quot;: &quot;/Users/alex/codes/ores/prompt-command&quot;,\r\n      &quot;pid&quot;: 11141,\r\n      &quot;exit_code&quot;: 5,\r\n      &quot;cmd&quot;: &quot;echo &#39;789&#39;&quot;\r\n    }\r\n\r\nbut instead of all those fields, I just want some output like:\r\n\r\n\r\n    alex echo &#39;123&#39;\r\n    alex echo &#39;789&#39;\r\n\r\n\r\nso I tried this:\r\n\r\n\r\n    cat &lt;file&gt; | jq -r &#39;.user .cmd&#39;\r\n\r\nbut that didn&#39;t work I got this error:\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:63): Cannot index string with string &quot;cmd&quot;\r\n\r\n\r\nI also want to filter it so I only see my commands, something like:\r\n\r\n    cat &lt;file&gt; | jq -r &#39;.user=alex .cmd&#39;\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56486272/how-to-concat-multiple-fields-to-same-line-with-jq",
        "title": "How to concat multiple fields to same line 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": 1559915664,
                "post_id": 56493988,
                "comment_id": 99580259,
                "content_license": "CC BY-SA 4.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": 1559917740,
                "post_id": 56493988,
                "comment_id": 99581402,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1559918702,
                "last_edit_date": 1559918702,
                "creation_date": 1559912466,
                "answer_id": 56494884,
                "question_id": 56493988,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The first argument to `sub` (**requires jq 1.5**) can be any PCRE.\r\n\r\n    .[].target |= sub(&quot;(?&lt;=com).*$&quot;; &quot;&quot;)\r\n",
                "title": "altering json value to be substring"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1559917311,
                "last_edit_date": 1559917311,
                "creation_date": 1559915465,
                "answer_id": 56495637,
                "question_id": 56493988,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `capture` is often easier than using `match`. In your case, the following would be sufficient to modify the &quot;target&quot; values assuming your input is an array of objects along the lines suggested by the snippet:\r\n\r\n    map(.target |= (capture(&quot;https?(?&lt;s&gt;://[^/]*)&quot;) | &quot;https&quot; + .s))\r\n\r\nEquivalently:\r\n\r\n    map(.target |= sub( &quot;https?(?&lt;s&gt;://[^/]*).*&quot;; &quot;https&quot; + .s) )\r\n\r\n\r\n",
                "title": "altering json value to be substring"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1560150543,
        "creation_date": 1559909099,
        "last_edit_date": 1559915502,
        "question_id": 56493988,
        "body_markdown": "I have a value in a json result set I would like to alter to be a substring value of the original\r\n\r\n\r\n    {\r\n       &quot;label&quot;: &quot;web page check&quot;,\r\n      &quot;target&quot;: &quot;http://www.example.com/random/page&quot;\r\n    },\r\n    {\r\n       &quot;label&quot;: &quot;web page check1 &quot;,\r\n      &quot;target&quot;: &quot;http://www.example1.com/random/page&quot;\r\n    }, \r\n\r\nwhat I would like to do is return it as\r\n\r\n    {\r\n      &quot;label&quot;: &quot;web page check&quot;,\r\n      &quot;target&quot;: &quot;https://www.example.com&quot;\r\n    },\r\n    {\r\n       &quot;label&quot;: &quot;web page check&quot;,\r\n      &quot;target&quot;: &quot;https://www.example1.com&quot;\r\n    }\r\n\r\nI have tried \r\n\r\n    jq  &#39;.[].target=(match(^https:\\/\\/[0-9a-zA-z.]*|^http:\\/\\/[0-9a-zA-z.]*).string)&#39;\r\n    \r\n    jq -c &#39;.[] | {label: .label, target: (.target |=match(^https:\\/\\/[0-9a-zA-z.]*|^http:\\/\\/[0-9a-zA-z.]*).string})&#39;\r\n",
        "link": "https://stackoverflow.com/questions/56493988/altering-json-value-to-be-substring",
        "title": "altering json value to be substring"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1560053833,
                "last_edit_date": 1560053833,
                "creation_date": 1559944132,
                "answer_id": 56501578,
                "question_id": 56500760,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following solution has the advantage of not requiring any shell-specific functionality and only requiring a single invocation of jq. It assumes you want to be able to handle arbitrarily many files, as determined by `order.json`.  Amongst other assumptions is that in the pwd, we can use the pattern `[A-Z]*.json` to select the relevant &quot;documents&quot;.\r\n\r\n    jq -n --argfile order order.json &#39;\r\n      INDEX(inputs.document;  .product) as $dict\r\n      | reduce $order.order[] as $product ([]; . + [$dict[$product]])\r\n      | {document: .}\r\n    &#39; [A-Z]*.json\r\n     \r\n\r\n### def INDEX\r\nIf your jq does not have `INDEX/2`, then it might be a good time to upgrade; alternatively, you could simply add (prepend) its def:\r\n\r\n    def INDEX(stream; idx_expr):\r\n      reduce stream as $row ({}; .[$row|idx_expr|tostring] = $row);",
                "title": "How to merge multiple Json files in folder in certain order"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1560022788,
                "last_edit_date": 1560022788,
                "creation_date": 1559957543,
                "answer_id": 56502729,
                "question_id": 56500760,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that uses order.json to determine which files are to be read by jq:\r\n\r\n    jq -n &#39;{documents: [inputs.document]}&#39; $(jq -r &#39;.order[] + &quot;.json&quot;&#39; order.json)\r\n\r\nThe approach exemplified immediately above has many advantages, but the above line makes various assumptions that might not be warranted.  For example, it assumes there are no spaces in any of the file names. \r\n\r\n## Robust handling of file names\r\n\r\nThe following assumes bash-ful functionality:\r\n\r\n    mapfile -t args &lt; &lt;(jq -r &#39;.order[] + &quot;.json&quot;&#39; order.json)\r\n    jq -n &#39;{documents: [inputs.document]}&#39; &quot;${args[@]}&quot;\r\n\r\nIf your bash does not have `mapfile`, you could set the bash variable as follows:\r\n\r\n    args=()\r\n    while read -r f; do \r\n      args+=(&quot;$f&quot;)\r\n    done &lt; &lt;(jq -r &#39;.order[] + &quot;.json&quot;&#39; order.json)\r\n",
                "title": "How to merge multiple Json files in folder in certain order"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1560053833,
        "creation_date": 1559938686,
        "question_id": 56500760,
        "body_markdown": "I have several JSON files in a folder and I want to combine them in a single one following certain order given in `order.json`\r\n\r\nI&#180;ve tested the code below that merges all the files but in alphabetical order based on file name.\r\n\r\n\tjq -s . *.json &gt; Merged.json\r\n\t\r\nThis is the file **Shoes.json**\r\n\r\n\t{ &quot;document&quot;: { &quot;product&quot;: &quot;Shoes&quot;, &quot;info&quot;: [ { &quot;day&quot;: &quot;1&quot;, &quot;month&quot;: &quot;1&quot;, &quot;entry&quot;: &quot;Some text about Shoes for day 1 and month 1&quot;, &quot;code&quot;: &quot;AJKD&quot; }, { &quot;day&quot;: &quot;2&quot;, &quot;month&quot;: &quot;1&quot;, &quot;entry&quot;: &quot;Some text about Shoes for day 2 and month 1&quot;, &quot;code&quot;: &quot;KKGIR&quot; } ] } }\r\n\r\nThis is the file **Watches.json**\r\n\r\n\t{ &quot;document&quot;: {\t&quot;product&quot;: &quot;Watches&quot;,\t&quot;info&quot;: [ {\t&quot;day&quot;: &quot;2&quot;,\t&quot;month&quot;: &quot;3&quot;,\t&quot;entry&quot;: &quot;Some text about Watches for day 2 and month 3&quot;,\t&quot;code&quot;: &quot;PEWQ&quot; }\t] } \t}\r\n\r\nThis is the file **Accesories.json**\r\n\r\n\t{ &quot;document&quot;: {\t&quot;product&quot;: &quot;Accesories&quot;,\t&quot;info&quot;: [ {\t&quot;day&quot;: &quot;7&quot;,\t&quot;month&quot;: &quot;2&quot;,\t&quot;entry&quot;: &quot;Some text about Accesories for day 7 and month 2&quot;,\t&quot;code&quot;: &quot;UYAAC&quot; }\t] } \t}\r\n\r\nThis is the file that gives the order I want to get in output **order.json**\r\n\r\n\t{  \r\n\t   &quot;order&quot;:{  \r\n\t\t  &quot;product 1&quot;:&quot;Watches&quot;,\r\n\t\t  &quot;product 2&quot;:&quot;Accesories&quot;,\r\n\t\t  &quot;product 3&quot;:&quot;Shoes&quot;\r\n\t   }\r\n\t}\r\n\t\r\nAnd the output file I&#180;d like to get would be like this **Merged.json**:\r\n\r\n\t{  \r\n\t   &quot;document&quot;:[  \r\n\t\t  {  \r\n\t\t\t &quot;product&quot;:&quot;Watches&quot;,\r\n\t\t\t &quot;info&quot;:[  \r\n\t\t\t\t{  \r\n\t\t\t\t   &quot;day&quot;:&quot;2&quot;,\r\n\t\t\t\t   &quot;month&quot;:&quot;3&quot;,\r\n\t\t\t\t   &quot;entry&quot;:&quot;Some text about Watches for day 2 and month 3&quot;,\r\n\t\t\t\t   &quot;code&quot;:&quot;PEWQ&quot;\r\n\t\t\t\t}\r\n\t\t\t ]\r\n\t\t  },\r\n\t\t  {  \r\n\t\t\t &quot;product&quot;:&quot;Accesories&quot;,\r\n\t\t\t &quot;info&quot;:[  \r\n\t\t\t\t{  \r\n\t\t\t\t   &quot;day&quot;:&quot;7&quot;,\r\n\t\t\t\t   &quot;month&quot;:&quot;2&quot;,\r\n\t\t\t\t   &quot;entry&quot;:&quot;Some text about Accesories for day 7 and month 2&quot;,\r\n\t\t\t\t   &quot;code&quot;:&quot;UYAAC&quot;\r\n\t\t\t\t}\r\n\t\t\t ]\r\n\t\t  },\r\n\t\t  {  \r\n\t\t\t &quot;product&quot;:&quot;Shoes&quot;,\r\n\t\t\t &quot;info&quot;:[  \r\n\t\t\t\t{  \r\n\t\t\t\t   &quot;day&quot;:&quot;1&quot;,\r\n\t\t\t\t   &quot;month&quot;:&quot;1&quot;,\r\n\t\t\t\t   &quot;entry&quot;:&quot;Some text about Shoes for day 1 and month 1&quot;,\r\n\t\t\t\t   &quot;code&quot;:&quot;AJKD&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{  \r\n\t\t\t\t   &quot;day&quot;:&quot;2&quot;,\r\n\t\t\t\t   &quot;month&quot;:&quot;1&quot;,\r\n\t\t\t\t   &quot;entry&quot;:&quot;Some text about Shoes for day 2 and month 1&quot;,\r\n\t\t\t\t   &quot;code&quot;:&quot;KKGIR&quot;\r\n\t\t\t\t}\r\n\t\t\t ]\r\n\t\t  }\r\n\t   ]\r\n\t}\r\n\t\r\nMaybe someone could help me with this case.\r\n\r\nAny help would be very appreciated.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56500760/how-to-merge-multiple-json-files-in-folder-in-certain-order",
        "title": "How to merge multiple Json files in folder in certain order"
    },
    {
        "tags": [
            "node.js",
            "json",
            "jq",
            "stringify",
            "xml2js"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1560060522,
                "creation_date": 1560060522,
                "answer_id": 56512385,
                "question_id": 56512329,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Never use double quotes for quoting an argument if there is nothing in it that you want the shell to expand.\r\n```\r\n$ jq &#39;.NewDataSet.Table[]\r\n| select(.SegmentType[0] != &quot;2&quot; and .IsActive[0] == &quot;true&quot;)\r\n| (.SegmentID, .SegmentName, .BeginningDcuID, .EndingDcuID, .SegmentLength)[0]&#39; file\r\n&quot;3051&quot;\r\n&quot;OR212 at SE 242nd Ave to OR212 at SE Foster Rd&quot;\r\n&quot;584&quot;\r\nnull\r\n&quot;100&quot;\r\n```",
                "title": "Parse result of XML -&gt; XML2JS -&gt;JSON.stringify using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1666590448,
        "creation_date": 1560059803,
        "last_edit_date": 1666590448,
        "question_id": 56512329,
        "body_markdown": "I have a file created by doing an XHR fetch of XML and parsing it through the node module `xlm2js` and then `JSON.stringify`.  It has about 700 *segments* of two basic types. This is an edited version of the file with one *segment* of each type:\r\n```\r\n{\r\n  &quot;NewDataSet&quot;: {\r\n    &quot;Table&quot;: [\r\n      {\r\n        &quot;SegmentID&quot;: [\r\n          &quot;2342&quot;\r\n        ],\r\n        &quot;StationID&quot;: [\r\n          &quot;005es00045:_MN_Stn&quot;\r\n        ],\r\n        &quot;SegmentName&quot;: [\r\n          &quot;I-5 NB MP0.45 @ SR-14&quot;\r\n        ],\r\n        &quot;SegmentType&quot;: [\r\n          &quot;2&quot;\r\n        ],\r\n        &quot;SegmentLength&quot;: [\r\n          &quot;1135&quot;\r\n        ],\r\n        &quot;MinimumLanesReporting&quot;: [\r\n          &quot;0.5&quot;\r\n        ],\r\n        &quot;CalculationThreshold&quot;: [\r\n          &quot;30&quot;\r\n        ],\r\n        &quot;CalculationPeriod&quot;: [\r\n          &quot;2&quot;\r\n        ],\r\n        &quot;MinimumSamples&quot;: [\r\n          &quot;3&quot;\r\n        ],\r\n        &quot;SegmentMaximumFilter&quot;: [\r\n          &quot;774&quot;\r\n        ],\r\n        &quot;SegmentMinimumFilter&quot;: [\r\n          &quot;12&quot;\r\n        ],\r\n        &quot;StandardDeviationSamples&quot;: [\r\n          &quot;15&quot;\r\n        ],\r\n        &quot;StandardDeviationMultiplier&quot;: [\r\n          &quot;1.96&quot;\r\n        ],\r\n        &quot;UseStandardDeviationFilter&quot;: [\r\n          &quot;false&quot;\r\n        ],\r\n        &quot;IsActive&quot;: [\r\n          &quot;true&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;SegmentID&quot;: [\r\n          &quot;3051&quot;\r\n        ],\r\n        &quot;BeginningDcuID&quot;: [\r\n          &quot;584&quot;\r\n        ],\r\n        &quot;EndDcuID&quot;: [\r\n          &quot;589&quot;\r\n        ],\r\n        &quot;SourceSystem&quot;: [\r\n          &quot;TravelTime&quot;\r\n        ],\r\n        &quot;SegmentName&quot;: [\r\n          &quot;OR212 at SE 242nd Ave to OR212 at SE Foster Rd&quot;\r\n        ],\r\n        &quot;SegmentType&quot;: [\r\n          &quot;1&quot;\r\n        ],\r\n        &quot;SegmentLength&quot;: [\r\n          &quot;100&quot;\r\n        ],\r\n        &quot;CalculationThreshold&quot;: [\r\n          &quot;60&quot;\r\n        ],\r\n        &quot;CalculationPeriod&quot;: [\r\n          &quot;10&quot;\r\n        ],\r\n        &quot;MinimumSamples&quot;: [\r\n          &quot;3&quot;\r\n        ],\r\n        &quot;SegmentMaximumFilter&quot;: [\r\n          &quot;3600&quot;\r\n        ],\r\n        &quot;SegmentMinimumFilter&quot;: [\r\n          &quot;50&quot;\r\n        ],\r\n        &quot;StandardDeviationSamples&quot;: [\r\n          &quot;20&quot;\r\n        ],\r\n        &quot;StandardDeviationMultiplier&quot;: [\r\n          &quot;1.96&quot;\r\n        ],\r\n        &quot;UseStandardDeviationFilter&quot;: [\r\n          &quot;true&quot;\r\n        ],\r\n        &quot;IsActive&quot;: [\r\n          &quot;true&quot;\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI need to ignore the `&quot;SegmentType&quot;:[&quot;2&quot;]` segments and extract `SegmentID`, `SegmentName`, `BeginningDcuID`, `EndingDcuID`, and `SegmentLength` from the type 1 segments where `IsActive` is `true`.\r\n\r\nI can list the file with `jq &quot;.&quot;` but any attempt at other operations with jq fail, usually with the message:\r\n&gt; &#39;jq: error: syntax error, unexpected &#39;[&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:&#39;\r\n\r\nAny suggestions for jq syntax changes or `xml2js` parameter changes to make this work would be outstandingly helpful.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56512329/parse-result-of-xml-xml2js-json-stringify-using-jq",
        "title": "Parse result of XML -&gt; XML2JS -&gt;JSON.stringify using JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1560075198,
                "last_edit_date": 1560075198,
                "creation_date": 1560066115,
                "answer_id": 56512828,
                "question_id": 56512803,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use assignment operators:\r\n```\r\n.headers += { Cookie: &quot;xyz&quot; }\r\n```\r\n```\r\n.headers.Cookie = &quot;xyz&quot;\r\n```\r\nThe latter one changes a bit when there are multiple fields to be added:\r\n```\r\n.headers |= (.Cookies = &quot;xyz&quot; | .Referer = &quot;xyz&quot;)\r\n```",
                "title": "jq - insert values into subkey"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1560075198,
        "creation_date": 1560065884,
        "last_edit_date": 1560073405,
        "question_id": 56512803,
        "body_markdown": "I have a httpie session file that looks like this:\r\n\r\n    {\r\n       &quot;headers&quot;: {\r\n          &quot;Host&quot;: &quot;34.213.0.202&quot;,\r\n          &quot;Accept&quot;: &quot;text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8&quot;,\r\n          &quot;User-Agent&quot;: &quot;Mozilla/5.0 (X11; Linux x86_64; rv:67.0) Gecko/20100101 Firefox/67.0&quot;,\r\n          &quot;Accept-Language&quot;: &quot;en-US,en;q=0.5&quot;,\r\n          &quot;Accept-Encoding&quot;: &quot;gzip, deflate&quot;,\r\n          &quot;DNT&quot;: &quot;1&quot;,\r\n          &quot;Connection&quot;: &quot;keep-alive&quot;,\r\n          &quot;Upgrade-Insecure-Requests&quot;: &quot;1&quot;,\r\n          &quot;Cache-Control&quot;: &quot;max-age=0&quot;\r\n        }\r\n    }\r\n\r\nI would like to insert an item into headers (think *&#39;.headers + {&quot;Cookie&quot;: &quot;xyz&quot;}&#39;*) but I would like the output to be the whole JSON. Using jq &#39;.headers + {&quot;Cookie&quot;: &quot;xyz&quot;}&#39; only prints out the .headers value. What I am looking to get is the whole entire JSON, but with the cookie subkey included. \r\n\r\nWhat&#39;s the way to get that?\r\n",
        "link": "https://stackoverflow.com/questions/56512803/jq-insert-values-into-subkey",
        "title": "jq - insert values into subkey"
    },
    {
        "tags": [
            "json",
            "recursion",
            "tree",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 368,
                    "reputation": 45561,
                    "user_id": 459,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/0db193fbf6f0929c49dd9704698204ff?s=256&d=identicon&r=PG",
                    "display_name": "dlamblin",
                    "link": "https://stackoverflow.com/users/459/dlamblin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1560405055,
                "post_id": 56539699,
                "comment_id": 99726249,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1560342271,
                "last_edit_date": 1560342271,
                "creation_date": 1560244252,
                "answer_id": 56540226,
                "question_id": 56539699,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The argument to `walk` in your post is incorrect.\r\n\r\nYou presumably want to update the value of `.contents`, i.e.:\r\n\r\n    walk(if type == &quot;object&quot; and has(&quot;contents&quot;)\r\n      then .contents |= (sort_by(.size)|reverse)\r\n      else . end)\r\n\r\n(In the latest (post-1.6) version of jq, you can omit the `else .` clause.)\r\n\r\n## p.s.\r\nVersion 1.8 of `tree` fixes the trailing-comma issue.\r\n\r\nIf your `tree` produces invalid JSON when using the -J option, rather than using a generic text-processing tool such as `awk`, it might be better to use a tool such as [hjson][1] to &quot;sanitize&quot; the pseudo-JSON, e.g.\r\n\r\n    tree .... | hjson -j | jq ...\r\n\r\n## p.p.s.\r\n\r\nTo understand why one gets the error when the incorrect expression is used as the argument of `walk`, let&#39;s consider the simple test case in the OP, but with an extra `debug` inserted so we can see what&#39;s going on:\r\n\r\n```\r\n\r\necho &#39;\r\n{&quot;a&quot;:0, &quot;c&quot;:[\r\n  {&quot;a&quot;:1,&quot;s&quot;:3, &quot;c&quot;:[\r\n    {&quot;a&quot;:1,&quot;s&quot;:5},\r\n    {&quot;a&quot;:2,&quot;s&quot;:6}]\r\n  },\r\n  {&quot;a&quot;:2,&quot;s&quot;:4}]\r\n}&#39; | jq -c &#39;\r\n  walk(if type == &quot;object&quot; and has(&quot;c&quot;)\r\n       then debug | .c | sort_by(.s) | reverse\r\n       else . end)&#39;\r\n\r\n```\r\n(I&#39;ve left out the `length` check as it just clutters up the code.)\r\n\r\nThis produces:\r\n\r\n```\r\n[&quot;DEBUG:&quot;,{&quot;a&quot;:1,&quot;s&quot;:3,&quot;c&quot;:[{&quot;a&quot;:1,&quot;s&quot;:5},{&quot;a&quot;:2,&quot;s&quot;:6}]}]\r\n[&quot;DEBUG:&quot;,{&quot;a&quot;:0,&quot;c&quot;:[[{&quot;a&quot;:2,&quot;s&quot;:6},{&quot;a&quot;:1,&quot;s&quot;:5}],{&quot;a&quot;:2,&quot;s&quot;:4}]}]\r\njq: error (at &lt;stdin&gt;:6): Cannot index array with string &quot;s&quot;\r\n```\r\n\r\nNow we can see the problem: the second DEBUG line shows that .c has become a bit of a jumble: the first item is an array.  This is because we have replaced .c with an array. It is for this reason that the attempt to use `sort_by(.s)` is failing.\r\n\r\nTo understand this more completely, it would be necessary to check the definition of `walk`, which is easily done: you could google `jq &quot;def walk&quot;` or go to the source: [builtin.jq][2]\r\n\r\n\r\n  [1]: http://hjson.org/\r\n  [2]: https://github.com/stedolan/jq/blob/master/src/builtin.jq",
                "title": "Does `jq`&#39;s `walk` have an issue with sorting while walking?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1560342271,
        "creation_date": 1560242412,
        "last_edit_date": 1560274864,
        "question_id": 56539699,
        "body_markdown": "I have a small `jq` use where I want to reverse sort by a tree&#39;s size. I know it&#39;s possible with `du -h` and `sort -h` etc. But I&#39;m trying it out with `tree`&#39;s json output and `jq`.\r\n\r\nIt looks like:\r\n```bash\r\n$ tree -h -pug --du -nA -J perl5 | \\\r\nawk -v RS= &#39;{ gsub(/,[[:space:]]*]/, &quot;\\n]&quot;, $0) }1&#39; | \\\r\njq &#39;\r\nwalk(if type == &quot;object&quot; and has(&quot;contents&quot;)\r\n then (.contents|sort_by(.size)|reverse)\r\n else . end)&#39;\r\njq: error (at &lt;stdin&gt;:65): Cannot index array with string &quot;size&quot;\r\n```\r\n\r\nSo to unpack this, `awk` is used because the json output of `tree` contains extra commas after the last file or directory in a directory&#39;s `contents` array.\r\nLine 65 of the input contains the `report` which looks like:\r\n```json\r\n  {&quot;type&quot;:&quot;report&quot;,&quot;size&quot;:1310049,&quot;directories&quot;:24,&quot;files&quot;:15}\r\n```\r\nIt doesn&#39;t contains `contents` so the `if` should be avoiding it.\r\n\r\nHere&#39;s some simpler test cases:\r\n```bash\r\n$ echo &#39;\r\n{&quot;a&quot;:0, &quot;c&quot;:[\r\n  {&quot;a&quot;:1, &quot;s&quot;:3},\r\n  {&quot;a&quot;:2, &quot;s&quot;:4}]}&#39; | jq -c &#39;\r\nwalk(if type == &quot;object&quot; and has(&quot;c&quot;) and (.c|length) &gt; 0\r\n then (.c|sort_by(.s)|reverse)\r\n else . end)&#39;\r\n[{&quot;a&quot;:2,&quot;s&quot;:4},{&quot;a&quot;:1,&quot;s&quot;:3}]\r\n$&#160;echo &#39;\r\n{&quot;a&quot;:0, &quot;c&quot;:[\r\n  {&quot;a&quot;:1,&quot;s&quot;:3, &quot;c&quot;:[\r\n    {&quot;a&quot;:1,&quot;s&quot;:5},\r\n    {&quot;a&quot;:2,&quot;s&quot;:6}]},\r\n  {&quot;a&quot;:2,&quot;s&quot;:4}]}&#39; | jq -c &#39;\r\nwalk(if type == &quot;object&quot; and has(&quot;c&quot;) and (.c|length) &gt; 0\r\n then (.c|sort_by(.s)|reverse)\r\n else . end)&#39;\r\njq: error (at &lt;stdin&gt;:1): Cannot index array with string &quot;s&quot;\r\n```\r\n\r\nI&#39;m not sure I understand this error message and what I&#39;m missing about `walk`.",
        "link": "https://stackoverflow.com/questions/56539699/does-jqs-walk-have-an-issue-with-sorting-while-walking",
        "title": "Does `jq`&#39;s `walk` have an issue with sorting while walking?"
    },
    {
        "tags": [
            "shell",
            "grep",
            "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": 1,
                "creation_date": 1560283782,
                "post_id": 56550933,
                "comment_id": 99683766,
                "content_license": "CC BY-SA 4.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": 1560283883,
                "post_id": 56550933,
                "comment_id": 99683809,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1560298107,
                "last_edit_date": 1560298107,
                "creation_date": 1560292908,
                "answer_id": 56552520,
                "question_id": 56550933,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have not followed the [mcve][1] guidelines, but  as @shellter pointed out, the problem description suggests you just have to use the proper (grep) regex:\r\n\r\n\r\n    grep -q &quot;${add}use.* internal us-east&quot;\r\n\r\nHowever, since you are using jq in any case, it would probably be better to perform the filtering by extending the jq filter, for example as follows:\r\n\r\n```\r\njq --arg add &quot;$add&quot; &#39;\r\n  .Subnets[0].Tags\r\n  | select(test(&quot;\\($add)use.* internal us-east&quot;))\r\n&#39; subnet.txt \r\n\r\n```\r\n\r\n\r\n  [1]: http://stackoverflow.com/help/mcve",
                "title": "Unable to print value using jq with grep"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1560298107,
        "creation_date": 1560283098,
        "last_edit_date": 1560292967,
        "question_id": 56550933,
        "body_markdown": "I&#39;m using below jq statement with grep in my code to print a value.\r\n\r\n    jq &#39;.Subnets[0].Tags&#39; subnet.txt | grep -q &quot;${add}usea1 internal us-east&quot;\r\n\r\n This works fine for some values however, few values need grep to be &quot;${add}use* internal us-east&quot;, can i use asterisk so that  all my values can be printed.\r\n\r\n\r\nI get error when i include asterisk. any suggestions?",
        "link": "https://stackoverflow.com/questions/56550933/unable-to-print-value-using-jq-with-grep",
        "title": "Unable to print value using jq with grep"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 51,
                "is_accepted": false,
                "score": 51,
                "last_activity_date": 1675334354,
                "last_edit_date": 1675334354,
                "creation_date": 1560317915,
                "answer_id": 56555296,
                "question_id": 56555155,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [alternative operator (`//`)](https://stedolan.github.io/jq/manual/#Alternativeoperator://) in this particular case.\r\n``` shell\r\n$ jq &#39;.columns.description | .required // false&#39; file\r\nfalse\r\n```\r\nFor a generally applicable approach, see [peak&#39;s answer](https://stackoverflow.com/a/56555442/10248678).",
                "title": "Get or default function in JQ?"
            },
            {
                "up_vote_count": 21,
                "is_accepted": true,
                "score": 20,
                "last_activity_date": 1671140471,
                "last_edit_date": 1671140471,
                "creation_date": 1560318755,
                "answer_id": 56555442,
                "question_id": 56555155,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; If the field &quot;required&quot; does not exist, it should return the default value false.\r\n\r\nTo implement that functionality literally, you would use `has/1` rather than `//`, e.g.:\r\n```\r\n   .columns.id\r\n   | if has(&quot;required&quot;) then .required else false end\r\n```\r\n\r\nIf the .required field is known never to be specified as `null`, then the two techniques (using `has` as above and using `// false`) are equivalent.\r\n\r\n\r\n## getOrDefault/2\r\n\r\nYou&#39;d almost surely never define such a function, but since you ask:\r\n\r\n    def getOrDefault($key; $default):\r\n      if has($key) then .[$key] else $default end;\r\n\r\n\r\n(NB: The argument separator in jq is `;`.)\r\n\r\n## Generalized getOrDefault/2\r\n```\r\n# $key can be a string or a non-empty array-path\r\ndef getOrDefault($key; $default):\r\n  if $key | type == &quot;string&quot;\r\n  then if has($key) then .[$key] else $default end\r\n  elif $key | length == 1 then getOrDefault($key[0]; $default)\r\n  else ($key|first) as $kf\r\n  | if has($kf) \r\n    then try (.[$kf] | getOrDefault($key[1:]; $default)) catch $default\r\n    else $default\r\n    end\r\n  end;\r\n```\r\n",
                "title": "Get or default function in JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 26,
        "last_activity_date": 1675334354,
        "creation_date": 1560317027,
        "last_edit_date": 1611397143,
        "question_id": 56555155,
        "body_markdown": "Assuming there is a json file:\r\n\r\n    {\r\n      &quot;columns&quot;: {\r\n        &quot;id&quot;: {\r\n          &quot;required&quot;: true,\r\n          &quot;type&quot;: &quot;integer&quot;\r\n        },\r\n        &quot;name&quot;: {\r\n          &quot;required&quot;: false,\r\n          &quot;type&quot;: &quot;string&quot;\r\n        },\r\n        &quot;description&quot;: {\r\n          &quot;type&quot;: &quot;string&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI want to use `jq` to get the value &quot;required&quot; field for each column. If the field &quot;required&quot; does not exist, it should return the default value `false`.\r\n\r\nSpecifically:\r\n\r\n    jq &#39;.columns.id | getOrDefault(&quot;required&quot;, false)&#39;  # true\r\n    jq &#39;.columns.name | getOrDefault(&quot;required&quot;, false)&#39;  # false\r\n    jq &#39;.columns.description | getOrDefault(&quot;required&quot;, false)&#39;  # false\r\n\r\nHow to implement this magic getOrDefault() function in `jq`?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56555155/get-or-default-function-in-jq",
        "title": "Get or default function in JQ?"
    },
    {
        "tags": [
            "json",
            "limit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1560350561,
                "last_edit_date": 1560350561,
                "creation_date": 1560350137,
                "answer_id": 56564720,
                "question_id": 56563972,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To select just the first, use `first`:\r\n\r\n    first(.. | objects | select(has(&quot;model&quot;)))\r\n\r\nor if minimizing keystrokes is a goal:\r\n\r\n    first(..|select(.model?))\r\n\r\nOr, if your input has more than one top-level JSON document, and you only want at most one from the bunch:\r\n\r\n    jq -n &#39;first(inputs|..|select(.model?))&#39;",
                "title": "Find first json object with given key name recursively using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1560350642,
        "creation_date": 1560347852,
        "last_edit_date": 1560350642,
        "question_id": 56563972,
        "body_markdown": "How can I find recursively first key with given name using jq?\r\n\r\nSuppose I have JSON structure:\r\n\r\n    {\r\n      &quot;firstKey&quot;: { \r\n          &quot;secondKey&quot;: {\r\n              &quot;model&quot;: {\r\n                  &quot;name&quot;: {\r\n                      ....\r\n                   } \r\n               }\r\n           }\r\n       }\r\n    }   \r\n\r\nIs there any way how to tell jq to return me first found json object with key name for example in this case &quot;model&quot;? So it returns:\r\n\r\n    &quot;model&quot;: {\r\n        &quot;name:&quot; {\r\n          ....\r\n        } \r\n    }\r\n     ",
        "link": "https://stackoverflow.com/questions/56563972/find-first-json-object-with-given-key-name-recursively-using-jq",
        "title": "Find first json object with given key name recursively using jq"
    },
    {
        "tags": [
            "json",
            "windows",
            "csv",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1560756222,
                "last_edit_date": 1560756222,
                "creation_date": 1560379981,
                "answer_id": 56571308,
                "question_id": 56569222,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The question shows a stream of JSON objects, so the following solutions assume that the input file is already a sequence as shown. These solutions can also easily be adapted to cover the case where the input file contains a huge array of objects, e.g. as discussed in the epilog.\r\n\r\n \r\n## A two-invocation solution\r\nHere&#39;s a two-pass solution using two invocations of jq.  The presentation assumes a bash-like environment, in case you have [tag:WSL]:\r\n\r\n\r\n    n=$(jq -n &#39;reduce (inputs|.labels|length) as $i (-1;\r\n      if $i &gt; . then $i else . end)&#39; stream.json)\r\n    jq -nr --argjson n $n &#39;\r\n      def fill($n): . + [range(length;$n)|null];\r\n      [range(0;$n)|&quot;labels&quot;],\r\n      (inputs | .labels | fill($n))\r\n      | @csv&#39; stream.json\r\n\r\nAssuming the input is as described, this is guaranteed to produce valid CSV. Hopefully you can adapt the above to your shell as necessary -- maybe this link will help:\r\nhttps://stackoverflow.com/questions/2323292/assign-output-of-a-program-to-a-variable-using-a-ms-batch-file\r\n\r\n## Using `input_filename` and a single invocation of jq\r\nUnfortunately, jq does not have a &quot;rewind&quot; facility, but\r\nthere is an alternative: read the file twice within a single invocation of jq. This is more cumbersome than the two-invocation solution above but avoids any difficulties associated with the latter.\r\n\r\n```\r\ncat sample.json | jq -nr &#39;\r\n\r\n  def fill($n): . + [range(length;$n)|null];\r\n  def max($x): if . &lt; $x then $x else . end;\r\n\r\n  foreach (inputs|.labels) as $in ( {n:0};\r\n    if input_filename == &quot;&lt;stdin&gt;&quot; \r\n    then .n |= max($in|length)\r\n    else .printed+=1\r\n    end;\r\n    if .printed == null then empty\r\n    else .n as $n\r\n    | (if .printed == 1 then [range(0;$n)|&quot;labels&quot;] else empty end),\r\n      ($in | fill($n))\r\n    end)\r\n  | @csv&#39;  -  sample.json\r\n```\r\n  \r\n##  Another single-invocation solution\r\nThe following solution uses a special value (here `null`) to delineate the two streams:\r\n\r\n```\r\n(cat stream.json; echo null; cat stream.json) | jq -nr &#39;\r\n  def fill($n): . + [range(length; $n) | null];\r\n  def max($x): if . &lt; $x then $x else . end;\r\n\r\n  (label $loop | foreach inputs as $in (0; \r\n     if $in == null then . else max($in|.labels|length) end;\r\n     if $in == null then ., break $loop else empty end)) as $n\r\n  | [range(0;$n)|&quot;labels&quot;],\r\n    (inputs | .labels | fill($n))\r\n  | @csv &#39;\r\n```  \r\n## Epilog\r\n\r\nA file with a top-level JSON array that is too large to fit into memory can be converted into a stream of the array&#39;s items by invoking jq with the --stream option, e.g. as follows:\r\n\r\n    jq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39;\r\n",
                "title": "JSON to CSV: variable number of columns per row"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1560380646,
                "last_edit_date": 1560380646,
                "creation_date": 1560380345,
                "answer_id": 56571356,
                "question_id": 56569222,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For such a large file, you will probably want to do this in two separate invocations, one to get the count, then another to actually output the csv. If you wanted to read the whole file into memory, you could do this in one, but we definitely don&#39;t want to do that, we&#39;ll want to stream it in where possible.\r\n\r\nThings get a little ugly when it comes to storing the result of commands to a variable, writing to a file might be simpler. But I&#39;d rather not use temp files if we don&#39;t have to.\r\n\r\n    REM assuming in a batch file\r\n    for /f &quot;usebackq delims=&quot; %%i in (`jq -n --stream &quot;reduce (inputs | .[0][1] + 1) as $l (0; if $l &gt; . then $l else . end)&quot; input.json`) do set cols=%%i\r\n    jq -rn --stream --argjson cols &quot;%cols%&quot; &quot;[range($cols)|\\&quot;labels\\&quot;],(fromstream(1|truncate_stream(inputs))|[.[],(range($cols-length)|null)])|@csv&quot; input.json\r\n\r\n&lt;hr&gt;\r\n\r\n    &gt; jq -n --stream &quot;reduce (inputs | .[0][1] + 1) as $l (0; if $l &gt; . then $l else . end)&quot; input.json\r\n\r\nFor the first invocation to get the count of columns, we&#39;re just taking advantage of the fact that the paths to the array values could be used to indicate the lengths of the arrays. We&#39;ll just want to take the max across all items.\r\n\r\n&lt;hr&gt;\r\n\r\n    &gt; jq -rn --stream --argjson cols &quot;%cols%&quot; ^\r\n    &quot;[range($cols)|\\&quot;labels\\&quot;],(fromstream(1|truncate_stream(inputs))|[.[],(range($cols-length)|null)])|@csv&quot; input.json\r\n\r\nThen to output the rest, we&#39;re just taking the `labels` array (assuming it&#39;s the only property on the objects) and padding them out with `null` up to the `$cols` count. Then output as csv.\r\n\r\n&lt;hr&gt;\r\n\r\nIf the labels are in a different, deeply nested path than what&#39;s in your example here, you&#39;ll need to select based on the appropriate paths.\r\n\r\n    set labelspath=foo.bar.labels\r\n    jq -rn --stream --argjson cols &quot;%cols%&quot; --arg labelspath &quot;%labelspath%&quot; ^\r\n    &quot;($labelspath|split(\\&quot;.\\&quot;)|[.,length]) as [$path,$depth] | [range($cols)|\\&quot;labels\\&quot;],(fromstream($depth|truncate_stream(inputs|select(.[0][:$depth] == $path)))|[.[],(range($cols-length)|null)])|@csv&quot; input.json",
                "title": "JSON to CSV: variable number of columns per row"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1560756222,
        "creation_date": 1560368046,
        "last_edit_date": 1560469444,
        "question_id": 56569222,
        "body_markdown": "I need to convert JSON to CSV where JSON has arrays of variable length, for example:\r\n\r\nJSON objects:\r\n\r\n    {&quot;labels&quot;: [&quot;label1&quot;]}\r\n    {&quot;labels&quot;: [&quot;label2&quot;, &quot;label3&quot;]}\r\n    {&quot;labels&quot;: [&quot;label1&quot;, &quot;label4&quot;, &quot;label5&quot;]}\r\n\r\n\r\nResulting CSV:\r\n\r\n    labels,labels,labels\r\n    &quot;label1&quot;,,\r\n    &quot;label2&quot;,&quot;label3&quot;,\r\n    &quot;label1&quot;,&quot;label4&quot;,&quot;label5&quot;\r\n\r\nThere are many other properties in the source JSON, this is just an exсerpt for the sake of simplicity.\r\n\r\nAlso, I need to say that the process has to work with JSON as a stream because source JSON could be very large (&gt;1GB).\r\n\r\nI wanted to use jq with two passes, the first pass would collect the maximum length of the &#39;labels&#39; array, the second pass would create CSV as the number of the resulting columns is known by this time. But jq doesn&#39;t have a concept of global variables, so I don&#39;t know where I can store the running total.\r\n\r\nI&#39;d like to be able to do that on Windows via CLI.\r\nThank you in advance.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56569222/json-to-csv-variable-number-of-columns-per-row",
        "title": "JSON to CSV: variable number of columns per row"
    },
    {
        "tags": [
            "json",
            "jq",
            "rounding",
            "libm"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1560499105,
                "creation_date": 1560499105,
                "answer_id": 56593877,
                "question_id": 56593531,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Seems like `round` is unavailable in your build. Either upgrade jq or implement `round` using `floor`:\r\n```\r\ndef round: . + 0.5 | floor;\r\n```\r\nUsage example:\r\n```\r\n$ jq -n &#39;def round: . + 0.5 | floor; 10.01 | round&#39;\r\n10\r\n```",
                "title": "jq: error: round/0 is not defined at &lt;top-level&gt;"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1673586628,
                "creation_date": 1673586628,
                "answer_id": 75105093,
                "question_id": 56593531,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "We can use the pow function along with `. + 0.5 | floor` to create our own &#39;round&#39; function that takes a value to round as input and the number of decimal places as argument.\r\n\r\n```\r\ndef round_whole:\r\n  # Basic round function, returns the closest whole number\r\n  # Usage:\r\n  # 2.6 | round_whole // 3\r\n  . + 0.5 | floor\r\n;\r\ndef round(num_dec):\r\n  # Round function, takes num_dec as argument\r\n  # Usage: 2.2362 | round(2) // 2.24\r\n  num_dec as $num_dec | \r\n  # First multiply the number by the number of decimal places we want to round to\r\n  # i.e 2.2362 becomes 223.62\r\n  . * pow(10; $num_dec) | \r\n  # Then use the round_whole function\r\n  # 223.62 becomes 224\r\n  round_whole |\r\n  # Then divide by the number of decimal places we want to round by\r\n  # 224 becomes 2.24 as expected\r\n  . / pow(10; $num_dec)\r\n;\r\n```\r\n\r\n```bash\r\njq --null-input --raw-output \\\r\n  &#39;\r\n    def round_whole:\r\n      # Basic round function, returns the closest whole number\r\n      # Usage:\r\n      # 2.6 | round_whole // 3\r\n      . + 0.5 | floor\r\n    ;\r\n    def round(num_dec):\r\n      # Round function, takes num_dec as argument\r\n      # Usage: 2.2362 | round(2) // 2.24\r\n      num_dec as $num_dec |\r\n      # First multiply the number by the number of decimal places we want to round to\r\n      # i.e 2.2362 becomes 223.62\r\n      . * pow(10; $num_dec) |\r\n      # Then use the round_whole function\r\n      # 223.62 becomes 224\r\n      round_whole |\r\n      # Then divide by the number of decimal places we want to round by\r\n      # 224 becomes 2.24 as expected\r\n      . / pow(10; $num_dec)\r\n    ;\r\n    [\r\n      2.2362,\r\n      2.4642,\r\n      10.23423\r\n    ] |\r\n    map(\r\n      round(2)\r\n    )\r\n  &#39;\r\n```\r\n\r\nYields\r\n\r\n```\r\n[\r\n  2.24,\r\n  2.46,\r\n  10.23\r\n]\r\n```",
                "title": "jq: error: round/0 is not defined at &lt;top-level&gt;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1673923617,
        "creation_date": 1560497730,
        "last_edit_date": 1673923617,
        "question_id": 56593531,
        "body_markdown": "round function in jq doesn&#39;t work.\r\n\r\n    $ jq &#39;10.01 | round&#39;\r\n    jq: error: round/0 is not defined at &lt;top-level&gt;, line 1:\r\n    10.01 | round        \r\n    jq: 1 compile error\r\n    \r\n    $ jq --help\r\n    jq - commandline JSON processor [version 1.5-1-a5b5cbe]\r\n\r\nWhat I need to do?",
        "link": "https://stackoverflow.com/questions/56593531/jq-error-round-0-is-not-defined-at-top-level",
        "title": "jq: error: round/0 is not defined at &lt;top-level&gt;"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1560688732,
                "last_edit_date": 1560688732,
                "creation_date": 1560651178,
                "answer_id": 56615575,
                "question_id": 56614969,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Using jq 1.5 or later\r\n\r\n    {id, name: (.tags | if . then from_entries.Name else . end )}\r\n\r\nor if you have a sufficiently recent (post-1.6) version of jq, you can omit the `else .`:\r\n\r\n    {id, name: (.tags | if . then from_entries.Name end )}\r\n\r\n## An alternative for jq 1.3 and up\r\n\r\n    {id, name: (.tags // {} | .[] | select(.Key==&quot;Name&quot;).Value // null)}\r\n\r\nSee also the Comments below.",
                "title": "extract value from subarray or return null using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1560688732,
        "creation_date": 1560641858,
        "question_id": 56614969,
        "body_markdown": "So given this input\r\n```\r\n{\r\n    &quot;id&quot;: 1,\r\n    &quot;tags&quot;: [\r\n        {\r\n            &quot;Key&quot;: &quot;Name&quot;,\r\n            &quot;Value&quot;: &quot;I am id 1&quot;\r\n        },\r\n        {\r\n            &quot;Key&quot;: &quot;Else&quot;,\r\n            &quot;Value&quot;: &quot;Random&quot;\r\n        }\r\n    ]\r\n}\r\n{\r\n    &quot;id&quot;: 2,\r\n    &quot;tags&quot;: null\r\n}\r\n```\r\n\r\nI would like to get the `id` and the value of `name` if exists. So for that input, I would like to get the following output.\r\n\r\n```\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;name&quot;: &quot;I am id 1&quot;\r\n}\r\n{\r\n  &quot;id&quot;: 2,\r\n  &quot;name&quot;: null\r\n}\r\n```\r\n\r\nI tried doing: \r\n```\r\njq &#39;{&quot;id&quot;: .id, &quot;name&quot;: .tags[]|select(.Key==&quot;Name&quot;).Value}&#39;\r\n```\r\n\r\nbut although it extracts when it that key is present, it fails to give `null` or default value when the path doesn&#39;t exist.\r\n\r\nAny idea on how to solve this?\r\n\r\nYou can try out at this jqplay: https://jqplay.org/s/GgXZg67o79",
        "link": "https://stackoverflow.com/questions/56614969/extract-value-from-subarray-or-return-null-using-jq",
        "title": "extract value from subarray or return null using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1560662782,
                "creation_date": 1560662782,
                "answer_id": 56616324,
                "question_id": 56616171,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re on the right track thinking of `to_entries`:\r\n\r\n    [to_entries[] | {id: .key} + .value]\r\n\r\nNuf said.\r\n",
                "title": "jq convert named array to list"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1560662840,
                "creation_date": 1560662840,
                "answer_id": 56616329,
                "question_id": 56616171,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a snippet that works. One optimization you can do on top of this to use map instead of for in. But this just works\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    let sourceArr = {\r\n      &quot;l1&quot;: {\r\n        &quot;v1&quot;: {\r\n          &quot;a&quot;: [1],\r\n          &quot;b&quot;: [2]\r\n        },\r\n        &quot;v2&quot;: {\r\n          &quot;a&quot;: [3],\r\n          &quot;b&quot;: [4]\r\n        }\r\n      },\r\n      &quot;l2&quot;: {\r\n        &quot;v3&quot;: {\r\n          &quot;a&quot;: [5],\r\n          &quot;b&quot;: [6]\r\n        },\r\n        &quot;v4&quot;: {\r\n          &quot;a&quot;: [7],\r\n          &quot;b&quot;: [8]\r\n        }\r\n      }\r\n    };\r\n\r\n    let targetArr = [];\r\n\r\n    for( let id in sourceArr ){\r\n       let obj = {\r\n           &quot;id&quot;: id\r\n       }\r\n       \r\n       let subItem = sourceArr[id];\r\n       //let itemKey = Object.keys(mainItem);\r\n       for( item in subItem ){\r\n          let itemKey = item;\r\n          let itemVal = subItem[item]\r\n          \r\n          let subItems = {};\r\n          subItems[itemKey] = itemVal;\r\n          Object.assign(obj, subItems);\r\n       }\r\n       \r\n       targetArr.push( obj );\r\n       \r\n    }\r\n\r\n    console.log( targetArr );\r\n\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n",
                "title": "jq convert named array to list"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1560662840,
        "creation_date": 1560660671,
        "last_edit_date": 1560661058,
        "question_id": 56616171,
        "body_markdown": "How to take the names of the named array, insert them as elements into it, then remove the name?\r\n\r\n```lang-json\r\n{\r\n  &quot;l1&quot;: {\r\n    &quot;v1&quot;: {\r\n      &quot;a&quot;: [1],\r\n      &quot;b&quot;: [2]\r\n    },\r\n    &quot;v2&quot;: {\r\n      &quot;a&quot;: [3],\r\n      &quot;b&quot;: [4]\r\n    }\r\n  },\r\n  &quot;l2&quot;: {\r\n    &quot;v3&quot;: {\r\n      &quot;a&quot;: [5],\r\n      &quot;b&quot;: [6]\r\n    },\r\n    &quot;v4&quot;: {\r\n      &quot;a&quot;: [7],\r\n      &quot;b&quot;: [8]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\ninto\r\n\r\n```lang-json\r\n[\r\n  {\r\n    &quot;id&quot;: [&quot;l1&quot;],\r\n    &quot;v1&quot;: {\r\n      &quot;a&quot;: [1],\r\n      &quot;b&quot;: [2]\r\n    },\r\n    &quot;v2&quot;: {\r\n      &quot;a&quot;: [3],\r\n      &quot;b&quot;: [4]\r\n    }\r\n  },\r\n  {\r\n    &quot;id&quot;: [&quot;l2&quot;],\r\n    &quot;v3&quot;: {\r\n      &quot;a&quot;: [5],\r\n      &quot;b&quot;: [6]\r\n    },\r\n    &quot;v4&quot;: {\r\n      &quot;a&quot;: [7],\r\n      &quot;b&quot;: [8]\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nThe names (`&quot;l1&quot;`, `&quot;l2&quot;`) are not known a priori, nor are the other contents; all I know is that I want to take the top-level names and insert them as `&quot;id&quot;`-named objects.\r\n\r\nI believe this is close to opposite https://stackoverflow.com/q/52303570.\r\n\r\n```\r\njq &#39;to_entries&#39;\r\n```\r\n\r\nstarts, but embeds both `&quot;key&quot;` and `&quot;value&quot;`, whereas I really just want to add (prepend) `&quot;key&quot;`, even better controlling the literal &quot;key&quot; to (say) `&quot;id&quot;`.",
        "link": "https://stackoverflow.com/questions/56616171/jq-convert-named-array-to-list",
        "title": "jq convert named array to list"
    },
    {
        "tags": [
            "json",
            "unique",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1560777111,
                "last_edit_date": 1560777111,
                "creation_date": 1560758444,
                "answer_id": 56627085,
                "question_id": 56626848,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Above is a jq command that I want to use \r\n\r\nThe following response focuses on the above requirement.\r\n\r\n`unique/0` could be used if you don&#39;t mind the fact that it sorts its input.  This filter expects an array as input, and so you could modify your query as follows:\r\n```\r\n[.[]\r\n | select(.accountEnabled==true)\r\n | select(.assignedPlans[].service==&quot;exchange&quot; and .assignedPlans[].capabilityStatus==&quot;Enabled&quot;)\r\n | .proxyAddresses[]]\r\n| unique\r\n```\r\n\r\nThis produces an array, so if you want a stream, simply tack on `[]` at the end.\r\n\r\n## A stream-oriented approach\r\n\r\nUnder some circumstances, it may be desirable to avoid the `sort` that `unique/0` uses.  Here is a stream-oriented solution using a generic filter, `uniques/1`, which involves no sorting and which has other potential advantages, though it is a bit tricky to define because it puts no restrictions on the stream.\r\n\r\n```\r\ndef uniques(stream):\r\n  foreach stream as $s ({};\r\n     ($s|type) as $t\r\n     | (if $t == &quot;string&quot; then $s else ($s|tostring) end) as $y\r\n     | if .[$t][$y]\r\n       then .emit = false\r\n       else .emit = true | (.item = $s) | (.[$t][$y] = true)\r\n       end;\r\n     if .emit then .item else empty end );\r\n```\r\nUsing `uniques/1`, a small tweak to the previous solution is sufficient:\r\n\r\n```\r\nuniques(.[]\r\n | select(.accountEnabled==true)\r\n | select(.assignedPlans[].service==&quot;exchange&quot; and .assignedPlans[].capabilityStatus==&quot;Enabled&quot;)\r\n | .proxyAddresses[] )\r\n\r\n```",
                "title": "How do I get jq to return unique results when json has multiple identical entries?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1560776528,
                "last_edit_date": 1560776528,
                "creation_date": 1560775210,
                "answer_id": 56631527,
                "question_id": 56626848,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Perhaps the problem is that the given jq query is simply &quot;wrong&quot; in that it does not capture the OP&#39;s intent.\r\n\r\nEven if the following query does not reflect the OP&#39;s intent, it is worth noting that, with the given JSON, it produces the single result that is wanted:\r\n\r\n```\r\n.[]\r\n| select(.accountEnabled==true)\r\n| select(any(.assignedPlans[];\r\n             .service==&quot;exchange&quot; and\r\n             .capabilityStatus==&quot;Enabled&quot;))\r\n| .proxyAddresses[]\r\n```\r\n\r\n## Likewise ....\r\nHere&#39;s another query with different semantics but which, with the given JSON, also produces the single desired result.  (It goes to show that a single example by itself is no substitute for requirements.)\r\n\r\n```\r\n.[]\r\n | select(.accountEnabled==true)\r\n | select(any(.assignedPlans[]; .service==&quot;exchange&quot;))\r\n | select(any(.assignedPlans[]; .capabilityStatus==&quot;Enabled&quot;))\r\n | .proxyAddresses[]\r\n```",
                "title": "How do I get jq to return unique results when json has multiple identical entries?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1560777111,
        "creation_date": 1560757505,
        "last_edit_date": 1560767809,
        "question_id": 56626848,
        "body_markdown": "```\r\njq &#39;\r\n  .[]|select(.accountEnabled==true)|select(.assignedPlans[].service==&quot;exchange&quot; and .assignedPlans[].capabilityStatus==&quot;Enabled&quot;).proxyAddresses[]&#39;\r\n```\r\n\r\nBelow is a sample of json, it&#39;s the output of &quot;az ad user list&quot; (getting the Active Directory userlist from Azure) anonymised and with irrelevant things removed. Above is a jq command that I want to use to extract email addresses, the desired output is &quot;SMTP:russell.coker@example.com&quot; printed once not 9 times. Yes, I know I could pipe this to the Unix command &quot;sort -u&quot; but I&#39;d like to do other json queries on it.\r\n\r\n\r\n\r\n\r\n\r\n```\r\n[\r\n  {\r\n    &quot;accountEnabled&quot;: true,\r\n    &quot;assignedPlans&quot;: [\r\n      {\r\n        &quot;capabilityStatus&quot;: &quot;Enabled&quot;,\r\n        &quot;service&quot;: &quot;exchange&quot;\r\n      },\r\n      {\r\n        &quot;capabilityStatus&quot;: &quot;Enabled&quot;,\r\n        &quot;service&quot;: &quot;exchange&quot;\r\n      },\r\n      {\r\n        &quot;capabilityStatus&quot;: &quot;Enabled&quot;,\r\n        &quot;service&quot;: &quot;exchange&quot;\r\n      }\r\n    ],\r\n    &quot;provisionedPlans&quot;: [\r\n      {\r\n        &quot;capabilityStatus&quot;: &quot;Enabled&quot;,\r\n        &quot;provisioningStatus&quot;: &quot;Success&quot;,\r\n        &quot;service&quot;: &quot;exchange&quot;\r\n      },\r\n      {\r\n        &quot;capabilityStatus&quot;: &quot;Enabled&quot;,\r\n        &quot;provisioningStatus&quot;: &quot;Success&quot;,\r\n        &quot;service&quot;: &quot;exchange&quot;\r\n      },\r\n      {\r\n        &quot;capabilityStatus&quot;: &quot;Enabled&quot;,\r\n        &quot;provisioningStatus&quot;: &quot;Success&quot;,\r\n        &quot;service&quot;: &quot;exchange&quot;\r\n      },\r\n      {\r\n        &quot;capabilityStatus&quot;: &quot;Enabled&quot;,\r\n        &quot;provisioningStatus&quot;: &quot;Success&quot;,\r\n        &quot;service&quot;: &quot;exchange&quot;\r\n      }\r\n    ],\r\n    &quot;proxyAddresses&quot;: [\r\n      &quot;SMTP:russell.coker@example.com&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;accountEnabled&quot;: true,\r\n    &quot;assignedPlans&quot;: [\r\n      {\r\n        &quot;capabilityStatus&quot;: &quot;Deleted&quot;,\r\n        &quot;service&quot;: &quot;exchange&quot;\r\n      },\r\n      {\r\n        &quot;capabilityStatus&quot;: &quot;Deleted&quot;,\r\n        &quot;service&quot;: &quot;OfficeForms&quot;\r\n      }\r\n    ],\r\n    &quot;provisionedPlans&quot;: [\r\n      {\r\n        &quot;capabilityStatus&quot;: &quot;Deleted&quot;,\r\n        &quot;provisioningStatus&quot;: &quot;Success&quot;,\r\n        &quot;service&quot;: &quot;SharePoint&quot;\r\n      },\r\n      {\r\n        &quot;capabilityStatus&quot;: &quot;Deleted&quot;,\r\n        &quot;provisioningStatus&quot;: &quot;Success&quot;,\r\n        &quot;service&quot;: &quot;exchange&quot;\r\n      },\r\n      {\r\n        &quot;capabilityStatus&quot;: &quot;Deleted&quot;,\r\n        &quot;provisioningStatus&quot;: &quot;Success&quot;,\r\n        &quot;service&quot;: &quot;exchange&quot;\r\n      }\r\n    ],\r\n    &quot;proxyAddresses&quot;: [\r\n      &quot;smtp:a@example.com&quot;,\r\n      &quot;smtp:b@example.com&quot;,\r\n      &quot;SMTP:c@example.com&quot;\r\n    ]\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/56626848/how-do-i-get-jq-to-return-unique-results-when-json-has-multiple-identical-entrie",
        "title": "How do I get jq to return unique results when json has multiple identical entries?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1560805934,
                "post_id": 56638907,
                "comment_id": 99848802,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1560805982,
                "post_id": 56638907,
                "comment_id": 99848814,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1560809136,
                "creation_date": 1560809136,
                "answer_id": 56639446,
                "question_id": 56638907,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following filter will do what you want, assuming you&#39;ve fixed the input:\r\n\r\n    .desc\r\n    | to_entries\r\n    | map( {id: .key} + .value)\r\n\r\nTo understand this, simply read up on `to_entries` in the online manual (see [tag:jq]).",
                "title": "Transform a Map to List"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1560814783,
        "creation_date": 1560805490,
        "last_edit_date": 1560814783,
        "question_id": 56638907,
        "body_markdown": "I am trying to transform the map of the object in json to List using JQ ...\r\n\r\nSource:\r\n\r\n    {\r\n      &quot;title&quot;: &quot;title&quot;,\r\n      &quot;keyword&quot;: &quot;keyword&quot;,\r\n      &quot;desc&quot;: {\r\n        &quot;user1&quot;: {\r\n          &quot;name&quot;: &quot;kumar&quot;,\r\n          &quot;Duration&quot;: null,\r\n          &quot;Time&quot;: null,\r\n          &quot; Dominance&quot;: &quot;Upper Field First&quot;\r\n        },\r\n        &quot;user2&quot;: {\r\n          &quot;id&quot;: &quot;user2&quot;,\r\n          &quot;name&quot;: &quot;user2&quot;,\r\n          &quot;Duration&quot;: null,\r\n          &quot;Time&quot;: null,\r\n          &quot; Dominance&quot;: &quot;Upper Field First&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nTarget:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;user1&quot;,\r\n        &quot;name&quot;: &quot;kumar&quot;,\r\n        &quot;Duration&quot;: null,\r\n        &quot;Time&quot;: null,\r\n        &quot;Dominance&quot;: &quot;Upper Field First&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;user2&quot;,\r\n        &quot;name&quot;: &quot;user2&quot;,\r\n        &quot;Duration&quot;: null,\r\n        &quot;Time&quot;: null,\r\n        &quot;Dominance&quot;: &quot;Upper Field First&quot;\r\n      }\r\n    ]\r\n\r\nI tried various options like , but not able to get the extact thing i need.\r\n\r\n\r\n1. `.desc | . as $in| keys[]`\r\n2. `to_entries` \r\n\r\n\r\nJQ Workspace ::: https://jqplay.org/s/MiJ9w1Sz5L\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56638907/transform-a-map-to-list",
        "title": "Transform a Map to List"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 301110,
                    "reputation": 103185,
                    "user_id": 608639,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/aPIhh.jpg?s=256",
                    "display_name": "jww",
                    "link": "https://stackoverflow.com/users/608639/jww"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1560859656,
                "post_id": 56648694,
                "comment_id": 99867180,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1560860414,
                "creation_date": 1560860414,
                "answer_id": 56649035,
                "question_id": 56648694,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just map it to string.\r\n\r\n    jq --raw-output &#39;.key, ( .level_cnt.buckets[] | &quot;\\(.key):\\(.doc_count)&quot; )&#39;\r\n\r\nWith the following input:\r\n\r\n    {\r\n        &quot;key&quot;: &quot;Agreement&quot;,\r\n        &quot;doc_count&quot;: 1603,\r\n        &quot;level_cnt&quot;: {\r\n            &quot;doc_count_error_upper_bound&quot;: 0,\r\n            &quot;sum_other_doc_count&quot;: 0,\r\n            &quot;buckets&quot;: [\r\n                {\r\n                &quot;key&quot;: &quot;INFO&quot;,\r\n                &quot;doc_count&quot;: 1458\r\n              },\r\n              {\r\n                &quot;key&quot;: &quot;ERROR&quot;,\r\n                &quot;doc_count&quot;: 145\r\n              }\r\n            ]\r\n        }\r\n    }\r\n\r\nwill output:\r\n\r\n    Agreement\r\n    INFO:1458\r\n    ERROR:145\r\n\r\ntested at [jq play](https://jqplay.org/s/um5yii0dZn).\r\n",
                "title": "How to parse JSON-input"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1560860414,
        "creation_date": 1560859373,
        "last_edit_date": 1560859962,
        "question_id": 56648694,
        "body_markdown": "I&#39;ve been reading JQ-s docs for the last two days and didn&#39;t find out how to extract values and put them together.\r\n\r\nI&#39;ve got some curl-output:\r\n\r\n```JSON\r\n...\r\n{\r\n    &quot;key&quot;: &quot;Agreement&quot;,\r\n    &quot;doc_count&quot;: 1603,\r\n    &quot;level_cnt&quot;: {\r\n        &quot;doc_count_error_upper_bound&quot;: 0,\r\n        &quot;sum_other_doc_count&quot;: 0,\r\n        &quot;buckets&quot;: [\r\n            {\r\n            &quot;key&quot;: &quot;INFO&quot;,\r\n            &quot;doc_count&quot;: 1458\r\n          },\r\n          {\r\n            &quot;key&quot;: &quot;ERROR&quot;,\r\n            &quot;doc_count&quot;: 145\r\n          }\r\n        ]\r\n    }\r\n}\r\n...\r\n```\r\n\r\nThe task is to take the first Key and to combine it with the next Key&#39;s and their values:\r\n\r\n`Agreement\r\nINFO:1458\r\nERROR:145`\r\n\r\nThe trouble is, when I try to parse the necessary keys, their values comes together aftewards:\r\n\r\n`jq &#39;.aggregations.controller_cnt.buckets[].key, .aggregations.controller_cnt.buckets[].level_cnt.buckets[].key, .aggregations.controller_cnt.buckets[].level_cnt.buckets[].doc_count`\r\n\r\n`&quot;Agreement&quot;\r\n&quot;INFO&quot;\r\n&quot;ERROR&quot;\r\n1469\r\n149`\r\n\r\nHow to build this jq-query?\r\n\r\nThanx in advance!",
        "link": "https://stackoverflow.com/questions/56648694/how-to-parse-json-input",
        "title": "How to parse JSON-input"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1560870028,
                "post_id": 56651743,
                "comment_id": 99873891,
                "content_license": "CC BY-SA 4.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": 1560880659,
                "post_id": 56651743,
                "comment_id": 99879200,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1560882311,
                "post_id": 56651743,
                "comment_id": 99879911,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 65870,
                    "reputation": 1003,
                    "user_id": 193539,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/d2d22153d8fdaf387f0e5ca3b4e25f63?s=256&d=identicon&r=PG",
                    "display_name": "AC.",
                    "link": "https://stackoverflow.com/users/193539/ac"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1560889235,
                "post_id": 56651743,
                "comment_id": 99882900,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1560898733,
                "post_id": 56651743,
                "comment_id": 99885827,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1560898650,
                "last_edit_date": 1560898650,
                "creation_date": 1560897059,
                "answer_id": 56657843,
                "question_id": 56651743,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re basically implementing your own merging scheme. If you want a generalized solution, you&#39;ll want to define a function so it could be done recursively. This won&#39;t be quite the same as &quot;`*` but with different array semantics&quot; but you could use something like this:\r\n\r\n    def new_merge($item):\r\n        if type == ($item|type) then   # if same types\r\n            if type == &quot;array&quot; then        # concatenate the arrays\r\n                . + $item\r\n            elif type == &quot;object&quot; then     # recursively merge objects\r\n                reduce ($item|to_entries[]) as {$key,$value} (.;\r\n                    .[$key] |= new_merge($value)\r\n                )\r\n            else                           # just take the &quot;other&quot; value\r\n                $item // .\r\n            end\r\n        else                           # just take the &quot;other&quot; value\r\n            $item // .\r\n        end\r\n        ;\r\n\r\nI&#39;d put this in your `~/.jq` file and invoke like this:\r\n\r\n    $ jq &#39;reduce inputs as $i (.; do_merge($i))&#39; file*.json\r\n    {\r\n      &quot;value1&quot;: 200,\r\n      &quot;timestamp&quot;: 1382461861,\r\n      &quot;parameter&quot;: [\r\n        {\r\n          &quot;param&quot;: 1\r\n        },\r\n        {\r\n          &quot;param&quot;: 2\r\n        }\r\n      ],\r\n      &quot;status&quot;: 200,\r\n      &quot;value&quot;: {\r\n        &quot;aaa&quot;: {\r\n          &quot;value3&quot;: &quot;v3&quot;,\r\n          &quot;value4&quot;: 4\r\n        }\r\n      }\r\n    }\r\n\r\nIf on the other hand you wanted array items recursively merged as you had it in your original question, just change the array case to recursively merge corresponding items.\r\n\r\n    def new_merge2($item):\r\n        if type == ($item|type) then\r\n            if type == &quot;array&quot; then\r\n                [.,$item] | transpose[] as [$a,$b] | [$a | new_merge2($b)]\r\n            elif type == &quot;object&quot; then\r\n                reduce ($item|to_entries[]) as {$key,$value} (.;\r\n                    .[$key] |= new_merge2($value)\r\n                )\r\n            else\r\n                $item // .\r\n            end\r\n        else\r\n            $item // .\r\n        end\r\n        ;\r\n\r\nThis version would produce:\r\n\r\n    {\r\n      &quot;value1&quot;: 200,\r\n      &quot;timestamp&quot;: 1382461861,\r\n      &quot;parameter&quot;: [\r\n        {\r\n          &quot;param1&quot;: 1,\r\n          &quot;param2&quot;: 2\r\n        }\r\n      ],\r\n      &quot;status&quot;: 200,\r\n      &quot;value&quot;: {\r\n        &quot;aaa&quot;: {\r\n          &quot;value3&quot;: &quot;v3&quot;,\r\n          &quot;value4&quot;: 4\r\n        }\r\n      }\r\n    }\r\n\r\n",
                "title": "jq merging multiple json files merging any array element"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1560908662,
                "creation_date": 1560908662,
                "answer_id": 56659008,
                "question_id": 56651743,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution to the problem in the case that there are two files, each with one object in which there is at least one same-named array-valued field at some level.  \r\n\r\nThe requirements are unclear on many points, so the following may require tweaking in accordance with more detailed requirements.  If there are more than two files, then the same techniques can be used, but again the details will depend on the detailed requirements.\r\n```\r\njq -n --slurpfile file1 file1.json --slurpfile file2 file2.json &#39;\r\n\r\n  # a and b are expected to be jq paths ending with a string\r\n  # emit the array of the intersection of key names\r\n  def common(a;b):\r\n    ((a|map(.[-1])) + (b|map(.[-1]))) \r\n    | unique;\r\n\r\n  $file1[0] as $f1\r\n  | $file2[0] as $f2\r\n  | [$f1 | paths as $p | select(getpath($p) | type == &quot;array&quot;) | $p] as $p1\r\n  | [$f2 | paths as $p | select(getpath($p) | type == &quot;array&quot;) | $p] as $p2\r\n  | $f1+$f2\r\n  | if ($p1|length) &gt; 0 and ($p2|length) &gt; 0 \r\n    then common($p1; $p2) as $both\r\n    | if ($both|length) &gt; 0 \r\n      then first( $p1[] | select(.[-1] == $both[0])) as $p1\r\n      |    first( $p2[] | select(.[-1] == $both[0])) as $p2\r\n      | ($f1 | getpath($p1)) as $a1\r\n      | ($f2 | getpath($p2)) as $a2\r\n      | setpath($p1; $a1 + $a2)\r\n      else .\r\n      end\r\n    else .\r\n    end\r\n  &#39;\r\n```\r\n\r\n## Output\r\nUsing the given input, after adding the missing &quot;:&quot; in the second file, the output is:\r\n```\r\n{\r\n  &quot;value1&quot;: 200,\r\n  &quot;timestamp&quot;: 1382461861,\r\n  &quot;parameter&quot;: [\r\n    {\r\n      &quot;param1&quot;: 1\r\n    },\r\n    {\r\n      &quot;param2&quot;: 2\r\n    }\r\n  ],\r\n  &quot;status&quot;: 200,\r\n  &quot;value&quot;: {\r\n    &quot;aaa&quot;: {\r\n      &quot;value3&quot;: &quot;v3&quot;,\r\n      &quot;value4&quot;: 4\r\n    }\r\n  }\r\n}\r\n```",
                "title": "jq merging multiple json files merging any array element"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1560939349,
                "last_edit_date": 1560939349,
                "creation_date": 1560938837,
                "answer_id": 56665157,
                "question_id": 56651743,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a simple but generic solution to the problem in the case of two files, each with one object.\r\n\r\nThis solution will concatenate each pair of arrays at the same path.  Hopefully it is simple enough for it to speak for itself and for modifications to be made to handle a wide range of more detailed requirements.\r\n\r\n```\r\njq -n --slurpfile file1 file1.json --slurpfile file2 file2.json &#39;\r\n  $file1[0] as $f1\r\n  | $file2[0] as $f2\r\n  | reduce ($f1 | paths) as $p ($f1+$f2;\r\n      ($f1|getpath($p)) as $v1\r\n      | ($f2|getpath($p)) as $v2\r\n      | if ($v1 | type == &quot;array&quot;) and\r\n           ($v2 | type == &quot;array&quot;)\r\n        then setpath($p; $v1 + $v2)\r\n        else .\r\n        end)\r\n\r\n&#39;\r\n```\r\n\r\nThe output is exactly as required, assuming that the second file has been corrected in the obvious way so that it is valid JSON.\r\n",
                "title": "jq merging multiple json files merging any array element"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1560939349,
        "creation_date": 1560869153,
        "last_edit_date": 1560888467,
        "question_id": 56651743,
        "body_markdown": "I want to use jq to merge multiple files and if more than one file contains an array with the name, I need the arrays merged (order doesn&#39;t matter).\r\n\r\nFor example \r\n\r\nfile1\r\n``` \r\n{\r\n    &quot;value1&quot;: 200,\r\n    &quot;timestamp&quot;: 1382461861,\r\n    &quot;parameter&quot;: [\r\n    {&quot;param&quot;: 1}\r\n    ]\r\n}\r\n```\r\n\r\nfile2\r\n```\r\n{\r\n    &quot;status&quot;: 200,\r\n    &quot;timestamp&quot;: 1382461861,\r\n    &quot;value&quot;: {\r\n        &quot;aaa&quot;: {\r\n            &quot;value3&quot;: &quot;v3&quot;,\r\n            &quot;value4&quot;: 4\r\n        }\r\n    },\r\n    &quot;parameter&quot; [\r\n    {&quot;param&quot;: 2}\r\n    ]\r\n}\r\n```\r\n\r\nit is suggested other stack overflow articles to merge these json, I should do:\r\n\r\n```\r\njq -s &#39;.[0] * .[1]&#39; file1 file2\r\n```\r\n\r\nyet this gets me:\r\n```\r\n{\r\n  &quot;value1&quot;: 200,\r\n  &quot;timestamp&quot;: 1382461861,\r\n  &quot;parameter&quot;: [\r\n    {\r\n      &quot;param&quot;: 2\r\n    }\r\n  ],\r\n  &quot;status&quot;: 200,\r\n  &quot;value&quot;: {\r\n    &quot;aaa&quot;: {\r\n      &quot;value3&quot;: &quot;v3&quot;,\r\n      &quot;value4&quot;: 4\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nwhere what I want is:\r\n```\r\n{\r\n  &quot;value1&quot;: 200,\r\n  &quot;timestamp&quot;: 1382461861,\r\n  &quot;parameter&quot;: [\r\n    { &quot;param&quot;: 1}, \r\n    { &quot;param&quot;: 2}\r\n  ],\r\n  &quot;status&quot;: 200,\r\n  &quot;value&quot;: {\r\n    &quot;aaa&quot;: {\r\n      &quot;value3&quot;: &quot;v3&quot;,\r\n      &quot;value4&quot;: 4\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nnotice the &quot;parameter&quot; array should have the elements from both file1 and file2\r\n\r\n\r\nI also need a solution that doesn&#39;t require specifying the fields that array, and the arrays can be nested at any level of the json\r\n\r\nI&#39;m willing to accept a solution that is not using jq, a small python script would be ok I guess\r\n\r\n\r\nthe closest solution I have found requires me to know that parameter is an array \r\n\r\n```\r\n jq -s &#39;.[0] *  .[1]&#39; file1.json file2.json &gt;temp.json\r\n jq -s &#39;.[0].parameter=([.[].parameter]|flatten)|.[0]&#39; temp.json file1.json\r\n```\r\nand the output is \r\n```\r\n{\r\n  &quot;value1&quot;: 200,\r\n  &quot;timestamp&quot;: 1382461861,\r\n  &quot;parameter&quot;: [\r\n    {\r\n      &quot;param&quot;: 2\r\n    },\r\n    {\r\n      &quot;param&quot;: 1\r\n    }\r\n  ],\r\n  &quot;status&quot;: 200,\r\n  &quot;value&quot;: {\r\n    &quot;aaa&quot;: {\r\n      &quot;value3&quot;: &quot;v3&quot;,\r\n      &quot;value4&quot;: 4\r\n    }\r\n  }\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/56651743/jq-merging-multiple-json-files-merging-any-array-element",
        "title": "jq merging multiple json files merging any array element"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1560941490,
                "last_edit_date": 1560941490,
                "creation_date": 1560873807,
                "answer_id": 56653068,
                "question_id": 56652066,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following `jq` invocation works for your sample input :\r\n\r\n    .[0] as $header | .[1:] | map( { ($header[0].value) : .[0].value, ($header[1].value) : .[1].value, ($header[2].value) : .[2].value } )\r\n\r\nIt extracts the header then iterate over the rest of the list, creating an object with keys extracted from the header and values from the current element.\r\n\r\nYou can [try it here](https://jqplay.org/s/BpwNee35dx).\r\n\r\nIt only handles inputs with a specific amount of columns though, while I think it would be possible to generically link the values of the first item with those of the other items.\r\n\r\n\r\n--------\r\n\r\n## Edit (macicero@)\r\n\r\n&gt; This is exactly what I was looking for. I&#39;ve enhanced your example with this version that is not coupled to the # of columns:\r\n\r\n```\r\n[.[0][].value] as $cols | [.[1:][] | to_entries] | map(map({($cols[.key]): .value.value}) | add)\r\n```",
                "title": "Replace field names of some objects with values of another object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1560876985,
                "creation_date": 1560876985,
                "answer_id": 56653837,
                "question_id": 56652066,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another way you can construct the desired results.\r\n\r\n    (.[0] | map({key:.value})) as $keys | [.[1:][] | [$keys,.] | transpose | map(add) | from_entries]\r\n\r\nYou can take advantage of `from_entries` here treating the header and rows as sets of keys and values. You just need to manipulate the values to be paired up with their corresponding keys.",
                "title": "Replace field names of some objects with values of another object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1560941490,
        "creation_date": 1560870239,
        "question_id": 56652066,
        "body_markdown": "Suppose I have the following JSON array:\r\n\r\n```javascript\r\n[\r\n    [\r\n         { &quot;value&quot;: &quot;first_name&quot; },\r\n         { &quot;value&quot;: &quot;last_name&quot; },\r\n         { &quot;value&quot;: &quot;age&quot; }\r\n    ],\r\n    [\r\n         { &quot;value&quot;: &quot;John&quot; },\r\n         { &quot;value&quot;: &quot;Johnson&quot; },\r\n         { &quot;value&quot;: 27 }\r\n    ],\r\n    [\r\n         { &quot;value&quot;: &quot;Martin&quot; },\r\n         { &quot;value&quot;: &quot;Martinson&quot; },\r\n         { &quot;value&quot;: 18 }\r\n    ]\r\n]\r\n```\r\n\r\nYou can think of this JSON as a different view for:\r\n\r\n```\r\n| first_name | last_name | age |\r\n|------------|-----------|-----|\r\n| John       | Johnson   | 27  |\r\n| Martin     | Martinson | 18  |\r\n```\r\n\r\n----\r\n\r\nThe first item of the array **always** represents the *&quot;columns&quot;*, while the other items are the rows.\r\n\r\nI&#39;d like to transform the above JSON into something more readable, i.e. getting rid of the first item altogether, merging all the separated objects and also udpating the field name accordingly:\r\n\r\n```javascript\r\n[\r\n    {\r\n        &quot;first_name&quot;: &quot;John&quot;,\r\n        &quot;last_name&quot;: &quot;Johnson&quot;,\r\n        &quot;age&quot;: 27\r\n    },\r\n    {\r\n        &quot;first_name&quot;: &quot;Martin&quot;,\r\n        &quot;last_name&quot;: &quot;Martinson&quot;,\r\n        &quot;age&quot;: 18\r\n    }\r\n]\r\n```\r\n\r\nIdeally, I&#39;d like to achieve this with a CLI tool such as **jq** - is this possible?",
        "link": "https://stackoverflow.com/questions/56652066/replace-field-names-of-some-objects-with-values-of-another-object",
        "title": "Replace field names of some objects with values of another object"
    },
    {
        "tags": [
            "shell",
            "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": 1560952127,
                "post_id": 56668919,
                "comment_id": 99906094,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4429543,
                    "reputation": 17161,
                    "user_id": 3612353,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://www.gravatar.com/avatar/94f2502e42d2e474bfd81dba411fe66f?s=256&d=identicon&r=PG",
                    "display_name": "cn0047",
                    "link": "https://stackoverflow.com/users/3612353/cn0047"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1560953277,
                "post_id": 56668919,
                "comment_id": 99906850,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15552769,
                    "reputation": 15,
                    "user_id": 11220016,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/06f7ec2b579c8274c86ee4b6b7e86473?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Lamz",
                    "link": "https://stackoverflow.com/users/11220016/lamz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1560957159,
                "post_id": 56668919,
                "comment_id": 99909312,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1560952101,
                "creation_date": 1560952101,
                "answer_id": 56669271,
                "question_id": 56668919,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After fixing the given JSON in the obvious way, the following invocation of jq produces the results shown below:\r\n\r\n\r\n    $ jq -r &#39;[.id, .user, .&quot;date-started&quot;.date] | join(&quot; &quot;)&#39; input.json\r\n    132 sthirard 2019-06-19T12:16:49Z\r\n\r\nYou might like to consider using `@csv` or `@tsv` instead of using `join`; and you might have to prepend `.executions[0] |` to the above pipeline. \r\n\r\n",
                "title": "jq display different fields of a json file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1560952467,
                "creation_date": 1560952467,
                "answer_id": 56669393,
                "question_id": 56668919,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You may try to do something like this:\r\n\r\n    jq &#39;.executions[0] | &quot;\\(.id) \\(.user) \\(.&quot;date-started&quot;.date)&quot;&#39; response.json",
                "title": "jq display different fields of a json file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1560952467,
        "creation_date": 1560951139,
        "question_id": 56668919,
        "body_markdown": "I want to get different values from a json file with jq but i can&#39;t get values which are in a different level.\r\n\r\nHere is the json i have :\r\n```\r\n{\r\n  &quot;id&quot;: 132,\r\n  &quot;status&quot;: &quot;succeeded&quot;,\r\n  &quot;project&quot;: &quot;TEST-Sylvain&quot;,\r\n  &quot;executionType&quot;: &quot;user&quot;,\r\n  &quot;user&quot;: &quot;sthirard&quot;,\r\n  &quot;date-started&quot;: {\r\n    &quot;unixtime&quot;: 1560946609000,\r\n    &quot;date&quot;: &quot;2019-06-19T12:16:49Z&quot;\r\n  },\r\n  &quot;date-ended&quot;: {\r\n    &quot;unixtime&quot;: 1560946613000,\r\n    &quot;date&quot;: &quot;2019-06-19T12:16:53Z&quot;\r\n  },\r\n  &quot;job&quot;: {\r\n    &quot;id&quot;: &quot;7a8dfbb0-a4b1-4309-8b76-f04cd0f03af2&quot;,\r\n    &quot;averageDuration&quot;: 3060,\r\n    &quot;name&quot;: &quot;TEST_chainage_job&quot;,\r\n    &quot;group&quot;: &quot;DEPLOYMENT&quot;,\r\n    &quot;project&quot;: &quot;TEST-Sylvain&quot;,\r\n    &quot;description&quot;: &quot;JOb d&#39;installation  &quot;,\r\n  },\r\n  &quot;description&quot;: &quot;hostname [... 4 steps]&quot;,\r\n  &quot;argstring&quot;: null,\r\n  &quot;successfulNodes&quot;: [\r\n    &quot;acde&quot;,\r\n    &quot;bfgh&quot;\r\n  ]\r\n}\r\n```\r\n\r\nI can get id / user but i can&#39;t get the date field.\r\n\r\n```\r\njq &#39;.executions[0] | &quot;\\(.id) \\(.user)&quot;&#39; response.json\r\n```\r\n\r\nI tried \r\n\r\n```\r\njq &#39;.executions[0] | .date-started.date&#39; response.json\r\n\r\n```\r\nbut it doesn&#39;t work\r\n\r\nCan you help me with that ?\r\n\r\nThanks ",
        "link": "https://stackoverflow.com/questions/56668919/jq-display-different-fields-of-a-json-file",
        "title": "jq display different fields of a json file"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 365431,
                    "reputation": 5132,
                    "user_id": 2057091,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://i.sstatic.net/7kWv6.png?s=256",
                    "display_name": "Aserre",
                    "link": "https://stackoverflow.com/users/2057091/aserre"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1560959770,
                "post_id": 56671337,
                "comment_id": 99910891,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4518980,
                    "reputation": 5332,
                    "user_id": 3672883,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/bOBrL.png?s=256",
                    "display_name": "Tlaloc-ES",
                    "link": "https://stackoverflow.com/users/3672883/tlaloc-es"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1560960623,
                "post_id": 56671337,
                "comment_id": 99911308,
                "content_license": "CC BY-SA 4.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": 2,
                "creation_date": 1560960746,
                "post_id": 56671337,
                "comment_id": 99911368,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1560961414,
                "creation_date": 1560961414,
                "answer_id": 56672124,
                "question_id": 56671337,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use awk to fix up your current output file.\r\n\r\n    awk -F, &#39;{a[$1&quot;,&quot;$2]=a[$1&quot;,&quot;$2]&quot;,&quot;$3}; END{for (v in a) print v a[v]}&#39; in.txt | sort &gt;out.txt\r\n\r\nInput:\r\n\r\n    001,Robert,Pen\r\n    001,Robert,Paper\r\n    002,Bruce,Pen,\r\n    002,Bruce,Computer\r\n    002,Bruce,Headphones\r\n\r\nOutput:\r\n\r\n    001,Robert,Pen,Paper\r\n    002,Bruce,Pen,Computer,Headphones\r\n",
                "title": "How to convert a JSON array to a CSV row?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1560962647,
                "creation_date": 1560962647,
                "answer_id": 56672420,
                "question_id": 56671337,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    $ jq -r &#39;.resources[] | [.id,.name,.items[].name] | @csv&#39; &lt; /tmp/b.json\r\n    &quot;001&quot;,&quot;Robert&quot;,&quot;Pen&quot;,&quot;Paper&quot;\r\n    &quot;002&quot;,&quot;Bruce&quot;,&quot;Pen&quot;,&quot;Computer&quot;,&quot;Headphones&quot;",
                "title": "How to convert a JSON array to a CSV row?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1561010097,
        "creation_date": 1560958386,
        "last_edit_date": 1561010097,
        "question_id": 56671337,
        "body_markdown": "I&#39;m trying to convert a large `JSON` file to a `CSV` format. (I&#39;ve just learned how to use `jq` so I&#39;m still a beginner).\r\n\r\nI&#39;ve successfully managed to convert most of the data, however, I&#39;m stuck at an array. Every `JSON` object in the file is supposed to be converted to a single `CSV` row, and I can&#39;t get that to work.\r\n\r\nI&#39;ve been trying to help myself with an existing answer:\r\nhttps://stackoverflow.com/questions/49191968/convert-export-json-to-csv\r\n\r\nBut the problem is that this method writes a row for each item in the array, needlessly repeating information.\r\n\r\nI am using the same type of command as the above answer, the only difference being the name of the columns, but the array blocks...\r\n\r\nFor instance, I could have a `JSON` file resembling:\r\n\r\n```JSON\r\n{resources:[\r\n    {&quot;id&quot;:&quot;001&quot;,&quot;name&quot;=&quot;Robert&quot;,&quot;items&quot;:[\r\n        {&quot;label&quot;:&quot;00A&quot;,&quot;name&quot;:&quot;Pen&quot;},\r\n        {&quot;label&quot;:&quot;00B&quot;,&quot;name&quot;:&quot;Paper&quot;}],\r\n    {&quot;id&quot;:&quot;002&quot;,&quot;name&quot;=&quot;Bruce&quot;,&quot;items&quot;:[\r\n        {&quot;label&quot;:&quot;00A&quot;,&quot;name&quot;:&quot;Pen&quot;},\r\n        {&quot;label&quot;:&quot;00B&quot;,&quot;name&quot;:&quot;Computer&quot;},\r\n        {&quot;label&quot;:&quot;00C&quot;,&quot;name&quot;:&quot;Headphones&quot;}]\r\n]\r\n}\r\n```\r\n\r\nThat I would like to become:\r\n```CSV\r\n001,Robert,Pen,Paper,\r\n002,Bruce,Pen,Computer,Headphones\r\n```\r\n\r\nI only need the `name` columns of the array\r\n\r\nFor the moment, the result is:\r\n```CSV\r\n001,Robert,Pen\r\n001,Robert,Paper\r\n002,Bruce,Pen,\r\n002,Bruce,Computer\r\n002,Bruce,Headphones\r\n```\r\n\r\nThe problem is the actual array is about 30 items long for each `JSON` object, making it impossible to use this way.\r\n",
        "link": "https://stackoverflow.com/questions/56671337/how-to-convert-a-json-array-to-a-csv-row",
        "title": "How to convert a JSON array to a CSV row?"
    },
    {
        "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": 1,
                "creation_date": 1560976427,
                "post_id": 56675409,
                "comment_id": 99918189,
                "content_license": "CC BY-SA 4.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": 3,
                "creation_date": 1560976450,
                "post_id": 56675409,
                "comment_id": 99918196,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1560987365,
                "last_edit_date": 1560987365,
                "creation_date": 1560976824,
                "answer_id": 56675530,
                "question_id": 56675409,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This code is broken *long* before the 3rd line.\r\n\r\n- If there isn&#39;t an outer array or object, you can&#39;t use `.[]`.\r\n- If your data type is an object and not a list, using `map()` on it throws away data (specifically, it discards the keys, leaving only the values).\r\n\r\n...so, `.[]` iterates over the *values* in your object, and then `map()` tries to iterate over each of those values as if it was an iterable object itself, which it&#39;s not... hence your error.\r\n\r\n---\r\n\r\nA version cut down to remove the broken parts might look like:\r\n\r\n```\r\na=&quot;google.com&quot; jq -r &#39;\r\nif (.host | contains(env.a)) then\r\n  [.&quot;ip.A&quot;,.&quot;ts&quot;,.&quot;ip.B&quot;] | @tsv\r\nelse\r\n  empty\r\nend\r\n&#39; &lt;&lt;&#39;EOF&#39;\r\n{\r\n  &quot;ts&quot;: &quot;2019-06-19T00:00:00.000000Z&quot;,\r\n  &quot;ip.A&quot;: &quot;0.0.0.0&quot;,\r\n  &quot;ip.B&quot;: &quot;0.0.0.0&quot;,\r\n  &quot;host&quot;: &quot;www.google.com&quot;\r\n}\r\nEOF\r\n```\r\n\r\n...which works fine.",
                "title": "jq command throws error &quot;cannot iterate over string&quot; when"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1560987365,
        "creation_date": 1560976160,
        "question_id": 56675409,
        "body_markdown": "I am writing a bash script utilizing jq to filter out JSON entries given some bash variables and return some of the key values from each entry into a tab-delimited file. I think the first few lines of this command are okay, but the 4th line I think is causing the problem. I have tried piping each entry in line 4 to tostring but to no avail. \r\n\r\n    info=`cat $FILE | jq -r \\\r\n\t\t&#39; .[] \\\r\n\t\t| map(select(.host| contains(env.A))) \\\r\n\t\t| [.&quot;ip.A&quot;,.&quot;ts&quot;,.&quot;ip.B&quot;] \\\r\n\t\t| @tsv&#39;`\r\nJSON example entry:\r\n\r\n    {\r\n      &quot;ts&quot;: &quot;2019-06-19T00:00:00.000000Z&quot;,\r\n      &quot;ip.A&quot;: &quot;0.0.0.0&quot;,\r\n      &quot;ip.B&quot;: &quot;0.0.0.0&quot;,\r\n      &quot;host&quot;: &quot;www.google.com&quot;,\r\n    }\r\nIn these files, there are no brackets surrounding the entire text within the file.\r\n\r\nError Given:\r\n\r\n    jq: error (at &lt;stdin&gt;:0): Cannot iterate over string (&quot;2019-06-18...)\r\nDo I need to handle &quot;.ts&quot; in some special way?",
        "link": "https://stackoverflow.com/questions/56675409/jq-command-throws-error-cannot-iterate-over-string-when",
        "title": "jq command throws error &quot;cannot iterate over string&quot; when"
    },
    {
        "tags": [
            "json",
            "unix",
            "curl",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8423,
                    "reputation": 757671,
                    "user_id": 15168,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/WtEI9.png?s=256",
                    "display_name": "Jonathan Leffler",
                    "link": "https://stackoverflow.com/users/15168/jonathan-leffler"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1560988591,
                "post_id": 56676743,
                "comment_id": 99921441,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1560984990,
                "last_edit_date": 1560984990,
                "creation_date": 1560984184,
                "answer_id": 56676813,
                "question_id": 56676743,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With jq:\r\n\r\n    | jq -r &#39;.password[]|.[0]&#39;\r\n\r\nOutput:\r\n&lt;pre&gt;\r\npasswordreal\r\n&lt;/pre&gt;\r\n\r\n---\r\nUse a tool that can safely handle JSON. sed is not one of them.",
                "title": "Using sed to get an exact value from a JSON response"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1560988417,
        "creation_date": 1560983714,
        "last_edit_date": 1560988417,
        "question_id": 56676743,
        "body_markdown": "I&#39;m getting this string data from `curl` command\r\n\r\n     {&quot;password&quot;: [[&quot;passwordreal&quot;, &quot;2035/01/01 00:00&quot;]], &quot;user&quot;: &quot;user1&quot;, &quot;address&quot;: &quot;kobebkokoko.net&quot;}\r\n\r\nHow do I get `passwordreal` using `sed`?\r\n\r\nFor example,\r\n\r\n    curl xxxx | sed -n &#39;/ *&quot;password&quot;&#39; =&gt; Been working on this long hours.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/56676743/using-sed-to-get-an-exact-value-from-a-json-response",
        "title": "Using sed to get an exact value from a JSON response"
    },
    {
        "tags": [
            "json",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1561028994,
                "creation_date": 1561028994,
                "answer_id": 56684707,
                "question_id": 56684251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest solution would probably be:\r\n\r\n    .image as $prefix\r\n    | .vulnerabilities[].description |= $prefix + &quot; - &quot; + .\r\n\r\nIn words: update all the `.description` values using .image as shown.\r\n\r\nEquivalently, and perhaps less esoterically:\r\n\r\n    .image as $prefix\r\n    | .vulnerabilities |= map(.description |= $prefix + &quot; - &quot; + .)\r\n",
                "title": "Concatenate nested fields"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1561049921,
        "creation_date": 1561027312,
        "last_edit_date": 1561049921,
        "question_id": 56684251,
        "body_markdown": "I&#39;m trying to concatenate two properties for a list of objects.\r\n\r\nInput\r\n-----\r\n\r\n    {\r\n        &quot;image&quot;: &quot;golang:1.3&quot;,\r\n        &quot;unapproved&quot;: [\r\n            &quot;CVE-2016-5421&quot;,\r\n            &quot;CVE-2019-5010&quot;\r\n        ],\r\n        &quot;vulnerabilities&quot;: [\r\n            {\r\n                &quot;featurename&quot;: &quot;curl&quot;,\r\n                &quot;featureversion&quot;: &quot;7.38.0-4+deb8u2&quot;,\r\n                &quot;vulnerability&quot;: &quot;CVE-2016-5421&quot;,\r\n                &quot;namespace&quot;: &quot;debian:8&quot;,\r\n                &quot;description&quot;: &quot;Use-after-free vulnerability in libcurl before 7.50.1 allows attackers to control which connection is used or possibly have unspecified other impact via unknown vectors.&quot;,\r\n                &quot;link&quot;: &quot;https://security-tracker.debian.org/tracker/CVE-2016-5421&quot;,\r\n                &quot;severity&quot;: &quot;High&quot;,\r\n                &quot;fixedby&quot;: &quot;7.38.0-4+deb8u4&quot;\r\n            },\r\n            {\r\n                &quot;featurename&quot;: &quot;python2.7&quot;,\r\n                &quot;featureversion&quot;: &quot;2.7.9-2&quot;,\r\n                &quot;vulnerability&quot;: &quot;CVE-2019-5010&quot;,\r\n                &quot;namespace&quot;: &quot;debian:8&quot;,\r\n                &quot;description&quot;: &quot;Test description&quot;,\r\n                &quot;link&quot;: &quot;https://security-tracker.debian.org/tracker/CVE-2019-5010&quot;,\r\n                &quot;severity&quot;: &quot;Unknown&quot;,\r\n                &quot;fixedby&quot;: &quot;&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nDesired output\r\n--------------\r\n\r\n&gt; The top-level `image` property should be used as a prefix for the\r\n&gt; `description` of every object in the `vulnerabilities` list.\r\n\r\n    {\r\n      &quot;image&quot;: &quot;golang:1.3&quot;,\r\n      &quot;unapproved&quot;: [\r\n        &quot;CVE-2016-5421&quot;,\r\n        &quot;CVE-2019-5010&quot;\r\n      ],\r\n      &quot;vulnerabilities&quot;: [\r\n        {\r\n          &quot;featurename&quot;: &quot;curl&quot;,\r\n          &quot;featureversion&quot;: &quot;7.38.0-4+deb8u2&quot;,\r\n          &quot;vulnerability&quot;: &quot;CVE-2016-5421&quot;,\r\n          &quot;namespace&quot;: &quot;debian:8&quot;,\r\n          &quot;description&quot;: &quot;golang:1.3 - Use-after-free vulnerability in libcurl before 7.50.1 allows attackers to control which connection is used or possibly have unspecified other impact via unknown vectors.&quot;,\r\n          &quot;link&quot;: &quot;https://security-tracker.debian.org/tracker/CVE-2016-5421&quot;,\r\n          &quot;severity&quot;: &quot;High&quot;,\r\n          &quot;fixedby&quot;: &quot;7.38.0-4+deb8u4&quot;\r\n        },\r\n        {\r\n          &quot;featurename&quot;: &quot;python2.7&quot;,\r\n          &quot;featureversion&quot;: &quot;2.7.9-2&quot;,\r\n          &quot;vulnerability&quot;: &quot;CVE-2019-5010&quot;,\r\n          &quot;namespace&quot;: &quot;debian:8&quot;,\r\n          &quot;description&quot;: &quot;golang:1.3 - Test description&quot;,\r\n          &quot;link&quot;: &quot;https://security-tracker.debian.org/tracker/CVE-2019-5010&quot;,\r\n          &quot;severity&quot;: &quot;Unknown&quot;,\r\n          &quot;fixedby&quot;: &quot;&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nCurrent attempt\r\n---------------\r\n\r\nMy current filter:\r\n\r\n    {image, unapproved, vulnerabilities: [{description: (.image + &quot; - &quot; + .vulnerabilities[].description)}] }\r\n\r\nOutput\r\n------\r\n\r\n    {\r\n      &quot;image&quot;: &quot;golang:1.3&quot;,\r\n      &quot;unapproved&quot;: [\r\n        &quot;CVE-2016-5421&quot;,\r\n        &quot;CVE-2019-5010&quot;\r\n      ],\r\n      &quot;vulnerabilities&quot;: [\r\n        {\r\n          &quot;description&quot;: &quot;golang:1.3 - Use-after-free vulnerability in libcurl before 7.50.1 allows attackers to control which connection is used or possibly have unspecified other impact via unknown vectors.&quot;\r\n        },\r\n        {\r\n          &quot;description&quot;: &quot;golang:1.3 - Test description&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n\r\nUnfortunately, I only get the `description` field back with my current filter. I want the full vulnerability object with the modified `description` field.\r\n\r\nQuestion\r\n--------\r\n\r\nHow can I concatenate the nested field and keep the other properties of the object too?\r\n\r\n[jqPlay][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/oKSyWG3ihn",
        "link": "https://stackoverflow.com/questions/56684251/concatenate-nested-fields",
        "title": "Concatenate nested fields"
    },
    {
        "tags": [
            "json",
            "select",
            "null",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 26,
                "is_accepted": true,
                "score": 26,
                "last_activity_date": 1561049823,
                "creation_date": 1561049823,
                "answer_id": 56690698,
                "question_id": 56690455,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to remove the `null` values from consideration would be:\r\n\r\n    .certificates[] | select(.variable_path | strings | test(&quot;thing&quot;))\r\n\r\n\r\nYou could also consider using `?`, which could be used here like this:\r\n\r\n    .certificates[] | select(.variable_path | test(&quot;thing&quot;)?)\r\n",
                "title": "JQ Select Objects Where Value Contains String And Value Not Null"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 11,
        "last_activity_date": 1561049823,
        "creation_date": 1561048669,
        "question_id": 56690455,
        "body_markdown": "Trying to select objects from JSON array where value contains a string and value is not null.\r\n\r\n\r\n\r\n\r\nDesired output:\r\n\r\n```\r\n    {\r\n      &quot;configurable&quot;: false,\r\n      &quot;property_reference&quot;: &quot;.properties.blobstore_certificate&quot;,\r\n      &quot;property_type&quot;: &quot;rsa_cert_credentials&quot;,\r\n      &quot;product_guid&quot;: &quot;p-blah-29d4678e926cf2069871&quot;,\r\n      &quot;location&quot;: &quot;ops_manager&quot;,\r\n      &quot;variable_path&quot;: &quot;something&quot;,\r\n      &quot;issuer&quot;: &quot;/C=US/O=Blah&quot;,\r\n      &quot;valid_from&quot;: &quot;2019-01-16T19:55:11Z&quot;,\r\n      &quot;valid_until&quot;: &quot;2021-01-16T19:55:11Z&quot;\r\n    }\r\n```\r\n\r\nWhen selecting from:\r\n\r\n```\r\n{\r\n  &quot;certificates&quot;: [\r\n    {\r\n      &quot;configurable&quot;: false,\r\n      &quot;property_reference&quot;: &quot;.properties.director_ssl&quot;,\r\n      &quot;property_type&quot;: &quot;rsa_cert_credentials&quot;,\r\n      &quot;product_guid&quot;: &quot;p-blah-29d4678e926cf2069871&quot;,\r\n      &quot;location&quot;: &quot;ops_manager&quot;,\r\n      &quot;variable_path&quot;: null,\r\n      &quot;issuer&quot;: &quot;/C=US/O=Blah&quot;,\r\n      &quot;valid_from&quot;: &quot;2019-01-16T19:55:10Z&quot;,\r\n      &quot;valid_until&quot;: &quot;2021-01-16T19:55:10Z&quot;\r\n    },\r\n    {\r\n      &quot;configurable&quot;: false,\r\n      &quot;property_reference&quot;: &quot;.properties.uaa_ssl&quot;,\r\n      &quot;property_type&quot;: &quot;rsa_cert_credentials&quot;,\r\n      &quot;product_guid&quot;: &quot;p-blah-29d4678e926cf2069871&quot;,\r\n      &quot;location&quot;: &quot;ops_manager&quot;,\r\n      &quot;variable_path&quot;: null,\r\n      &quot;issuer&quot;: &quot;/C=US/O=Blah&quot;,\r\n      &quot;valid_from&quot;: &quot;2019-01-16T19:55:10Z&quot;,\r\n      &quot;valid_until&quot;: &quot;2021-01-16T19:55:10Z&quot;\r\n    },\r\n    {\r\n      &quot;configurable&quot;: false,\r\n      &quot;property_reference&quot;: &quot;.properties.blobstore_certificate&quot;,\r\n      &quot;property_type&quot;: &quot;rsa_cert_credentials&quot;,\r\n      &quot;product_guid&quot;: &quot;p-blah-29d4678e926cf2069871&quot;,\r\n      &quot;location&quot;: &quot;ops_manager&quot;,\r\n      &quot;variable_path&quot;: &quot;something&quot;,\r\n      &quot;issuer&quot;: &quot;/C=US/O=Blah&quot;,\r\n      &quot;valid_from&quot;: &quot;2019-01-16T19:55:11Z&quot;,\r\n      &quot;valid_until&quot;: &quot;2021-01-16T19:55:11Z&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nUsing:\r\n\r\n```\r\ncurl blah | jq &#39; .certificates[] | select(.variable_path|test(&quot;thing&quot;))&#39;\r\n```\r\n\r\nGetting:\r\n```\r\njq: error (at &lt;stdin&gt;:0): null (null) cannot be matched, as it is not a string\r\n```\r\n\r\nI think the issue is that there are nulls. I am not sure how to select with the presence of these nulls without getting the error.",
        "link": "https://stackoverflow.com/questions/56690455/jq-select-objects-where-value-contains-string-and-value-not-null",
        "title": "JQ Select Objects Where Value Contains String And Value Not Null"
    },
    {
        "tags": [
            "json",
            "null",
            "jq",
            "key-value",
            "jsonlines"
        ],
        "answers": [
            {
                "up_vote_count": 22,
                "is_accepted": true,
                "score": 22,
                "last_activity_date": 1561068397,
                "creation_date": 1561068397,
                "answer_id": 56694468,
                "question_id": 56692037,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The tricky part here is emitting the keys without quotation marks in a way that the empty string is shown with quotation marks.  Here is one solution that works with jq&#39;s -r command-line option:\r\n\r\n    to_entries[]\r\n    | select(.value | . == null or . == &quot;&quot;)\r\n    | if .value == &quot;&quot; then .value |= &quot;\\&quot;\\(.)\\&quot;&quot; else . end\r\n    | &quot;\\(.key): \\(.value)&quot;\r\n\r\nOnce the given input has been modified in the obvious way to make it valid JSON, the output is exactly as specified.\r\n",
                "title": "Filter empty and/or null values with jq"
            },
            {
                "up_vote_count": 14,
                "is_accepted": false,
                "score": 14,
                "last_activity_date": 1620032973,
                "last_edit_date": 1620032973,
                "creation_date": 1620032256,
                "answer_id": 67366098,
                "question_id": 56692037,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Some people may find the following jq program more useful for identifying keys with null or empty string values:\r\n\r\n    with_entries(select(.value |.==null or . == &quot;&quot;))\r\n\r\nWith the sample input, this program would produce:\r\n\r\n    {&quot;available&quot;:&quot;&quot;}\r\n    {&quot;color&quot;:null}\r\n\r\nAdding further information, such as the input line or object number, would also make sense, e.g. perhaps:\r\n\r\n    with_entries(select(.value |.==null or . == &quot;&quot;))\r\n    | select(length&gt;0)\r\n    | {n: input_line_number} + .\r\n\r\n\r\n",
                "title": "Filter empty and/or null values with jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1685450339,
                "last_edit_date": 1685450339,
                "creation_date": 1663936415,
                "answer_id": 73827807,
                "question_id": 56692037,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With a single `with_entries(if .value == null or .value == &quot;&quot; then empty else . end)` filter expression it&#39;s possible to filter out `null` and empty (`&quot;&quot;`) values.\r\n\r\nWithout filtering:\r\n\r\n    echo &#39;{&quot;foo&quot;: null, &quot;bar&quot;: &quot;&quot;}&#39; | jq &#39;.&#39;\r\n    {\r\n      &quot;foo&quot;: null,\r\n      &quot;bar&quot;: &quot;&quot;\r\n    }\r\n\r\nWith filtering:\r\n\r\n    echo &#39;{&quot;foo&quot;: null, &quot;bar&quot;: &quot;&quot;}&#39; |  jq &#39;with_entries(if .value == null or .value == &quot;&quot; then empty else . end)&#39;\r\n    {}\r\n\r\n",
                "title": "Filter empty and/or null values with jq"
            },
            {
                "up_vote_count": 24,
                "is_accepted": false,
                "score": 24,
                "last_activity_date": 1674655374,
                "creation_date": 1674655374,
                "answer_id": 75235139,
                "question_id": 56692037,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Take a look at this snippet https://blog.nem.ec/code-snippets/jq-ignore-nulls/\r\n\r\n    jq -r &#39;.firstName | select( . != null )&#39; file.json",
                "title": "Filter empty and/or null values with jq"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1694098099,
                "creation_date": 1694098099,
                "answer_id": 77060651,
                "question_id": 56692037,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `select(.)` to filter out the nulls",
                "title": "Filter empty and/or null values with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 33,
        "last_activity_date": 1694098099,
        "creation_date": 1561055858,
        "last_edit_date": 1620032345,
        "question_id": 56692037,
        "body_markdown": "I have a file with jsonlines and would like to find empty values.\r\n\r\n    {&quot;name&quot;: &quot;Color TV&quot;, &quot;price&quot;: &quot;1200&quot;, &quot;available&quot;: &quot;&quot;}\r\n    {&quot;name&quot;: &quot;DVD player&quot;, &quot;price&quot;: &quot;200&quot;, &quot;color&quot;: null}\r\n\r\nAnd would like to output empty and/or null values and their keys:\r\n\r\n    available: &quot;&quot;\r\n    color: null\r\n\r\nI think it should be something like `cat myexample | jq &#39;. | select(. == &quot;&quot;)&#39;`, but is not working.",
        "link": "https://stackoverflow.com/questions/56692037/filter-empty-and-or-null-values-with-jq",
        "title": "Filter empty and/or null values with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1561106673,
                "creation_date": 1561106673,
                "answer_id": 56699864,
                "question_id": 56699742,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq has a `from_entries` function that expects an array of `{key, value}` objects and produces an object. Thus, you can transform your &quot;key 3&quot; value into such an array and produce an object like so:\r\n\r\n`.&quot;key 3&quot; | map({key: .a, value: .v} | from_entries`\r\n\r\nPutting that together with a map that just copies the two other keys:\r\n\r\n`map({key1, key2} + (.&quot;key 3&quot; | map({key: .a, value: .v}) | from_entries))`",
                "title": "Flatten array of key-value pairs into object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1561110952,
                "last_edit_date": 1561110952,
                "creation_date": 1561110507,
                "answer_id": 56700939,
                "question_id": 56699742,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to avoid having to specify the keys to retain, you could go with:\r\n\r\n    map( .\r\n         + (.&quot;key 3&quot; | map( {(.a): .v} ) | add )\r\n         | del(.&quot;key 3&quot;) )\r\n\r\n\r\nThat is, add in the new key-value pairs, and then delete &quot;key 3&quot;. Notice also that `add` has been used here instead of `from_entries`, making for a more succinct and perhaps more straightforward solution.",
                "title": "Flatten array of key-value pairs into object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1561110952,
        "creation_date": 1561106160,
        "last_edit_date": 1561106959,
        "question_id": 56699742,
        "body_markdown": "I&#39;ve got very little experience with JSON and jq and am struggling to reformat my JSON objects. Each object contains a couple of key/value pairs and an array of objects. I&#39;m trying to resturcture each object so that it&#39;s just a list of key/value pairs (i.e. extract the objects in the array).\r\n\r\n    [\r\n       {\r\n          &quot;key1&quot;:&quot;value1&quot;,\r\n          &quot;key2&quot;:&quot;value2&quot;,\r\n          &quot;key 3&quot;:[\r\n             {\r\n                &quot;a&quot;:&quot;key_to_be_extracted_1&quot;,\r\n                &quot;v&quot;:&quot;value_to_be_extracted_1&quot;\r\n             },\r\n             {\r\n                &quot;a&quot;:&quot;key_to_be_extracted_2&quot;,\r\n                &quot;v&quot;:&quot;value_to_be_extracted_2&quot;\r\n             }\r\n          ]\r\n       },\r\n       {\r\n          &quot;key1&quot;:&quot;value1&quot;,\r\n          &quot;key2&quot;:&quot;value2&quot;,\r\n          &quot;key 3&quot;:[\r\n             {\r\n                &quot;a&quot;:&quot;key_to_be_extracted_1&quot;,\r\n                &quot;v&quot;:&quot;value_to_be_extracted_1&quot;\r\n             },\r\n             {\r\n                &quot;a&quot;:&quot;key_to_be_extracted_2&quot;,\r\n                &quot;v&quot;:&quot;value_to_be_extracted_2&quot;\r\n             }\r\n          ]\r\n       }\r\n    ]\r\n\r\nWhat I&#39;m trying to get to is:\r\n\r\n    [\r\n       {\r\n          &quot;key1&quot;:&quot;value1&quot;,\r\n          &quot;key2&quot;:&quot;value2&quot;,\r\n          &quot;key_to_be_extracted_1&quot;:&quot;value_to_be_extracted_1&quot;,\r\n          &quot;key_to_be_extracted_2&quot;:&quot;value_to_be_extracted_2&quot;\r\n       },\r\n       {\r\n          &quot;key1&quot;:&quot;value1&quot;,\r\n          &quot;key2&quot;:&quot;value2&quot;,\r\n          &quot;key_to_be_extracted_1&quot;:&quot;value_to_be_extracted_1&quot;,\r\n          &quot;key_to_be_extracted_2&quot;:&quot;value_to_be_extracted_2&quot;\r\n       }\r\n    ]\r\n\r\nAny help with this would be amazing!! ",
        "link": "https://stackoverflow.com/questions/56699742/flatten-array-of-key-value-pairs-into-object",
        "title": "Flatten array of key-value pairs into object"
    },
    {
        "tags": [
            "json",
            "group-by",
            "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": 1561126864,
                "post_id": 56701545,
                "comment_id": 99973910,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1561129950,
                "last_edit_date": 1561129950,
                "creation_date": 1561126714,
                "answer_id": 56705205,
                "question_id": 56701545,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The filter you&#39;re evidently looking for is simpler than you might think:\r\n\r\n    group_by(.group_key)\r\n    | map( {new_key1: .[0].group_key,\r\n            new_key2: .} )\r\n\r\n",
                "title": "Combining JSON arrays with the same key value pair with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1561129950,
        "creation_date": 1561112582,
        "last_edit_date": 1561129840,
        "question_id": 56701545,
        "body_markdown": "Thanks to the folks who helped with my last jq newbie question and got me to an array of objects:\r\n\r\n    [\r\n      {\r\n        &quot;any_key&quot;:&quot;any_value&quot;,\r\n        &quot;group_key&quot;:&quot;group_val1&quot;\r\n      },\r\n      {\r\n        &quot;any_key&quot;:&quot;any_value&quot;,\r\n        &quot;group_key&quot;:&quot;group_val1&quot;\r\n      },\r\n      {\r\n        &quot;any_key&quot;:&quot;any_value&quot;,\r\n        &quot;group_key&quot;:&quot;group_val2&quot;\r\n      },\r\n      {\r\n        &quot;any_key&quot;:&quot;any_value&quot;,\r\n        &quot;group_key&quot;:&quot;group_val2&quot;\r\n      }\r\n    ]\r\n\r\nI&#39;ve changed the keys and values from the previous question to try and help explain where I&#39;m trying to go with this.\r\n\r\nI&#39;m now trying to group the objects based on the value of a shared key. Then, for each array of grouped objects, create a new object where the array is the value of a new key.\r\n\r\nI tried grouping with &quot;group_by&quot;, but it&#39;s still a fair way from where I&#39;m trying to get to and I&#39;m pretty certain I&#39;m missing some key concepts from jq.\r\n\r\n    [\r\n      [\r\n        {\r\n          &quot;any_key&quot;:&quot;any_value&quot;,\r\n          &quot;group_key&quot;:&quot;group_val1&quot;\r\n        },\r\n        {\r\n          &quot;any_key&quot;:&quot;any_value&quot;,\r\n          &quot;group_key&quot;:&quot;group_val1&quot;\r\n        }\r\n      ]\r\n    ]\r\n    [\r\n      [\r\n        {\r\n          &quot;any_key&quot;:&quot;any_value&quot;,\r\n          &quot;group_key&quot;:&quot;group_val2&quot;\r\n        },\r\n        {\r\n          &quot;any_key&quot;:&quot;any_value&quot;,\r\n          &quot;group_key&quot;:&quot;group_val2&quot;\r\n        }\r\n      ]\r\n    ]\r\n\r\nThis is where I&#39;m trying (painfully) to get to:\r\n\r\n    [\r\n      {\r\n        &quot;new_key1&quot;:&quot;group_val1&quot;,\r\n        &quot;new_key2&quot;:[\r\n          {\r\n            &quot;any_key&quot;:&quot;any_value&quot;,\r\n            &quot;group_key&quot;:&quot;group_val1&quot;\r\n          },\r\n          {\r\n            &quot;any_key&quot;:&quot;any_value&quot;,\r\n            &quot;group_key&quot;:&quot;group_val1&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;new_key1&quot;:&quot;group_val2&quot;,\r\n        &quot;new_key2&quot;:[\r\n          {\r\n            &quot;any_key&quot;:&quot;any_value&quot;,\r\n            &quot;group_key&quot;:&quot;group_val1&quot;\r\n          },\r\n          {\r\n            &quot;any_key&quot;:&quot;any_value&quot;,\r\n            &quot;group_key&quot;:&quot;group_val2&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nNot sure I&#39;ve explained this very clearly...sorry! But any help would be very, very much appreciated!\r\n",
        "link": "https://stackoverflow.com/questions/56701545/combining-json-arrays-with-the-same-key-value-pair-with-jq",
        "title": "Combining JSON arrays with the same key value pair with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "key-value"
        ],
        "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": 1,
                "creation_date": 1561120063,
                "post_id": 56701692,
                "comment_id": 99970067,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1561122532,
                "post_id": 56701692,
                "comment_id": 99971406,
                "content_license": "CC BY-SA 4.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": 1561126950,
                "post_id": 56701692,
                "comment_id": 99973962,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16178550,
                    "reputation": 3,
                    "user_id": 11680638,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/592caca521dd5fe24481cd4b26f788e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jasonYardley",
                    "link": "https://stackoverflow.com/users/11680638/jasonyardley"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1561131371,
                "post_id": 56701692,
                "comment_id": 99976311,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1561121289,
                "creation_date": 1561121289,
                "answer_id": 56703774,
                "question_id": 56701692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use **to_entries** filter for that.\r\n\r\n[Here is jqplay example](https://jqplay.org/s/7P7Rh5w5-a)\r\n",
                "title": "transform json to add array objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1561138358,
                "last_edit_date": 1561138358,
                "creation_date": 1561137947,
                "answer_id": 56708005,
                "question_id": 56701692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your input is not json, it&#39;s just a bunch of what could be thought of as key/value pairs. Assuming your json input actually looked like this:\r\n\r\n    {\r\n        &quot;user_id&quot;: &quot;testuser&quot;,\r\n        &quot;auth_token&quot;: &quot;abcd&quot;\r\n    }\r\n\r\nYou could get an array of key/value pair objects using `to_entries`.\r\n\r\n    $ jq &#39;to_entries&#39; input.json\r\n    [\r\n        {\r\n            &quot;key&quot;: &quot;user_id&quot;,\r\n            &quot;value&quot;: &quot;testuser&quot;\r\n        },\r\n        {\r\n            &quot;key&quot;: &quot;auth_token&quot;,\r\n            &quot;value&quot;: &quot;abcd&quot;\r\n        }\r\n    ]\r\n\r\n&lt;hr&gt;\r\n\r\nIf on the other hand your input was actually that, you would need to convert it to a format that can be processed. Fortunately you could read it in as a raw string and probably parse using regular expressions or basic string manipulation.\r\n\r\n    $ jq -Rn &#39;[inputs|capture(&quot;\\&quot;(?&lt;key&gt;[^\\&quot;]+)\\&quot;:\\&quot;(?&lt;value&gt;[^\\&quot;]*)\\&quot;&quot;)]&#39; input.txt\r\n\r\n&lt;!-- --&gt;\r\n\r\n    $ jq -Rn &#39;[inputs|split(&quot;:&quot;)|map(fromjson)|{key:.[0],value:.[1]}]&#39; input.txt",
                "title": "transform json to add array objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1561183892,
                "creation_date": 1561183892,
                "answer_id": 56713063,
                "question_id": 56701692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Robust conversion of `key:value` lines to JSON.\r\n\r\nIf the `key:value` specifications would be valid JSON except for the\r\nmissing punctuation (opening and closing braces etc), then a simple and quite robust approach to converting these key:value pairs to a single valid JSON object is illustrated by the following:\r\n\r\n    cat &lt;&lt;EOF | jq -nc -R &#39;[&quot;{&quot; + inputs + &quot;}&quot; | fromjson] | add&#39; \r\n    &quot;user_id&quot;: &quot;testuser&quot;\r\n    &quot;auth_token&quot; : &quot;abcd&quot;\r\n    EOF\r\n\r\n### Output\r\n\r\n    {\r\n      &quot;user_id&quot;: &quot;testuser&quot;,\r\n      &quot;auth_token&quot;: &quot;abcd&quot;\r\n    }\r\n\r\n\r\n",
                "title": "transform json to add array objects"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1561196513,
        "creation_date": 1561113127,
        "last_edit_date": 1561196513,
        "question_id": 56701692,
        "body_markdown": "I need to transform an array by adding additional objects -\r\n\r\n**I have:**\r\n\r\n    &quot;user_id&quot;:&quot;testuser&quot;\r\n    &quot;auth_token&quot;:&quot;abcd&quot;\r\n\r\n**I need:**\r\n\r\n    &quot;key&quot;:&quot;user_id&quot;\r\n    &quot;value&quot;:&quot;testuser&quot;\r\n    &quot;key&quot;:&quot;auth_token&quot;\r\n    &quot;value&quot;:&quot;abcd&quot;\r\n\r\nI have been using `jq` but cant figure out how to do it. Do i need to transform this into a `multi-dimensional` array first?\r\n\r\nI have tried multiple `jq` queries but cant find the most suitable\r\n\r\nWhen i try using `jq` i get \r\n\r\n&gt; jq: error: syntax error, unexpected $end, expecting QQSTRING_TEXT or QQSTRING_INTERP_START or QQSTRING_END (Unix shell quoting issues?) at &lt;top-level&gt;, line 1",
        "link": "https://stackoverflow.com/questions/56701692/transform-json-to-add-array-objects",
        "title": "transform json to add array objects"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1561174087,
                "last_edit_date": 1561174087,
                "creation_date": 1561171863,
                "answer_id": 56712222,
                "question_id": 56712193,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`contains` is quite tricky to use correctly. Since the requirement is:\r\n\r\n&gt; to capture only those ids who have dummy value of &quot;This is dummy&quot;\r\n\r\nI would suggest:\r\n\r\n    .[]\r\n    | select( any(.[]; .dummy == &quot;This is dummy&quot;) )\r\n    | add\r\n    | .id\r\n\r\nor perhaps (depending on your detailed requirements):\r\n\r\n    .[]\r\n    | select( any(.[]; .dummy == &quot;This is dummy&quot;) )\r\n    | .[]\r\n    | .id? // empty\r\n\r\n",
                "title": "Extract inner array matching values using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1561174087,
        "creation_date": 1561171274,
        "question_id": 56712193,
        "body_markdown": "My json is as shown below:\r\n\r\n    [\r\n    [\r\n        {\r\n            &quot;id&quot;: &quot;abcd&quot;\r\n        },\r\n        {\r\n            &quot;address&quot;: [\r\n                &quot;140 Deco st&quot;\r\n            ]\r\n        }\r\n    ],\r\n    [\r\n        {\r\n            &quot;id&quot;: &quot;xyz&quot;\r\n        },\r\n        {\r\n            &quot;dummy&quot;: &quot;This is dummy&quot;\r\n        }\r\n    ],\r\n    [\r\n        {\r\n            &quot;id&quot;: &quot;12356&quot;\r\n        },\r\n        {\r\n            &quot;address&quot;: [\r\n                &quot;140 Deco st&quot;\r\n            ]\r\n        }\r\n    ]]\r\n\r\nNow, I want to capture only those ids who have dummy value of &quot;This is dummy&quot;. Some of the data may or may not have dummy and address fields.\r\n\r\nI tried below but it gave me error &quot;... cannot have their containment checked&quot;\r\n\r\n    jq -c &#39;.[] | .[] | select(.dummy | contains(&quot;This is dummy&quot;)) | .[] | .id&#39;\r\n\r\nAny help is much appreciated!\r\n",
        "link": "https://stackoverflow.com/questions/56712193/extract-inner-array-matching-values-using-jq",
        "title": "Extract inner array matching values using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1561212887,
                "post_id": 56716155,
                "comment_id": 99994297,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1561213496,
                "post_id": 56716155,
                "comment_id": 99994409,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6615151,
                    "reputation": 7799,
                    "user_id": 5108695,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/4OG0U.jpg?s=256",
                    "display_name": "Dupinder Singh",
                    "link": "https://stackoverflow.com/users/5108695/dupinder-singh"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1561214266,
                "post_id": 56716155,
                "comment_id": 99994565,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1707439,
                    "reputation": 242707,
                    "user_id": 1566221,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/ce3ea4ffd1023d4382f397312352726d?s=256&d=identicon&r=PG",
                    "display_name": "rici",
                    "link": "https://stackoverflow.com/users/1566221/rici"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1561220202,
                "post_id": 56716155,
                "comment_id": 99995968,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6615151,
                    "reputation": 7799,
                    "user_id": 5108695,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/4OG0U.jpg?s=256",
                    "display_name": "Dupinder Singh",
                    "link": "https://stackoverflow.com/users/5108695/dupinder-singh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1561220607,
                "post_id": 56716155,
                "comment_id": 99996063,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1707439,
                    "reputation": 242707,
                    "user_id": 1566221,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/ce3ea4ffd1023d4382f397312352726d?s=256&d=identicon&r=PG",
                    "display_name": "rici",
                    "link": "https://stackoverflow.com/users/1566221/rici"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1561221248,
                "post_id": 56716155,
                "comment_id": 99996225,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1602355934,
                "last_edit_date": 1602355934,
                "creation_date": 1561220672,
                "answer_id": 56717178,
                "question_id": 56716155,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This looks to me like an instance of Windows/Unix line-ending incompatibility, indicated in jq bugs [92 (for Cygwin)][1] and [1870 (for MSYS2)][2].\r\n\r\nAny of the workarounds indicated in those bug reports should work, but once the fix gets into the release binary (presumably v1.7), the simplest solution is to use the new `-b` command-line option. (The option is available in recent jq preview builds; see the second bug report listed above):\r\n\r\n    for key in $(jq -b &#39;.issues | keys | .[]&#39; sonar-report.json); do\r\n        line=$(jq -rb &quot;.issues[$key].line&quot; sonar-report.json)\r\n        # I added quotes in the next line, because it&#39;s better style.\r\n        echo &quot;$line&quot;\r\n    done\r\n\r\nUntil the next version of `jq` is available, or if you don&#39;t want to upgrade for some reason, a good workaround is to just remove the CRs by piping the output of `jq` through `tr -d &#39;\\r&#39;`:\r\n\r\n    for key in $(jq -&#39;.issues | keys | .[]&#39; sonar-report.json | tr -d &#39;\\r&#39;); do\r\n        line=$(jq -r &quot;.issues[$key].line&quot; sonar-report.json | tr -d &#39;\\r&#39;)\r\n        echo &quot;$line&quot;\r\n    done\r\n\r\n\r\nHowever, as pointed out in a comment by Cyrus, you probably don&#39;t need to iterate line-by-line in a shell loop, which is incredibly inefficient since it leads to reparsing the entire JSON input many times. You can use jq itself to iterate, with the much simpler:\r\n\r\n    jq &#39;.issues[].line&#39; solar-response.json\r\n\r\nwhich will parse the JSON file just once, and then produce each `.line` value in the file. (You probably still want to use the `-b` command-line option or other workaround, depending on what you intend to do with the output.)\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/92\r\n  [2]: https://github.com/stedolan/jq/issues/1870",
                "title": "shell script parsing issue: unexpected INVALID_CHARACTER (Windows cmd shell quoting issues?)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1602355934,
        "creation_date": 1561212704,
        "last_edit_date": 1561213175,
        "question_id": 56716155,
        "body_markdown": "***What I am doing?***\r\nI have one JSON file as sonar-report.json. I want to iterate sonar-report.json in shell script, to read values of json.\r\nTo parse JSON file I am using jq https://stedolan.github.io/jq/\r\n\r\n\r\nSo Following code I was trying to execute in shell script\r\n\r\n    alias jq=./jq-win64.exe\r\n    for key in $(jq &#39;.issues | keys | .[]&#39; sonar-report.json); do\r\n    \techo &quot;$key&quot;\r\n    \tline=$(jq -r &quot;.issues[$key].line&quot; sonar-report.json)\r\n    done\r\n\r\n\r\n***Problem***\r\nWhen i execute this, console give me error:\r\n\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\n\r\n\r\nIf I update my above script, and add static index of array then script works fine\r\n\r\n    alias jq=./jq-win64.exe\r\n    \r\n    for key in $(jq &#39;.issues | keys | .[]&#39; sonar-report.json); do\r\n    \techo &quot;$key&quot;\r\n    \tline0=$(jq -r &quot;.issues[0].line&quot; sonar-report.json)\r\n        line1=$(jq -r &quot;.issues[1].line&quot; sonar-report.json)\r\n    done\r\n\r\n***so at the end what i want :***\r\nI want to iterate values and print in console like\r\n\r\n\r\n    alias jq=./jq-win64.exe\r\n    for key in $(jq &#39;.issues | keys | .[]&#39; sonar-report.json); do\r\n    \tline=$(jq -r &quot;.issues[$key].line&quot; sonar-report.json)\r\n        echo $line\r\n    done\r\n\r\nso the output should be \r\n\r\n    15\r\n\r\nThis is my JSON file as sonar-report.json\r\n\r\n    {\r\n    &quot;issues&quot;: [\r\n            {\r\n                &quot;key&quot;: &quot;016B7970D27939AEBD&quot;,\r\n                &quot;component&quot;: &quot;bits-and-bytes:src/main/java/com/catalystone/statusreview/handler/StatusReviewDecisionLedHandler.java&quot;,\r\n                &quot;line&quot;: 15,\r\n                &quot;startLine&quot;: 15,\r\n                &quot;startOffset&quot;: 12,\r\n                &quot;endLine&quot;: 15,\r\n                &quot;endOffset&quot;: 14,\r\n                &quot;message&quot;: &quot;Use the \\&quot;equals\\&quot; method if value comparison was intended.&quot;,\r\n                &quot;severity&quot;: &quot;MAJOR&quot;,\r\n                &quot;rule&quot;: &quot;squid:S4973&quot;,\r\n                &quot;status&quot;: &quot;OPEN&quot;,\r\n                &quot;isNew&quot;: true,\r\n                &quot;creationDate&quot;: &quot;2019-06-21T15:19:18+0530&quot;\r\n            },\r\n            {\r\n                &quot;key&quot;: &quot;AWtqCc-jtovxS8PJjBiP&quot;,\r\n                &quot;component&quot;: &quot;bits-and-bytes:src/test/java/com/catalystone/statusreview/service/StatusReviewInitiationSerivceTest.java&quot;,\r\n                &quot;message&quot;: &quot;Fix failing unit tests on file \\&quot;src/test/java/com/catalystone/statusreview/service/StatusReviewInitiationSerivceTest.java\\&quot;.&quot;,\r\n                &quot;severity&quot;: &quot;MAJOR&quot;,\r\n                &quot;rule&quot;: &quot;common-java:FailedUnitTests&quot;,\r\n                &quot;status&quot;: &quot;OPEN&quot;,\r\n                &quot;isNew&quot;: false,\r\n                &quot;creationDate&quot;: &quot;2019-06-18T15:32:08+0530&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\n\r\nplease help me, Thanks in advance",
        "link": "https://stackoverflow.com/questions/56716155/shell-script-parsing-issue-unexpected-invalid-character-windows-cmd-shell-quot",
        "title": "shell script parsing issue: unexpected INVALID_CHARACTER (Windows cmd shell quoting issues?)"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1561258784,
                "last_edit_date": 1561258784,
                "creation_date": 1561257554,
                "answer_id": 56720615,
                "question_id": 56720304,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I&#39;ve been scratching my head at this for a few days now\r\n\r\nYou&#39;ll probably feel like pulling some hair out when you see how close you got.  Basically, you just need an extra pair of parentheses:\r\n\r\n    (.[0] | {FirstItem1: .[0].items[0].firstitem1}) + \r\n    (.[1] | {seconditem: .[0].items[0].seconditem1})\r\n\r\nExcept you probably meant &quot;SecondItem1&quot; for the second key name.\r\n\r\n## An alternative\r\nHere&#39;s a less repetitive solution that might be worth considering:\r\n\r\n    [.[][] | .items[0]]\r\n    | {FirstItem1: first(.[0][]), SecondItem1: first(.[1][])}\r\n",
                "title": "Nested arrays, combining multiple filters using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1561258784,
        "creation_date": 1561252200,
        "last_edit_date": 1561252899,
        "question_id": 56720304,
        "body_markdown": "I have some JSON that includes nested arrays for each thing I&#39;m trying to collect.\r\n\r\nI&#39;ve distilled it here:\r\n\r\n```JSON\r\n[\r\n    [\r\n        {\r\n            &quot;Item&quot;:&quot;FIRST&quot;,\r\n            &quot;items&quot;:[\r\n                        {\r\n                            &quot;firstitem1&quot;:&quot;Item 1&quot;,\r\n                            &quot;firstitem2&quot;:&quot;Item 2&quot;\r\n                        }\r\n                    ]\r\n        }\r\n    ],\r\n    [\r\n        {\r\n            &quot;Item&quot;:&quot;SECOND&quot;,\r\n            &quot;items&quot;:[\r\n                        {\r\n                            &quot;seconditem1&quot;:&quot;Second Item 1&quot;,\r\n                            &quot;seconditem2&quot;:&quot;Second Item 2&quot;\r\n                        }\r\n                    ]\r\n        }\r\n    ]\r\n]\r\n```\r\nThe desired output would look like:\r\n```json\r\n{\r\n  &quot;FirstItem1&quot;: &quot;Item 1&quot;,\r\n  &quot;SecondItem1&quot;: &quot;Second Item 1&quot;\r\n}\r\n```\r\nI can return each item individually by using\r\n```json\r\n.[0] | {FirstItem1: .[0].items[0].firstitem1}\r\n```\r\n```json\r\n.[1] | {seconditem: .[0].items[0].seconditem1}\r\n```\r\nI found a similar problem which explains that you can concatenate filters using something like filter + (filter) :\r\n[Multiple filters using JQ][1]\r\n\r\n\r\nHowever, while both of my filters above work independantly, when I concatenate them in this way:\r\n```json\r\n.[0] | {FirstItem1: .[0].items[0].firstitem1} + (.[1] | {seconditem: .[0].items[0].seconditem1})\r\n```\r\nI get &#39;null&#39; for my second response.\r\n```json\r\n{\r\n  &quot;FirstItem1&quot;: &quot;Item 1&quot;,\r\n  &quot;seconditem&quot;: null\r\n}\r\n\r\n```\r\nI&#39;ve been scratching my head at this for a few days now, any ideas? I&#39;d appreciate the nudge if I should attack this differently.\r\n\r\nHere&#39;s a jqplay link\r\n[https://jqplay.org/s/By94hv9gKj][2]\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/30768196/multiple-filters-using-jq\r\n  [2]: https://jqplay.org/s/By94hv9gKj",
        "link": "https://stackoverflow.com/questions/56720304/nested-arrays-combining-multiple-filters-using-jq",
        "title": "Nested arrays, combining multiple filters using JQ"
    }
]