[
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1673431341,
                "creation_date": 1673431341,
                "answer_id": 75081249,
                "question_id": 75081092,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n``` sh\r\njq -r &#39;.[].instance | split(&quot;/&quot;) | &quot;\\(.[-1]) \\(.[-3])&quot;&#39;\r\n```",
                "title": "Select multiple values from a split string in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1673433202,
        "creation_date": 1673430570,
        "last_edit_date": 1673433202,
        "question_id": 75081092,
        "body_markdown": "I see questions about selecting multiple values from an array using JQ, but I have a string that originally I just need the value after the last `/`, which is easily selected:\r\n\r\nInput:\r\n``` none\r\nhttps://www.googleapis.com/compute/v1/projects/test-project-1/zones/europe-west1-b/instanceGroups/test-instance-group-1\r\n```\r\n\r\nJQ:\r\n``` sh\r\njq -r &#39;.[]|.zone|=split(&quot;/&quot;)[-1]|&quot;\\(.name) \\(.zone)&quot;&#39;\r\n```\r\n\r\nOutput:\r\n``` none\r\ntest-instance-group-1 europe-west1-b\r\n```\r\n\r\nHowever for the actual instances, the zone isn&#39;t listed, so must be extracted from the same key `instance`.\r\n\r\nInput:\r\n``` none\r\nhttps://www.googleapis.com/compute/v1/projects/test-project-1/zones/europe-west1-b/instances/test-instance-1\r\n```\r\n\r\nJQ:\r\n``` sh\r\njq -r &#39;.[]|.instance|=split(&quot;/&quot;)[-1]|&quot;\\(.instance)&#39;\r\n```\r\n\r\nOutput:\r\n``` none\r\ntest-instance-1\r\n```\r\n\r\nHowever, I also want to extract the zone infomation, from the input as well, which I presume is selected with `=split(&quot;/&quot;)[-3]` however no matter how I format the request to JQ, I get errors:\r\n\r\n``` none\r\n$ jq -r &#39;.[]|.instance|=split(&quot;/&quot;)[-1][-3]|&quot;\\(.instance)&quot;&#39;\r\njq: error (at &lt;stdin&gt;:47): Cannot index string with number\r\n```\r\n\r\nHow can I extract two strings, from the same value/key ?",
        "link": "https://stackoverflow.com/questions/75081092/select-multiple-values-from-a-split-string-in-jq",
        "title": "Select multiple values from a split string in JQ"
    },
    {
        "tags": [
            "linux",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1673437105,
                "creation_date": 1673437105,
                "answer_id": 75082443,
                "question_id": 75082410,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming this is bash, you are missing a dollar sign on this line:\r\n\r\n    echo $version\r\n\r\nso you are printing a string instead of referring to a variable.",
                "title": "jq doesn&#39;t grab correct file in a json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1673437105,
        "creation_date": 1673436970,
        "question_id": 75082410,
        "body_markdown": "I have a package.json \r\n\r\n```\r\n{\r\n   version: &quot;1.0.0&quot;,\r\n}\r\n```\r\n\r\nAnd below is my content \r\n\r\n```\r\nversion=$(jq -r &#39;.version&#39; package.json)\r\n\r\necho version\r\n\r\n```\r\n\r\nof my bash.sh file, but I couldn&#39;t get the &#39;1.0.0&#39;, I got `version` printed on my terminal, any clue why?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75082410/jq-doesnt-grab-correct-file-in-a-json",
        "title": "jq doesn&#39;t grab correct file in a json"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673445295,
                "post_id": 75083362,
                "comment_id": 132500572,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1673441966,
                "creation_date": 1673441966,
                "answer_id": 75083443,
                "question_id": 75083362,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should `group_by` to group all the matching `source_id`. \r\n\r\nThen you can create the desired output, for example:\r\n```none\r\ngroup_by(.source_id)[] | { ip: map(.ip), source_id: (first.source_id) }\r\n```\r\n\r\nWill output:\r\n```json\r\n{\r\n  &quot;ip&quot;: [\r\n    &quot;182,555,44.44&quot;\r\n  ],\r\n  &quot;source_id&quot;: &quot;2e74a68a-2fef-443544-815d-222&quot;\r\n}\r\n{\r\n  &quot;ip&quot;: [\r\n    &quot;192.134.5.31&quot;,\r\n    &quot;172.23.54.4&quot;\r\n  ],\r\n  &quot;source_id&quot;: &quot;2e74a68a-2fef-443544-815d-87&quot;\r\n}\r\n```\r\n\r\nSince\r\n\r\n- We group on `source_id`\r\n- We create an object for each group, containing\r\n- An `map()` from all the lower ip&#39;s and the `source_id` taken from the `first` object\r\n\r\n\r\n----------\r\n\r\nUse the `--slurp` option to combine those objects in to an array:\r\n```\r\njq --slurp &#39;group_by(.source_id)[] | { ip: map(.ip), source_id: (first.source_id) }&#39;\r\n```\r\n#### [JqPlay Demo](https://jqplay.org/s/-2G1blVLqo5)",
                "title": "Jq parse duplicate json file using jqplay.org"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1673449789,
                "creation_date": 1673449789,
                "answer_id": 75085147,
                "question_id": 75083362,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure what your expected output is, but if you are trying to group IPs by source id like such:\r\n\r\n```json\r\n{\r\n  &quot;2e74a68a-2fef-443544-815d-222&quot;: [\r\n    &quot;182,555,44.44&quot;\r\n  ],\r\n  &quot;2e74a68a-2fef-443544-815d-87&quot;: [\r\n    &quot;192.134.5.31&quot;,\r\n    &quot;172.23.54.4&quot;\r\n  ]\r\n}\r\n```\r\n\r\nThen you can [group](https://stedolan.github.io/jq/manual/#group_by(path_expression)) by your source_id and then transform the output:\r\n\r\n```\r\ngroup_by(.source_id) | map({(.[0].source_id): map(.ip)}) | add\r\n```\r\n\r\nOr by using a [custom function](https://stackoverflow.com/q/73893818/112968):\r\n\r\n```\r\ndef group(k): group_by(k) | map({key:first|k, value:.}) | from_entries;\r\ngroup(.source_id)  | map_values(map(.ip))\r\n```\r\n\r\nor\r\n\r\n```\r\ndef group(k;v): group_by(k) | map({key:first|k, value:map(v)}) | from_entries;\r\ngroup(.source_id;.ip)\r\n```",
                "title": "Jq parse duplicate json file using jqplay.org"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1673449789,
        "creation_date": 1673441600,
        "last_edit_date": 1673441983,
        "question_id": 75083362,
        "body_markdown": "Can I output the ip and source id only when source id is duplicate it should out put all ip in one array if no duplicate ip can be output with corresponding source id \r\n\r\n\r\n\r\n```json\r\n{&quot;ip&quot;:&quot;192.134.5.31&quot;,&quot;access_key&quot;:&quot;223434354656767&quot;,&quot;source_id&quot;:&quot;2e74a68a-2fef-443544-815d-87&quot;}\r\n{&quot;ip&quot;:&quot;172.23.54.4&quot;,&quot;saccess_key&quot;:&quot;223434354656767&quot;,&quot;source_id&quot;:&quot;2e74a68a-2fef-443544-815d-87&quot;}\r\n{&quot;ip&quot;:&quot;182,555,44.44&quot;,&quot;access_key&quot;:&quot;223434354656767&quot;,&quot;source_id&quot;:&quot;2e74a68a-2fef-443544-815d-222&quot;}\r\n```\r\n\r\nI dont care about access key here also if this access key can be done with Jq would be great \r\n\r\n```\r\nunique_by(.ip) |{ip.source_id[]}\r\n```\r\n```\r\n.ip| select(.source_id[])\r\n```",
        "link": "https://stackoverflow.com/questions/75083362/jq-parse-duplicate-json-file-using-jqplay-org",
        "title": "Jq parse duplicate json file using jqplay.org"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1673467277,
                "creation_date": 1673467277,
                "answer_id": 75088434,
                "question_id": 75088330,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could `declare` the Bash array using the `-a` option, and have jq [escape](https://stedolan.github.io/jq/manual/#Formatstringsandescaping) its output using the `@sh` builtin:\r\n~~~sh\r\nunset array\r\ndeclare -a array=&quot;($(jq -r &#39;.contestants[].name | @sh&#39; json))&quot;\r\n~~~\r\n\r\nThis should have the same effect as\r\n~~~sh\r\nunset array\r\narray=(&quot;Joan-Juan Frank&quot; &quot;Kimi-Kinder Karten&quot; &quot;Peter-Parker Plays Piano&quot;)\r\n~~~",
                "title": "Bash - issues with creating arrays from elements containing whitespaces (jq-formatted output as input)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1673467989,
        "creation_date": 1673466703,
        "question_id": 75088330,
        "body_markdown": "I am working on a bash script which needs to ingest some data from a json (formatted with `jq`) and do some simple work with it, however in the process of doing so I noticed elements are getting broken down and even though I am ingesting elements containing a whitespace enclosed in double-quotes, elements are processed incorrectly.\r\n\r\nHere&#39;s an exemplary json I will be processing\r\n\r\n```\r\n{\r\n  &quot;start&quot;: 1689652086,\r\n  &quot;finish&quot;: 1679652100,\r\n  &quot;contestants&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Joan-Juan Frank&quot;,\r\n      &quot;comment&quot;: &quot;I reek of havoc.&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Kimi-Kinder Karten&quot;,\r\n      &quot;output&quot;: &quot;I love chocolate.&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Peter-Parker Plays Piano&quot;,\r\n      &quot;output&quot;: &quot;And I am tired of it&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\nI composed this command in bash to get this formatted string out of the json - I am basically selecting each value from `name` property of each element in the json array\r\n\r\n```\r\ncat json | jq &#39;.contestants[].name&#39; | tr &#39;\\n&#39; &#39; &#39;\r\n```\r\nthis results in this basic format which should have worked as an array declaration\r\n\r\n```\r\n&quot;Joan-Juan Frank&quot; &quot;Kimi-Kinder Karten&quot; &quot;Peter-Parker Plays Piano&quot; \r\n```\r\nI tried each of these two version of creating an array (none of them worked)\r\n\r\n```\r\ncontestants=$(cat json | jq &#39;.contestants[].name&#39; | tr &#39;\\n&#39; &#39; &#39;)\r\narray=($contestants)\r\n\r\nor\r\n\r\narray=($(cat json | jq &#39;.contestants[].name&#39; | tr &#39;\\n&#39; &#39; &#39;))\r\n```\r\n\r\nLastly, I used this `for` loop to output each element\r\n\r\n```\r\nfor i in &quot;${array[@]}&quot;; do\r\n    echo &quot;Working on: $i&quot;\r\ndone\r\n```\r\noutput of the script is\r\n\r\n```\r\nWorking on: &quot;Joan-Juan\r\nWorking on: Frank&quot;\r\nWorking on: &quot;Kimi-Kinder\r\nWorking on: Karten&quot;\r\nWorking on: &quot;Peter-Parker\r\nWorking on: Plays\r\nWorking on: Piano&quot;\r\n```\r\n\r\nI also went back and found out that the issue seems to be somewhere at the level of the array declaration. When I echoed the variable before declaring an array and then echoed elements of the array, here&#39;s what I got:\r\n\r\n`echo` of `$contestants` - `&quot;Joan-Juan Frank&quot; &quot;Kimi-Kinder Karten&quot; &quot;Peter-Parker Plays Piano&quot;`\r\n\r\n`echo` of `$array`\r\n```\r\necho &quot;${array[0]}&quot;\r\n&quot;Joan-Juan\r\necho &quot;${array[1]}&quot;\r\nFrank&quot;\r\necho &quot;${array[2]}&quot;\r\n&quot;Kimi-Kinder\r\necho &quot;${array[3]}&quot;\r\nKarten&quot;\r\n...\r\n```\r\nI have then tried to declare the array without any variable\r\n\r\n```\r\narray=(&quot;Joan-Juan Frank&quot; &quot;Kimi-Kinder Karten&quot; &quot;Peter-Parker Plays Piano&quot; )\r\n```\r\nand this was processed correctly, as I would expect\r\n\r\n```\r\nWorking on: Joan-Juan Frank\r\nWorking on: Kimi-Kinder Karten\r\nWorking on: Peter-Parker Plays Piano\r\n```\r\nI was trying suggestions from other threads like [this one](https://stackoverflow.com/questions/9084257/bash-array-with-spaces-in-elements), [this one](https://stackoverflow.com/questions/54087481/assigning-an-array-parsed-with-jq-to-bash-script-array) or [this one](https://stackoverflow.com/questions/12985178/bash-quoted-array-expansion), but in my case, I wasn&#39;t able to make this work when I am ingesting content from a variable, instead of just declaring a static array. Although, it is possible I might have made a mistake along the way. \r\n\r\nDo you have any idea how I could fix this?",
        "link": "https://stackoverflow.com/questions/75088330/bash-issues-with-creating-arrays-from-elements-containing-whitespaces-jq-form",
        "title": "Bash - issues with creating arrays from elements containing whitespaces (jq-formatted output as input)"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1673537287,
                "post_id": 75098633,
                "comment_id": 132525985,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1673591123,
                "last_edit_date": 1673591123,
                "creation_date": 1673541276,
                "answer_id": 75099523,
                "question_id": 75098633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is not an issue with `jq` invocation, but the way the output files get written. Per your usage indicated, after writing the file `test.cert.pem`, the contents over the read end of the pipe (JSON output) is no longer available to extract the `private_key` contents.\r\n\r\nTo duplicate the contents over at the write end of pipe, use `tee` along with process substitution. The following should work on bash/zsh or ksh93 and not on POSIX bourne shell sh\r\n\r\n```bash\r\nvault write -format=json pki_int/issue/example-dot-com \\                                                            \r\ncommon_name=&quot;test.example.com&quot; \\    \r\nttl=&quot;24h&quot; \\                 \r\nformat=pem \\\r\n| tee &gt;( jq -r &#39;.data.certificate, .data.issuing_ca&#39; &gt; test.cert.pem) \\\r\n&gt;(jq -r &#39;.data.private_key&#39; &gt; test.key.pem) \\\r\n&gt;/dev/null\r\n```\r\nSee this in action\r\n\r\n```bash\r\njq -n &#39;{data:{certificate: &quot;foo&quot;, issuing_ca: &quot;bar&quot;, private_key: &quot;zoo&quot;}}&#39; \\\r\n| tee &gt;( jq -r &#39;.data.certificate, .data.issuing_ca&#39; &gt; test.cert.pem) \\\r\n&gt;(jq -r &#39;.data.private_key&#39; &gt; test.key.pem) \\\r\n&gt;/dev/null\r\n```\r\n\r\nand now observe the contents of both the files.",
                "title": "Can you separate distinct JSON attributes into two files using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1673543862,
                "creation_date": 1673543862,
                "answer_id": 75100044,
                "question_id": 75098633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could abuse `jq`&#39;s ability to write to standard error (version 1.6 or later) separately from standard output.\r\n\r\n    vault write -format=json pki_int/issue/example-dot-com \\                                                            \r\n    common_name=&quot;test.example.com&quot; \\    \r\n    ttl=&quot;24h&quot; \\                 \r\n    format=pem \\\r\n    | jq -r &#39;.data as $f | ($f.private_key | stderr) | ($f.certificate, $f.issuing_ca)&#39; &gt; test.cert.pem 2&gt; test.key.pem \r\n\r\n",
                "title": "Can you separate distinct JSON attributes into two files using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1673562419,
                "creation_date": 1673562419,
                "answer_id": 75102933,
                "question_id": 75098633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s a general technique for this type of problem that is worth mentioning\r\nbecause it has minimal prerequisites (just jq and awk), and because\r\nit scales well with the number of files.  Furthermore it is quite efficient in that only one invocation each of jq and awk is needed. The idea is to setup a pipeline of the form: jq ... | awk ...\r\n\r\nThere are many variants\r\nof the technique but in the present case, the following would suffice:\r\n\r\n```\r\njq -rc &#39;\r\n .data\r\n | &quot;test.cert.pem&quot;,\r\n      &quot;\\t\\(.certificate)&quot;,\r\n      &quot;\\t\\(.issuing_ca)&quot;, \r\n   &quot;test.key.pem&quot;,\r\n      &quot;\\t\\(.private_key)&quot;\r\n&#39; | awk -F\\\\t &#39;NF == 1 {fn=$1; next} {print $2 &gt; fn}&#39;\r\n```\r\n\r\nNotice that this works even if the items of interest are strings with embedded tabs.\r\n\r\n",
                "title": "Can you separate distinct JSON attributes into two files using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1673591123,
        "creation_date": 1673537009,
        "question_id": 75098633,
        "body_markdown": "I am following [this tutorial][1] from Vault about creating your own certificate authority. I&#39;d like to separate [the response][2] (change the output to API call using cURL to see the response) into two distinct files, one file possessing the `certificate` and `issuing_ca` attributes, the other file containing the `private_key`. The tutorial is using jq to parse JSON objects, but my unfamiliarity with jq isn&#39;t helpful here, and most searches are returning info on how to **merge** JSON using jq. \r\n\r\nI&#39;ve tried running something like \r\n```\r\nvault write -format=json pki_int/issue/example-dot-com \\                                                            \r\ncommon_name=&quot;test.example.com&quot; \\    \r\nttl=&quot;24h&quot; \\                 \r\nformat=pem \\\r\njq -r &#39;.data.certificate, .data.issuing_ca &gt; test.cert.pem \\\r\njq -r &#39;.data.private_key&#39; &gt; test.key.pem \r\n```\r\nor \r\n```\r\nvault write -format=json pki_int/issue/example-dot-com \\                                                            \r\ncommon_name=&quot;test.example.com&quot; \\    \r\nttl=&quot;24h&quot; \\                 \r\nformat=pem \\\r\n| jq -r &#39;.data.certificate, .data.issuing_ca &gt; test.cert.pem \\\r\n| jq -r &#39;.data.private_key&#39; &gt; test.key.pem \r\n```\r\nbut no dice.\r\n\r\n  [1]: https://developer.hashicorp.com/vault/tutorials/secrets-management/pki-engine#lab-setup\r\n  [2]: https://developer.hashicorp.com/vault/tutorials/secrets-management/pki-engine#step-4-request-certificates",
        "link": "https://stackoverflow.com/questions/75098633/can-you-separate-distinct-json-attributes-into-two-files-using-jq",
        "title": "Can you separate distinct JSON attributes into two files using jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1673565831,
                "last_edit_date": 1673565831,
                "creation_date": 1673565087,
                "answer_id": 75103255,
                "question_id": 75103172,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I supposed your file name is test.json\r\n\r\n    echo {\\&quot;msg\\&quot;: \\&quot;OK\\&quot;, \\&quot;status\\&quot;: 200, \\&quot;files\\&quot;: [ { \\&quot;filecode\\&quot;:\\&quot;am9kb3tw6hv1\\&quot;, \\&quot;filename\\&quot;: \\&quot;video.mp4\\&quot;, \\&quot;status\\&quot;: \\&quot;OK\\&quot; } ]} &gt; test.json\r\n\r\nRun this\r\n\r\n    jq &#39;.files[0].filecode&#39; test.json\r\n\r\nOutput\r\n\r\n    &quot;am9kb3tw6hv1&quot;\r\n\r\nIf you don&#39;t want the quotes, then use -r\r\n\r\n    jq -r &#39;.files[0].filecode&#39; test.json\r\n\r\noutput\r\n\r\n    am9kb3tw6hv1\r\n\r\n\r\nI found [this][1] page that explain how to use jq\r\n\r\n\r\n  [1]: https://tecadmin.net/linux-jq-command",
                "title": "How to get the value using jq command?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1673565831,
        "creation_date": 1673564269,
        "question_id": 75103172,
        "body_markdown": "How to get the value of filecode in\r\n\r\n```\r\n&quot;{&quot;msg&quot;: &quot;OK&quot;, &quot;status&quot;: 200, &quot;files&quot;: [ { &quot;filecode&quot;:&quot;am9kb3tw6hv1&quot;, &quot;filename&quot;: &quot;video.mp4&quot;, &quot;status&quot;: &quot;OK&quot; } ]}&quot;\r\n\r\n```\r\n\r\nThe printed output will be\r\n\r\n```\r\nam9kb3tw6hv1\r\n```",
        "link": "https://stackoverflow.com/questions/75103172/how-to-get-the-value-using-jq-command",
        "title": "How to get the value using jq command?"
    },
    {
        "tags": [
            "linux",
            "bitbucket",
            "jq",
            "bitbucket-pipelines",
            "sfdx"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673625696,
                "post_id": 75110653,
                "comment_id": 132548424,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13959660,
                    "reputation": 92,
                    "user_id": 10081285,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1c0aff6b51ff5fa21add37ecc7ee0bf9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Cezu",
                    "link": "https://stackoverflow.com/users/10081285/cezu"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673676735,
                "post_id": 75110653,
                "comment_id": 132556231,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673688646,
                "post_id": 75110653,
                "comment_id": 132557376,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1673676717,
        "creation_date": 1673620806,
        "last_edit_date": 1673676717,
        "question_id": 75110653,
        "body_markdown": "When i running a pipeline in bitbucket  i want to export into variable using \r\n\r\n```\r\nexport APEX_CLASSES=$(xq . &lt; package/package.xml | jq &#39;.Package.types | [.] | flatten | map(select(.name==&quot;ApexClass&quot;)) | .[] | .members | [.] | flatten | map(select(. | index(&quot;*&quot;) | not)) | unique | join(&quot;,&quot;)&#39; -r)\r\n```\r\nbut i got error in pipeline \r\n\r\n```\r\nparse error: Invalid numeric literal at line 1, column 5\r\n```\r\n\r\ni tried to identify a error but i always get same error :( \r\n\r\nWhen i add a escape \\ before &quot; i got this error\r\n\r\n```\r\njq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.Package.types | [.] | flatten | map(select(.name==\\&quot;ApexClass\\&quot;)) | .[] | .members | [.] | flatten | map(select(. | index(\\&quot;*\\&quot;) | not)) | unique | join(\\&quot;,\\&quot;)                                                   \r\njq: 1 compile error\r\n```\r\n\r\nThis is package.xml\r\n\r\n```\r\n&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;\r\n&lt;Package xmlns=&quot;http://soap.sforce.com/2006/04/metadata&quot;&gt;\r\n    &lt;types&gt;\r\n        &lt;members&gt;AccountHelper&lt;/members&gt;\r\n        &lt;members&gt;BoatHelper&lt;/members&gt;\r\n        &lt;members&gt;CaseHelper&lt;/members&gt;\r\n        &lt;name&gt;ApexClass&lt;/name&gt;\r\n    &lt;/types&gt;\r\n    &lt;version&gt;57.0&lt;/version&gt;\r\n&lt;/Package&gt;\r\n```",
        "link": "https://stackoverflow.com/questions/75110653/bitbucket-pipelines-export-into-variable-using-jq-and-xq-causes-error",
        "title": "Bitbucket Pipelines export into variable using jq and xq causes error"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673624387,
                "post_id": 75111251,
                "comment_id": 132547956,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27521124,
                    "reputation": 29,
                    "user_id": 21001282,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/59100bf5d3a92a19a62a5b261aceafdd?s=256&d=identicon&r=PG",
                    "display_name": "Yaroslav",
                    "link": "https://stackoverflow.com/users/21001282/yaroslav"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673624999,
                "post_id": 75111251,
                "comment_id": 132548148,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10275035,
                    "reputation": 121775,
                    "user_id": 7582247,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KPNHoVDG.png?s=256",
                    "display_name": "Ted Lyngmo",
                    "link": "https://stackoverflow.com/users/7582247/ted-lyngmo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673625582,
                "post_id": 75111251,
                "comment_id": 132548382,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1673625634,
                "last_edit_date": 1673625634,
                "creation_date": 1673624917,
                "answer_id": 75111439,
                "question_id": 75111251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could `select` on `.attributes[]` and display the `id` field only:\r\n```jq\r\njq &#39;.[] | select(.attributes[] == &quot;0fda6bb8-4fc9-4463-9d26-af2d503cb19c&quot;).id&#39;\r\n```\r\nOutput:\r\n```none\r\n&quot;c3b1516d-5b2c-4838-b5eb-77d94d634832&quot;\r\n```\r\nWith the input given, you&#39;d get the same result with the more specific:\r\n```jq\r\njq &#39;.[] | select(.attributes[&quot;1be40893-5dad-4b37-b70d-b830c4bd273f&quot;] == &quot;0fda6bb8-4fc9-4463-9d26-af2d503cb19c&quot;).id&#39;\r\n```\r\n(because there&#39;s only one `attribute` _Key_ with the _Value_ `&quot;0fda6bb8-4fc9-4463-9d26-af2d503cb19c&quot;` in your example)\r\n",
                "title": "How do i get id from json with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1673625634,
        "creation_date": 1673623890,
        "last_edit_date": 1673624291,
        "question_id": 75111251,
        "body_markdown": "i have json.  How can I get the id whose attributes value is 0fda6bb8-4fc9-4463-9d26-af2d503cb19c ?\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;c3b1516d-5b2c-4838-b5eb-77d94d634832&quot;,\r\n        &quot;versionId&quot;: &quot;c3b1516d-5b2c-4838-b5eb-77d94d634832&quot;,\r\n        &quot;name&quot;: &quot;выписка маленькая заявка с лендинга ИБ&quot;,\r\n        &quot;entityTypeName&quot;: &quot;TestCases&quot;,\r\n        &quot;projectId&quot;: &quot;6dfe2ace-dd40-4e36-b66e-4a655a855a2f&quot;,\r\n        &quot;sectionId&quot;: &quot;bf7fbece-4fdf-466a-b041-2d830debc844&quot;,\r\n        &quot;isAutomated&quot;: false,\r\n        &quot;globalId&quot;: 264511,\r\n        &quot;duration&quot;: 300,\r\n        &quot;attributes&quot;: {\r\n          &quot;1be40893-5dad-4b37-b70d-b830c4bd273f&quot;: &quot;0fda6bb8-4fc9-4463-9d26-af2d503cb19c&quot;,\r\n          &quot;f4b408ae-5418-4a8d-99d9-4a67cb34870b&quot;: &quot;fa000fb2-375d-4eb5-901c-fb5df30785ad&quot;\r\n        },\r\n        &quot;createdById&quot;: &quot;995b1f08-cc65-409c-aa1c-a16c82dabf1d&quot;,\r\n        &quot;modifiedById&quot;: &quot;995b1f08-cc65-409c-aa1c-a16c82dabf1d&quot;,\r\n        &quot;createdDate&quot;: &quot;2022-10-12T00:22:43.544Z&quot;,\r\n        &quot;modifiedDate&quot;: &quot;2022-10-12T00:22:43.544Z&quot;,\r\n        &quot;state&quot;: &quot;NeedsWork&quot;,\r\n        &quot;priority&quot;: &quot;Medium&quot;,\r\n        &quot;isDeleted&quot;: false,\r\n        &quot;tagNames&quot;: [\r\n          &quot;master&quot;\r\n        ],\r\n        &quot;iterations&quot;: []\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;ec423701-f2a8-4667-8459-939a6e079941&quot;,\r\n        &quot;versionId&quot;: &quot;0dfe176e-b172-47ae-8049-e6974086d497&quot;,\r\n        &quot;name&quot;: &quot;[iOS] СБПэй фичатоглы. Fts.SBPay.Settings выключен Fts.C2B.Settings.Subscriptions включен&quot;,\r\n        &quot;entityTypeName&quot;: &quot;TestCases&quot;,\r\n        &quot;projectId&quot;: &quot;6dfe2ace-dd40-4e36-b66e-4a655a855a2f&quot;,\r\n        &quot;sectionId&quot;: &quot;8626c9f5-a5aa-4584-bbca-e9cd60369a5e&quot;,\r\n        &quot;isAutomated&quot;: false,\r\n        &quot;globalId&quot;: 402437,\r\n        &quot;duration&quot;: 300,\r\n        &quot;attributes&quot;: {\r\n          &quot;1be40893-5dad-4b37-b70d-b830c4bd273f&quot;: &quot;b52bfc88-9b13-41e1-8b4c-098ebfa673e0&quot;,\r\n          &quot;240b7589-9461-44dc-8b13-361132877c50&quot;: &quot;cfd99bad-fb3f-43fe-be8a-cb745f2d4c78&quot;,\r\n          &quot;6639eb1a-1335-44ec-ba8b-c3c52bff9e79&quot;: &quot;ed3bc553-e873-472f-8dc1-7f2720ad457d&quot;,\r\n          &quot;9ae36ef5-ca0e-4273-bb39-aedf289a119d&quot;: &quot;6687017f-138b-4d75-91bd-c6465f1f5331&quot;,\r\n          &quot;b862c3ee-55eb-486f-8125-a7a034d69340&quot;: &quot;IBANK5-37207&quot;,\r\n          &quot;f4b408ae-5418-4a8d-99d9-4a67cb34870b&quot;: &quot;36dc55ac-359c-4312-9b1a-646ad5fd5aa9&quot;\r\n        },\r\n        &quot;createdById&quot;: &quot;11a30c8b-73e2-4233-bbf5-7cc41556d3e0&quot;,\r\n        &quot;modifiedById&quot;: &quot;11a30c8b-73e2-4233-bbf5-7cc41556d3e0&quot;,\r\n        &quot;createdDate&quot;: &quot;2022-11-01T12:05:56.821Z&quot;,\r\n        &quot;modifiedDate&quot;: &quot;2022-11-02T14:16:55.246Z&quot;,\r\n        &quot;state&quot;: &quot;Ready&quot;,\r\n        &quot;priority&quot;: &quot;Medium&quot;,\r\n        &quot;isDeleted&quot;: false,\r\n        &quot;tagNames&quot;: [],\r\n        &quot;iterations&quot;: []\r\n      }\r\n    ]\r\n\r\nI tried using \r\n\r\n    cat new2.xml |  jq &#39;.&#39;  |  jq &#39;.[] |  select(.&quot;1be40893-5dad-4b37-b70d-b830c4bd273f&quot; | index(&quot;0fda6bb8-4fc9-4463-9d26-af2d503cb19c&quot;)) |  .[] .id&#39;\r\n\r\n \r\n\r\nbut the search returns nothing\r\n",
        "link": "https://stackoverflow.com/questions/75111251/how-do-i-get-id-from-json-with-jq",
        "title": "How do i get id from json with jq?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673650141,
                "post_id": 75115127,
                "comment_id": 132554798,
                "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": 1673650169,
                "post_id": 75115127,
                "comment_id": 132554804,
                "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": 1673650404,
                "post_id": 75115127,
                "comment_id": 132554843,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26901269,
                    "reputation": 7,
                    "user_id": 20478378,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/95634ce9974365ae98ae7740f0ce792b?s=256&d=identicon&r=PG",
                    "display_name": "Jeroen G",
                    "link": "https://stackoverflow.com/users/20478378/jeroen-g"
                },
                "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": 1673794023,
                "post_id": 75115127,
                "comment_id": 132572576,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1673650386,
                "creation_date": 1673650386,
                "answer_id": 75115171,
                "question_id": 75115127,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `--args` option to provide a variable number of fields to query, then use the `$ARGS.positional` array to retrieve them:\r\n```sh\r\njq -r &#39;.data[] | [.[$ARGS.positional[]]] | @csv&#39; data.json --args datum prijsTI\r\n```\r\n```csv\r\n&quot;2023-01-11 00:00:00&quot;,&quot;0.160970&quot;\r\n&quot;2023-01-11 01:00:00&quot;,&quot;0.154920&quot;\r\n```",
                "title": "How to specify jq output fields from variable in bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1673650447,
        "creation_date": 1673649971,
        "question_id": 75115127,
        "body_markdown": "given the following (simplified) json file:\r\n\r\n```\r\n{\r\n    &quot;data&quot;: [\r\n        {\r\n            &quot;datum&quot;: &quot;2023-01-11 00:00:00&quot;,\r\n            &quot;prijs&quot;: &quot;0.005000&quot;,\r\n            &quot;prijsZP&quot;: &quot;0.161550&quot;,\r\n            &quot;prijsEE&quot;: &quot;0.181484&quot;,\r\n            &quot;prijsTI&quot;: &quot;0.160970&quot;,\r\n        },\r\n        {\r\n            &quot;datum&quot;: &quot;2023-01-11 01:00:00&quot;,\r\n            &quot;prijs&quot;: &quot;0.000000&quot;,\r\n            &quot;prijsZP&quot;: &quot;0.155500&quot;,\r\n            &quot;prijsEE&quot;: &quot;0.175434&quot;,\r\n            &quot;prijsTI&quot;: &quot;0.154920&quot;,\r\n        }\r\n  ]\r\n}\r\n```\r\n\r\nI want to specify in my jq command which fields to retreive, i.e. only &quot;datum&quot; and &quot;prijsTI&quot;. But on another moment this selection will be different.\r\n\r\nI use the following command to gather all the fields, but would like to set the field selection via a variable:\r\n\r\n`cat data.json |jq -r &#39;.data[]|[.datum, .prijsTI]|@csv&#39;`\r\n\r\nI already tried using arguments, but this did not work :-(\r\n\r\n`myJQselect=&quot;.datum, .prijsTI&quot;`  \r\n`cat data.json |jq -r --arg myJQselect &quot;$myJQselect&quot; &#39;.data[$myHour |tonumber]|[$myJQselect]|@csv&#39;`\r\n\r\ngives the following result:  `&quot;.datum, .prijs&quot; `instead of the correct values.\r\n\r\nWould this be possible?\r\n\r\nThanks,\r\n\r\nJeroen",
        "link": "https://stackoverflow.com/questions/75115127/how-to-specify-jq-output-fields-from-variable-in-bash",
        "title": "How to specify jq output fields from variable in bash?"
    },
    {
        "tags": [
            "json",
            "bash",
            "bigdata",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1673735553,
                "last_edit_date": 1673735553,
                "creation_date": 1673683048,
                "answer_id": 75116555,
                "question_id": 75116554,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use jq&#39;s (or gojq&#39;s) streaming parser in conjunction with `first/1` as shown below.\r\n\r\nThis reduces both the execution time and the memory requirements, e.g. compared to using the non-streaming parser:\r\nfrom 50 seconds to a few microseconds, and from 4,112MB of RAM (mrss) to 3MB.\r\n\r\nNotes:\r\n* jq and gojq do not produce identical results because gojq does not respect the ordering of keys within objects.\r\n* The performance statistics shown below are for rows.json described in the Q.\r\n\r\nHere is an extract from the transcript showing the command invocations and key performance statistics, on a 3GHz machine.\r\n\r\n\r\n```\r\n+ /usr/bin/time -lp gojq -n --stream &#39;first(fromstream(3|truncate_stream(inputs| select(.[0][0:3] == [&quot;meta&quot;,&quot;view&quot;, &quot;approvals&quot;]) )))&#39; rows.json\r\nuser 0.00\r\nsys 0.00\r\n             3702784  maximum resident set size\r\n             1531904  peak memory footprint\r\n```\r\n```\r\n+ /usr/bin/time -lp jq -n --stream &#39;first(fromstream(3|truncate_stream(inputs| select(.[0][0:3] == [&quot;meta&quot;,&quot;view&quot;, &quot;approvals&quot;]) )))&#39; rows.json\r\nuser 0.00\r\nsys 0.00\r\n             1990656  maximum resident set size\r\n             1114112  peak memory footprint\r\n```\r\n```\r\n/usr/bin/time -lp jq .meta.view.approvals rows.json\r\nuser 39.90\r\nsys 11.82\r\n          4112465920  maximum resident set size\r\n          6080188416  peak memory footprint\r\n```\r\n```\r\n/usr/bin/time -lp gojq -n --stream &#39;\r\n  fromstream(3|truncate_stream(inputs | select(.[0][0:3] == [&quot;meta&quot;,&quot;view&quot;, &quot;approvals&quot;]) ))&#39; rows.json\r\nuser 495.30\r\nsys 273.72\r\n          7858896896  maximum resident set size\r\n         38385831936  peak memory footprint\r\n```\r\n\r\nThe following [jm](https://github.com/pkoppstein/jm) command produces essentially the same results:\r\n```\r\n/usr/bin/time -lp jm --pointer /meta/view/approvals rows.json\r\nuser 0.05\r\nsys 0.07\r\n            13594624  maximum resident set size\r\n             7548928  peak memory footprint\r\n```\r\n---\r\n\r\nAn alternative would be to use `first_run/2` defined as follows:\r\n```\r\n# Emit the first run of the items in the stream for which the condition is truthy\r\ndef first_run(stream; condition):\r\n  label $out\r\n  | foreach stream as $x (null;\r\n      ($x|condition) as $y\r\n      | if $y\r\n        then [$x]\r\n\t    elif . then break $out\r\n\t    else .\r\n\t    end;\r\n      if . then .[0] else empty end);\r\n```",
                "title": "How to use jq to economically extract a small JSON fragment from near the beginning of a very large monolithic JSON document?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1673735553,
        "creation_date": 1673683048,
        "last_edit_date": 1673683490,
        "question_id": 75116554,
        "body_markdown": "The JSON file in question is quite large (~1.5GB) but has some metadata at a known location (.meta.view.approvals) near the beginning.\r\n  \r\nHow can jq or gojq be used to extract the object at that location without having to load\r\nthe whole file into memory, and without having to wait for the processing of the whole file to stop\r\nafter the item of interest has been extracted?\r\n\r\nA generic method is sought, but the specific file I&#39;m interested in is\r\nrows.json at https://data.montgomerycountymd.gov/api/views/4mse-ku6q/rows.json\r\nMy copy was retrieved on Jan 12, 2023; the file size is 1459382170 bytes, and the value of .meta.view.createdAt in the file is 1403103517\r\n\r\nCommand-line alternatives to\r\njq, gojq, and [jm](https://github.com/pkoppstein/jm) would also be of interest, provided they are economical with respect to both memory and CPU usage.\r\n",
        "link": "https://stackoverflow.com/questions/75116554/how-to-use-jq-to-economically-extract-a-small-json-fragment-from-near-the-beginn",
        "title": "How to use jq to economically extract a small JSON fragment from near the beginning of a very large monolithic JSON document?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10643264,
                    "reputation": 1371,
                    "user_id": 7837563,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/84bd9ecd95886440422f56a8b29c62b6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rmahajan",
                    "link": "https://stackoverflow.com/users/7837563/rmahajan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673715908,
                "post_id": 75119625,
                "comment_id": 132562043,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user21008014"
                },
                "reply_to_user": {
                    "account_id": 10643264,
                    "reputation": 1371,
                    "user_id": 7837563,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/84bd9ecd95886440422f56a8b29c62b6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rmahajan",
                    "link": "https://stackoverflow.com/users/7837563/rmahajan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673716136,
                "post_id": 75119625,
                "comment_id": 132562095,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user21008014"
                },
                "reply_to_user": {
                    "account_id": 10643264,
                    "reputation": 1371,
                    "user_id": 7837563,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/84bd9ecd95886440422f56a8b29c62b6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rmahajan",
                    "link": "https://stackoverflow.com/users/7837563/rmahajan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673716170,
                "post_id": 75119625,
                "comment_id": 132562102,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1673718450,
                "last_edit_date": 1673718450,
                "creation_date": 1673716201,
                "answer_id": 75119796,
                "question_id": 75119625,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Build an `INDEX`, then use that to map your tweets:\r\n\r\n```\r\nINDEX(.users[]; .id) as $idx | .tweets | map({ tweet, user: $idx[.user|tostring] })\r\n```\r\n\r\nor using `JOIN` directly:\r\n\r\n```\r\n[JOIN(INDEX(.users[]; .id); .tweets[]; .user|tostring; .[0] + { user: .[1] })]\r\n```\r\n\r\nYou could also do it the inefficient way, finding the correct user by iterating:\r\n\r\n```\r\n.users as $users\r\n| .tweets\r\n| map({ tweet, user: (.user as $user | $users[] | select(.id == $user))})\r\n```\r\n\r\n",
                "title": "INNER JOIN in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1673760298,
                "creation_date": 1673760298,
                "answer_id": 75123115,
                "question_id": 75119625,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "@knittl&#39;s solutions using INDEX are fine unless there is a &quot;collision&quot; of ids (e.g. if .id can be both `1` and `&quot;1&quot;`).\r\n\r\nTo avoid collisions and to allow other types of `.id` values, you could use\r\n`SAFE_INDEX` and `lookup` defined as follows:\r\n\r\n```\r\ndef SAFE_INDEX(stream; idx_expr):\r\n  reduce stream as $row ({};\r\n    ($row|idx_expr) as $ix\r\n    | .[$ix|type][$ix|tostring] = $row);\r\n\r\ndef lookup($value):\r\n   .[$value|type] as $t\r\n   | if ($t|type) == &quot;object&quot; then $t[$value|tostring] else null end;\r\n```\r\n\r\nSo a generic solution to the problem would look like this:\r\n```\r\nSAFE_INDEX(.users[]; .id) as $idx \r\n| .tweets\r\n| map({ tweet, user: (.user as $user | $idx |lookup($user)) })\r\n```\r\n\r\n\r\n",
                "title": "INNER JOIN in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1673760298,
        "creation_date": 1673714860,
        "last_edit_date": 1673716585,
        "question_id": 75119625,
        "body_markdown": "Using the input given, I need to join the true &quot;user&quot; value from the tweets array with the id in the users array and display the users array object as part of the tweets array\r\n\r\n**Input:**\r\n\r\n    {\r\n      &quot;tweets&quot;: [\r\n        {\r\n          &quot;tweet&quot;: &quot;Hey, i gonna release GPT4 soon&quot;,\r\n          &quot;user&quot;: 1\r\n        },\r\n        {\r\n          &quot;tweet&quot;: &quot;We have launched falcon 10 yesterday, it was awesome, one step closer to Mars&quot;,\r\n          &quot;user&quot;: 2\r\n        },\r\n        {\r\n          &quot;tweet&quot;: &quot;Databar acquires Statista.com, great news coming out&quot;,\r\n          &quot;user&quot;: 3\r\n        },\r\n        {\r\n          &quot;tweet&quot;: &quot;Gpt4 is available&quot;,\r\n          &quot;user&quot;: 1\r\n        }\r\n      ],\r\n      &quot;users&quot;: [\r\n        { &quot;id&quot;: 1, &quot;name&quot;: &quot;a&quot; },\r\n        { &quot;id&quot;: 2, &quot;name&quot;: &quot;b&quot; },\r\n        { &quot;id&quot;: 3, &quot;name&quot;: &quot;c&quot; }\r\n      ]\r\n    }\r\n\r\n**Output**\r\n\r\n    [\r\n      {\r\n        &quot;tweet&quot;: &quot;Hey, i gonna release GPT4 soon&quot;,\r\n        &quot;user&quot;: {\r\n          &quot;id&quot;: 1,\r\n          &quot;name&quot;: &quot;a&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;tweet&quot;: &quot;We have launched falcon 10 yesterday, it was awesome, one step closer to Mars&quot;,\r\n        &quot;user&quot;: {\r\n          &quot;id&quot;: 2,\r\n          &quot;name&quot;: &quot;b&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;tweet&quot;: &quot;Databar acquires Statista.com, great news coming out&quot;,\r\n        &quot;user&quot;: {\r\n          &quot;id&quot;: 3,\r\n          &quot;name&quot;: &quot;c&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;tweet&quot;: &quot;Gpt4 is available&quot;,\r\n        &quot;user&quot;: {\r\n          &quot;id&quot;: 1,\r\n          &quot;name&quot;: &quot;a&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nI tried using an if condition to find the equal values first, but it loops through the entire array, hence I cant get the specific value of the value in the users array that the ID is equal too\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75119625/inner-join-in-jq",
        "title": "INNER JOIN in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673768827,
                "post_id": 75123612,
                "comment_id": 132568726,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673778448,
                "post_id": 75123612,
                "comment_id": 132570040,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1673778358,
                "last_edit_date": 1673778358,
                "creation_date": 1673770190,
                "answer_id": 75123734,
                "question_id": 75123612,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JSON keys are always strings, but jq _sometimes_ allows to use them without string (if they would be a valid &quot;identifier&quot;). You must quote it if it contains special characters such as `%`:\r\n\r\n* `jq &#39;.system.&quot;%cpu&quot;&#39; test.json`\r\n* or `jq &#39;.system[&quot;%cpu&quot;]&#39; test.json`\r\n",
                "title": "Parse JSON key starting in % with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1673778358,
        "creation_date": 1673768421,
        "question_id": 75123612,
        "body_markdown": "Assume the following output from a REST API (stored as `test.json` here):\r\n``` json\r\n{\r\n  &quot;system&quot;: {\r\n    &quot;power&quot;: 10.5,\r\n    &quot;%mem&quot;: 0.5,\r\n    &quot;%cpu&quot;: 12.4\r\n  }\r\n}\r\n```\r\n\r\nI can easily query the first item:\r\n\r\n```\r\n$ jq &#39;.system.power&#39; test.json\r\n\r\n10.5\r\n```\r\n\r\nHowever:\r\n```\r\n$ jq &#39;.system.%cpu&#39; test.json\r\n\r\njq: error: syntax error, unexpected &#39;%&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.system.%cpu        \r\njq: 1 compile error\r\n```\r\n\r\nAccording to JSON.org, a&#160;string&#160;is a sequence of zero or more Unicode characters, wrapped in double quotes, using backslash escapes. **Any valid string can be used as a JSON key.** So `%cpu` seems indeed valid and, indeed, `jq` can handle this elsewhere just fine:\r\n```\r\n$ jq &#39;.system | has(&quot;%cpu&quot;)&#39; test.json \r\ntrue\r\n```\r\n\r\nQuestion: How can I extract the lower two properties from the `system` object?",
        "link": "https://stackoverflow.com/questions/75123612/parse-json-key-starting-in-with-jq",
        "title": "Parse JSON key starting in % with jq"
    },
    {
        "tags": [
            "regex",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1673855300,
                "last_edit_date": 1673855300,
                "creation_date": 1673854590,
                "answer_id": 75131333,
                "question_id": 75131082,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try grouping `minor` and `patch` together like this:\r\n```\r\ncapture(&quot;^((?&lt;compat_prefix&gt;.*)-)?[Vv]?(?&lt;version&gt;(?&lt;major&gt;\\\\d+)(\\\\.(?&lt;minor&gt;\\\\d+)(\\\\.(?&lt;patch&gt;\\\\d+))?)?)(-(?&lt;compat_suffix&gt;.*))?$&quot;)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/yS0UTnWtt81)&lt;/sup&gt;",
                "title": "Extracting optional version components with JQ regex"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1673855300,
        "creation_date": 1673852543,
        "question_id": 75131082,
        "body_markdown": "I&#39;m trying to define a regex to extract versioning information from strings that may have been formatted with different versioning schemes.\r\n\r\nExamples:\r\n\r\n```\r\nv2.234324\r\n4.5.0\r\nv1.1.0-bar\r\nv2.3-foo\r\nV1\r\nFEE-v1.0.2-fuu\r\n```\r\n\r\nI can &quot;generalize&quot; these versioning schemes by considering the following constituents:\r\n\r\n * An optional compatibility prefix\r\n * An optional `v` or `V`\r\n * Up to 3 version components, but at least 1: major, (minor), (patch)\r\n * An optional compatibility suffix\r\n\r\nI&#39;m currently using the following regex:\r\n\r\n```\r\n(?:(?&lt;compat_prefix&gt;^.*)-)?[vV]?(?&lt;version&gt;(?&lt;major&gt;\\\\d+)(?:\\\\.(?&lt;minor&gt;\\\\d+))?(?:\\\\.(?&lt;patch&gt;\\\\d+)?))(?:-(?&lt;compat_suffix&gt;.*$))?\r\n```\r\n\r\nExample:\r\n\r\n```\r\n$ echo &#39;[{&quot;version&quot;:&quot;v1.2.3&quot;},{&quot;version&quot;:&quot;v1.2&quot;}]&#39; | jq &#39;.[].version | capture(&quot;(?:(?&lt;compat_prefix&gt;^.*)-)?[vV]?(?&lt;version&gt;(?&lt;major&gt;\\\\d+)(?:\\\\.(?&lt;minor&gt;\\\\d+))?(?:\\\\.(?&lt;patch&gt;\\\\d+)?))(?:-(?&lt;compat_suffix&gt;.*$))?&quot;)&#39;\r\n\r\n{\r\n  &quot;compat_prefix&quot;: null,\r\n  &quot;version&quot;: &quot;1.2.3&quot;,\r\n  &quot;major&quot;: &quot;1&quot;,\r\n  &quot;minor&quot;: &quot;2&quot;,\r\n  &quot;patch&quot;: &quot;3&quot;,\r\n  &quot;compat_suffix&quot;: null\r\n}\r\n{\r\n  &quot;compat_prefix&quot;: null,\r\n  &quot;version&quot;: &quot;1.2&quot;,\r\n  &quot;major&quot;: &quot;1&quot;,\r\n  &quot;minor&quot;: null,\r\n  &quot;patch&quot;: &quot;2&quot;,\r\n  &quot;compat_suffix&quot;: null\r\n}\r\n```\r\n\r\nAnd this works mostly fine for my purposes.\r\n\r\n__But I&#39;d like `minor` to take precedence over `patch` when there are only two version components__.\r\n\r\nI&#39;ve tried to use non greedy match on the `patch` capture group `??` without success:\r\n\r\n```\r\n$ echo &#39;[{&quot;version&quot;:&quot;foo-v1.2&quot;}]&#39; | jq &#39;.[].version | capture(&quot;(?:(?&lt;compat_prefix&gt;^.*)-)?[vV]?(?&lt;version&gt;(?&lt;major&gt;\\\\d+)(?:\\\\.(?&lt;minor&gt;\\\\d+))?(?:\\\\.(?&lt;patch&gt;\\\\d+)??))(?:-(?&lt;compat_suffix&gt;.*$))?&quot;)&#39;\r\n\r\n{\r\n  &quot;compat_prefix&quot;: &quot;foo&quot;,\r\n  &quot;version&quot;: &quot;1.&quot;,\r\n  &quot;major&quot;: &quot;1&quot;,\r\n  &quot;minor&quot;: null,\r\n  &quot;patch&quot;: null,\r\n  &quot;compat_suffix&quot;: null\r\n}\r\n```\r\n\r\nI&#39;ve also attempted to use possesive quantifier `?+` in the `minor` capturing group with similar result:\r\n\r\n```\r\n$ echo &#39;[{&quot;version&quot;:&quot;foo-v1.2&quot;}]&#39; | jq &#39;.[].version | capture(&quot;(?:(?&lt;compat_prefix&gt;^.*)-)?[vV]?(?&lt;version&gt;(?&lt;major&gt;\\\\d+)(?:\\\\.(?&lt;minor&gt;\\\\d+))?+(?:\\\\.(?&lt;patch&gt;\\\\d+)?))(?:-(?&lt;compat_suffix&gt;.*$))?&quot;)&#39;\r\n\r\n# Nothing is returned\r\n```\r\n\r\nI would appreciate help to understand why my attempts aren&#39;t working and what to do instead.\r\n",
        "link": "https://stackoverflow.com/questions/75131082/extracting-optional-version-components-with-jq-regex",
        "title": "Extracting optional version components with JQ regex"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1673901943,
                "post_id": 75139419,
                "comment_id": 132596472,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1673958480,
                "post_id": 75139419,
                "comment_id": 132608226,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15709463,
                    "reputation": 53,
                    "user_id": 11335427,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-UY_zOEK5h1Y/AAAAAAAAAAI/AAAAAAAATbw/mWqy30DqrIs/s256-rj/photo.jpg",
                    "display_name": "Edi Junior",
                    "link": "https://stackoverflow.com/users/11335427/edi-junior"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1673972994,
                "post_id": 75139419,
                "comment_id": 132613610,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1673907403,
                "creation_date": 1673907403,
                "answer_id": 75140218,
                "question_id": 75139419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As a supplement to @pmf&#39;s answer, it is perhaps worth mentioning that\r\nyou can specify the prefix on the command-line.  Also, if you wanted to keep the tree structure, you could run jq like so:\r\n\r\n```\r\njq -c --arg prefix example/ &#39;.[0].contents |= map($prefix + .name)&#39;\r\n```",
                "title": "Use jq to add string to each element of a list"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1673907403,
        "creation_date": 1673901402,
        "question_id": 75139419,
        "body_markdown": "I would like to write all the direcory names of a parent inside a list.\r\nI&#39;m using the tree command to achieve this as well as jq.\r\n\r\nThat&#39;s what I have so far:\r\n\r\n```\r\ndirectories_found=$(tree -J -d -L 1 | jq -c &#39;.[0].contents | map(.name)&#39;).map(.name)\r\n```\r\n\r\nThe tree comand returns this before the pipe:\r\n\r\n```\r\ndirectories_found=[{&quot;type&quot;:&quot;directory&quot;,&quot;name&quot;: &quot;.&quot;,&quot;contents&quot;:[ {&quot;type&quot;:&quot;directory&quot;,&quot;name&quot;:&quot;AppBackend&quot;,&quot;contents&quot;:[ ]}, {&quot;type&quot;:&quot;directory&quot;,&quot;name&quot;:&quot;list-folder-action&quot;,&quot;contents&quot;:[ ]} ]}, {&quot;type&quot;:&quot;report&quot;,&quot;directories&quot;:2} ]\r\n```\r\n\r\nAnd then, after applying jq, the output I see is this:\r\n\r\n```\r\n[&quot;AppBackend&quot;,&quot;list-folder-action&quot;]\r\n```\r\n\r\nLooks awesome. But I&#39;d like to edit these values but also keep the list structure.\r\n\r\nMy goal is to add a chunk of text before each element, like this:\r\n\r\n```\r\n[&quot;example/AppBackend&quot;,&quot;example/list-folder-action&quot;]\r\n\r\n```\r\n\r\nI just started using jq. How could I do this?",
        "link": "https://stackoverflow.com/questions/75139419/use-jq-to-add-string-to-each-element-of-a-list",
        "title": "Use jq to add string to each element of a list"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1673914704,
                "creation_date": 1673914704,
                "answer_id": 75140933,
                "question_id": 75140874,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a combination of `objects` and `arrays` to select the items to update with `|=`, then `with_entries` to access the `.key` which can be queried with `IN`:\r\n~~~sh\r\n&lt; file jq &#39;\r\n  (.[] | objects, (arrays[] | objects))\r\n    |= with_entries(select(.key | IN(&quot;enabled&quot;, &quot;name&quot;)))\r\n&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;abc&quot;: {\r\n    &quot;enabled&quot;: true\r\n  },\r\n  &quot;def&quot;: {\r\n    &quot;enabled&quot;: false\r\n  },\r\n  &quot;ghi&quot;: [\r\n    {\r\n      &quot;enabled&quot;: false,\r\n      &quot;name&quot;: &quot;HELLO&quot;\r\n    }\r\n  ],\r\n  &quot;jkl&quot;: [\r\n    {\r\n      &quot;enabled&quot;: true,\r\n      &quot;name&quot;: &quot;HI&quot;\r\n    }\r\n  ],\r\n  &quot;mko&quot;: {\r\n    &quot;enabled&quot;: false\r\n  },\r\n  &quot;pqr&quot;: {\r\n    &quot;enabled&quot;: true\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/l1jywvb4Kzl)",
                "title": "JSON filter a JSON with wildcards and keynames"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1673914704,
        "creation_date": 1673913818,
        "question_id": 75140874,
        "body_markdown": "How to parse a JSON to when a few values are string and other are list. \r\n\r\nI have a list like this:\r\n\r\n    {\r\n      &quot;abc&quot;: {\r\n        &quot;enabled&quot;: true\r\n      },\r\n      &quot;def&quot;: {\r\n        &quot;enabled&quot;: false\r\n      },\r\n      &quot;ghi&quot;: [\r\n        {\r\n          &quot;enabled&quot;: false,\r\n          &quot;name&quot;: &quot;HELLO&quot;,\r\n          &quot;useless&quot;: &quot;DO NOT WANT THIS&quot;\r\n        }\r\n      ],\r\n      &quot;jkl&quot;: [\r\n        {\r\n          &quot;enabled&quot;: true,\r\n          &quot;name&quot;: &quot;HI&quot;\r\n        }\r\n      ],\r\n      &quot;mko&quot;: {\r\n        &quot;enabled&quot;: false,\r\n        &quot;something unwanted&quot;: 123\r\n      },\r\n      &quot;pqr&quot;: {\r\n        &quot;enabled&quot;: true\r\n      }\r\n    }\r\n\r\n\r\nTrying to filter only by the two key(`enabled` and `name like abc`):\r\n\r\n\r\n    {\r\n      &quot;abc&quot;: {\r\n        &quot;enabled&quot;: true\r\n      },\r\n      &quot;def&quot;: {\r\n        &quot;enabled&quot;: false\r\n      },\r\n      &quot;ghi&quot;: [\r\n        {\r\n          &quot;enabled&quot;: false,\r\n          &quot;name&quot;: &quot;HELLO&quot;\r\n        }\r\n      ],\r\n      &quot;jkl&quot;: [\r\n        {\r\n          &quot;enabled&quot;: true,\r\n          &quot;name&quot;: &quot;HI&quot;\r\n        }\r\n      ],\r\n      &quot;mko&quot;: {\r\n        &quot;enabled&quot;: false\r\n      },\r\n      &quot;pqr&quot;: {\r\n        &quot;enabled&quot;: true\r\n      }\r\n    }\r\n\r\nTried several answers on SO, but nothing is giving the desired result. I am not a regular consumer of JSON so this question might sounds stupid. \r\n\r\n    jq -r &#39;[*].enabled&#39; file\r\n    jq: error: syntax error, unexpected &#39;*&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    [*].enabled\r\n    jq: 1 compile error\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75140874/json-filter-a-json-with-wildcards-and-keynames",
        "title": "JSON filter a JSON with wildcards and keynames"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1674024420,
                "creation_date": 1674024420,
                "answer_id": 75155541,
                "question_id": 75154728,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s unclear whether you want an answer like @KiranKandel&#39;s, namely:\r\n```\r\n.objects[].name | select(. != &quot;All_Internet&quot;)\r\n```\r\nor something like:\r\n```\r\n.objects[1:][].name\r\n```\r\n\r\n",
                "title": "how to select element or delete output string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1674024420,
        "creation_date": 1674016576,
        "question_id": 75154728,
        "body_markdown": "I have a json contents\r\n\r\n```\r\n &quot;objects&quot; : [ {\r\n    &quot;uid&quot; : &quot;2272dba0-9ffb-49d4-88b7-0a18f38a3cdc&quot;,\r\n    &quot;name&quot; : &quot;All_Internet&quot;,\r\n    },\r\n    {\r\n    &quot;uid&quot; : &quot;b83fd31c-3cb3-406e-b46b-816a138e8ea1&quot;,\r\n    &quot;name&quot; : &quot;Public FTP&quot;,\r\n  } ]\r\n```\r\n\r\nI used :\r\n\r\n```\r\njq &#39;.objects[] | .name\r\n```\r\n\r\nand got the resule:\r\n\r\n```\r\n&quot;All_Internet&quot;\r\n&quot;Public FTP&quot;\r\n```\r\n\r\nhow to select the secondary &quot;name&quot; string, or removing the first &quot;name&quot; &quot;All_Internet&quot; of output\r\n\r\nthe &quot;All_Internet&quot; is fixed string.\r\n\r\nRegards and thanks",
        "link": "https://stackoverflow.com/questions/75154728/how-to-select-element-or-delete-output-string",
        "title": "how to select element or delete output string"
    },
    {
        "tags": [
            "xml",
            "jq",
            "yq",
            "xq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674056587,
                "post_id": 75161483,
                "comment_id": 132634314,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1674056589,
                "post_id": 75161483,
                "comment_id": 132634315,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2789802,
                    "reputation": 461,
                    "user_id": 3358585,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2398d6320dc694c1c3a3b099b676ae94?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Boyd",
                    "link": "https://stackoverflow.com/users/3358585/boyd"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674058781,
                "post_id": 75161483,
                "comment_id": 132635178,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2789802,
                    "reputation": 461,
                    "user_id": 3358585,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2398d6320dc694c1c3a3b099b676ae94?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Boyd",
                    "link": "https://stackoverflow.com/users/3358585/boyd"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674059003,
                "post_id": 75161483,
                "comment_id": 132635258,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1674065895,
                "creation_date": 1674065895,
                "answer_id": 75163608,
                "question_id": 75161483,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### The XML syntax isn&#39;t the problem.\r\n\r\nYou&#39;re struggling with the (general) way both [mikefarah/yq](https://github.com/mikefarah/yq) and [kislyuk/yq](https://github.com/kislyuk/yq) chose to represent the XML tree in JSON/YAML. There is no canonical solution to that, and both these approaches are lossy wrt to &quot;Complex Types with Mixed Content&quot;, i.e. element nodes embedded into floating-around text nodes.\r\n\r\n### But modifying the XML syntax may be a solution.\r\n\r\nIf you don&#39;t care about the markup information conveyed by the elements in question, you could flatten out these passages in a pre-processing step, e.g. using a simple XSL transformation like \r\n\r\n```xml\r\n&lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;\r\n&lt;xsl:stylesheet version=&quot;1.0&quot; xmlns:xsl=&quot;http://www.w3.org/1999/XSL/Transform&quot;&gt;\r\n    &lt;xsl:template match=&quot;node()|@*&quot;&gt;\r\n        &lt;xsl:copy&gt;\r\n            &lt;xsl:apply-templates select=&quot;node()|@*&quot;/&gt;\r\n        &lt;/xsl:copy&gt;\r\n    &lt;/xsl:template&gt;\r\n    &lt;xsl:template match=&quot;kref|sub&quot;&gt;\r\n        &lt;xsl:value-of select=&quot;.&quot;/&gt;\r\n    &lt;/xsl:template&gt;\r\n&lt;/xsl:stylesheet&gt;\r\n```\r\n\r\nThis uses a template matching `node()|@*` which just replicates all elements and attributes, and another one that overrides this behavior for the `kref` and `sub` elements by copying over just their textual content.\r\n\r\nApply this XSLT to your XML document using an XSLT processor such as `xsltproc`, `Saxon`, or `Xalan`, and you should get the stripped version of your input:\r\n\r\n```xml\r\n&lt;lexicon&gt;\r\n  &lt;ar&gt;\r\n    &lt;k id=&quot;fb982hk&quot;&gt;Society&lt;/k&gt;\r\n    &lt;def&gt;\r\n      &lt;deftext&gt;\r\n        Plural form of word index.\r\n      &lt;/deftext&gt;\r\n    &lt;/def&gt;\r\n  &lt;/ar&gt;\r\n  &lt;ar&gt;\r\n    &lt;k&gt;CO2&lt;/k&gt;\r\n    &lt;def&gt;\r\n      &lt;deftext&gt;\r\n        Carbon dioxide (CO2) - a heavy odorless gas formed during respiration.\r\n      &lt;/deftext&gt;\r\n    &lt;/def&gt;\r\n  &lt;/ar&gt;\r\n&lt;/lexicon&gt;\r\n```\r\n\r\nThis can then be applied to your original `xq`/`yq` pipeline.\r\n\r\n\r\n\r\n",
                "title": "How to deal with embeded html in xml with jq yq xq (xml to yaml conversion)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1674172426,
                "last_edit_date": 1674172426,
                "creation_date": 1674082246,
                "answer_id": 75166081,
                "question_id": 75161483,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want a quick-and-a-bit-hacky solution, and if you want to preserve the HTML-specific &quot;markup&quot;, you could do worse than:\r\n```\r\nsed -E -e &#39;s/&lt;(kref|sub)&gt;/!\\1&gt;/g&#39; -e &#39;s,&lt;/(kref|sub)&gt;,!/\\1&gt;,g&#39; |\r\n yq -p=xml -o=yaml |\r\n sed -E -e &#39;s/!(kref|sub)&gt;/&lt;\\1&gt;/g&#39; -e &#39;s,!/(kref|sub)&gt;,&lt;/\\1&gt;,g&#39;\r\n```\r\n\r\nYour sed might want a different option for regex processing.\r\nOr you could use some other text-mangling tool,\r\nsuch as jq:\r\n```\r\njq -Rr &#39;gsub(&quot;&lt;(?&lt;tag&gt;kref|sub)&gt;&quot;; &quot;!\\(.tag)&gt;&quot;) | gsub(&quot;&lt;/(?&lt;tag&gt;kref|sub)&gt;&quot;; &quot;!\\(.tag)&gt;&quot;)&#39; |\r\n yq -p=xml -o=yaml |\r\n jq -Rr &#39;gsub(&quot;!(?&lt;tag&gt;kref|sub)&gt;&quot;; &quot;&lt;\\(.tag)&gt;&quot;) | gsub(&quot;!/(&lt;tag&gt;kref|sub)&gt;&quot;; &quot;&lt;/\\(.tag)&gt;&quot;)&#39;\r\n```",
                "title": "How to deal with embeded html in xml with jq yq xq (xml to yaml conversion)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1674172426,
        "creation_date": 1674055365,
        "question_id": 75161483,
        "body_markdown": "I have an xml dictionary file based on the [xdxf dictionary format here][1] that I would like to convert (and round trip) to yaml.\r\n\r\n\r\n  [1]: https://github.com/soshial/xdxf_makedict\r\n\r\nThis format (with DTD) may contain `&lt;kref&gt;` (cross reference) elements around a word that is already surrounded by `&lt;deftext&gt;` tags (definitions).  Or it may contain for example `&lt;sub&gt;` tags to indicate a word in subscript. I have not been able to see how to manage xml to yaml conversion of these files with yq (either the go or python) version.\r\n\r\n\r\n### An abreviated sample.xml (from the xdxf repo)\r\n\r\n````\r\n&lt;lexicon&gt;\r\n    &lt;ar&gt;\r\n        &lt;k id=&quot;fb982hk&quot;&gt;Society&lt;/k&gt;\r\n        &lt;def&gt;\r\n            &lt;deftext&gt;Plural form of word &lt;kref&gt;index&lt;/kref&gt;.\r\n            &lt;/deftext&gt;\r\n        &lt;/def&gt;\r\n    &lt;/ar&gt;\r\n    &lt;ar&gt;\r\n        &lt;k&gt;CO\r\n            &lt;sub&gt;2&lt;/sub&gt;\r\n        &lt;/k&gt;\r\n        &lt;def&gt;\r\n            &lt;deftext&gt;Carbon dioxide (CO&lt;sub&gt;2&lt;/sub&gt;) - a heavy odorless gas formed during respiration.\r\n            &lt;/deftext&gt;\r\n        &lt;/def&gt;\r\n    &lt;/ar&gt;\r\n  &lt;/lexicon&gt;\r\n````\r\n\r\n### converted to yaml via yq (go) will render:\r\n\r\n````\r\n yq -p=xml -o=yaml &lt; sample.xml \r\nlexicon:\r\n  ar:\r\n    - k:\r\n        +content: Society\r\n        +@id: fb982hk\r\n      def:\r\n        deftext:\r\n          +content:\r\n            - Plural form of word\r\n            - .\r\n          kref: index\r\n    - k:\r\n        +content: CO\r\n        sub: &quot;2&quot;\r\n      def:\r\n        deftext:\r\n          +content:\r\n            - Carbon dioxide (CO\r\n            - ) - a heavy odorless gas formed during respiration.\r\n          sub: &quot;2&quot;\r\n````\r\n\r\n### converted to yaml via yq (python) will render:\r\n\r\n````\r\n xq &lt; sample.xml | yq -y \r\nlexicon:\r\n  ar:\r\n    - k:\r\n        &#39;@id&#39;: fb982hk\r\n        &#39;#text&#39;: Society\r\n      def:\r\n        deftext:\r\n          kref: index\r\n          &#39;#text&#39;: Plural form of word .\r\n    - k:\r\n        sub: &#39;2&#39;\r\n        &#39;#text&#39;: CO\r\n      def:\r\n        deftext:\r\n          sub: &#39;2&#39;\r\n          &#39;#text&#39;: Carbon dioxide (CO) - a heavy odorless gas formed during respiration.\r\n````\r\n\r\nIn both cases the `&lt;kref&gt;` and `&lt;sub&gt;` elements will no longer &#39;surround&#39; the correct text and a return to xml will not be correct either.  Is this just a limitation of the format?  Or is there some way to accomodate (or maybe ignore as xml?) these tags?",
        "link": "https://stackoverflow.com/questions/75161483/how-to-deal-with-embeded-html-in-xml-with-jq-yq-xq-xml-to-yaml-conversion",
        "title": "How to deal with embeded html in xml with jq yq xq (xml to yaml conversion)"
    },
    {
        "tags": [
            "json",
            "shell",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1674082373,
                "last_edit_date": 1674082373,
                "creation_date": 1674079486,
                "answer_id": 75165755,
                "question_id": 75164791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the CSV is reasonably well-behaved, you could write:\r\n\r\n```\r\n# Skip the CSV header row by NOT specifying the -n option\r\n&lt; changes.csv | jq -Rcr --argfile json sample.json &#39;\r\n  def trim: sub(&quot;^[ \\t]*\\&quot;&quot;; &quot;&quot;) | sub(&quot;\\&quot;[ \\t]*$&quot;;&quot;&quot;);\r\n  INDEX(inputs | split(&quot;,&quot;) | map(trim) | select(length&gt;0); .[1]) as $dict\r\n  | $json\r\n  | map( .a = $dict[.b][0] )\r\n&#39;\r\n```\r\n\r\nFor more messy CSV, you will probably want to use a CSV-to-JSON or CSV-to-TSV tool (which can both quite easily be written in jq -- see e.g. https://rosettacode.org/wiki/Convert_CSV_records_to_TSV#jq)\r\n\r\n---\r\n\r\nIf you prefer not to use the --argfile option, then by all means use some other method of reading the two files, e.g. you could use --rawfile for the CSV, leaving STDIN for the JSON.",
                "title": "Update a json file using csv file contents"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1674136431,
                "last_edit_date": 1674136431,
                "creation_date": 1674080607,
                "answer_id": 75165870,
                "question_id": 75164791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For a pure `jq` solution, you&#39;ll better make sure that your CSV doesn&#39;t contain any `,` or `&quot;` or `\\n` in any field or else the code will become a lot more complex.\r\n\r\nHence, I propose a solution with &lt;a href=&quot;https://miller.readthedocs.io/en/latest/&quot;&gt;Miller&lt;/a&gt; (available &lt;a href=&quot;https://github.com/johnkerl/miller/releases&quot;&gt;here&lt;/a&gt; for several OSs), which can do the task easily and robustly:\r\n\r\n```sh\r\nmlr --icsv --ojson --no-jvstack join --ijson -f file.json -j &#39;b&#39; --ul file.csv\r\n```\r\n\r\n```json\r\n[\r\n{&quot;b&quot;: &quot;b1&quot;, &quot;a&quot;: &quot;a11&quot;},\r\n{&quot;b&quot;: &quot;b2&quot;, &quot;a&quot;: &quot;a22&quot;},\r\n{&quot;b&quot;: &quot;b3&quot;, &quot;a&quot;: &quot;a33&quot;}\r\n]\r\n```\r\n\r\nLet&#39;s decompose the command:\r\n\r\n*   ```sh\r\n    mlr join -f file1 -j &#39;b&#39; file2\r\n    ```\r\n    will join _file1_ and _file2_ on the field `b`. When an other field than `b` exists in **both** files (for ex. `a`) then it is the value of _file2_ that is outputted.\r\n    &lt;br&gt;So, for updating the JSON with the values in the CSV, _file1_ shall be the JSON and _file2_ the CSV.\r\n\r\n* `--ul` means to output the unjoinable lines of _file1_; without it, the output will only contain the records that have been &quot;paired&quot;.\r\n\r\n* With the `join` verb, Miller allows to specify a different **input format** for _file1_ than the one of _file2_; you set the default input format as `--icsv` (for handling _file2_) and override it with `--ijson` after the `join` verb (for handling _file1_).\r\n\r\n* The **output format** is set to JSON with `--ojson`. The `--no-jvstack` means to output one &quot;record&quot; per line.",
                "title": "Update a json file using csv file contents"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1674475222,
                "last_edit_date": 1674475222,
                "creation_date": 1674154397,
                "answer_id": 75177021,
                "question_id": 75164791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So I just figured it out that if I transform my csv file values into input readable format and use --arg instead of --argjson, the file gets update fine. So, the command `awk &#39;{gsub(/&quot;/,&quot;&quot;)};1&#39; b.csv &gt; c.csv` will convert the csv file into: \r\n```\r\na11,b1\r\na22,b2\r\na33,b3\r\n```\r\n\r\nSo, now if apply the command:\r\n```\r\nwhile IFS=&quot;,&quot;, read f1 f2\r\ndo\r\n  jq --arg k1 $f1 --arg k2 $f2 &#39;(.[] | select(.b == $k2) | .a) |= $k1&#39; sample.json| sponge sample.json\r\ndone &lt; c.csv\r\n```\r\nthe desired changes will take place. \r\n\r\nThe plausible reason why it failed in older format because when we read values using &quot;read&quot; command, it transforms `&quot;a&quot;` to `&quot;\\&quot;a\\&quot;&quot;`. So, each time I append the answer, it returns void answer.\r\n\r\nThe answer works with any type of json format. For example, if json object is like:\r\n```\r\n[\r\n { \r\n  &quot;d&quot;: { &quot;a&quot;:&quot;a1&quot;, &quot;c&quot;:&quot;c1&quot;},\r\n  &quot;b&quot;: &quot;b1&quot;\r\n  }\r\n]\r\n```\r\n\r\nwe can update the command to ` &#39;(.[] | select(.b == $k2) | .d.a) |= $k1&#39; `.\r\n\r\nI didn&#39;t try the other methods posted, but I appreciate for the help. \r\nThanks folks (@peak &amp; @Fravadona)",
                "title": "Update a json file using csv file contents"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1674475222,
        "creation_date": 1674072683,
        "last_edit_date": 1674098506,
        "question_id": 75164791,
        "body_markdown": "I&#39;ve 2 files: changes.csv and sample.json. My csv file is like following:\r\n\r\n```\r\nheader &quot;a&quot;, &quot;b&quot;\r\n      &quot;a11&quot;,&quot;b1&quot;\r\n      &quot;a22&quot;,&quot;b2&quot;\r\n      &quot;a33&quot;,&quot;b3&quot;\r\n```\r\nand the json file is like:\r\n```\r\n[\r\n {&quot;a&quot;:&quot;a1&quot;,&quot;b&quot;:&quot;b1&quot;},\r\n {&quot;a&quot;:&quot;a2&quot;,&quot;b&quot;:&quot;b2&quot;},\r\n {&quot;a&quot;:&quot;a3&quot;,&quot;b&quot;:&quot;b3&quot;},\r\n {&quot;a&quot;:&quot;a4&quot;,&quot;b&quot;:&quot;b4&quot;}\r\n]\r\n```\r\nI need to write a jq command, which make changes in json file using the csv file, i.e., the final output of the json file should be like following:\r\n```\r\n[\r\n {&quot;a&quot;:&quot;a11&quot;,&quot;b&quot;:&quot;b1&quot;},\r\n {&quot;a&quot;:&quot;a22&quot;,&quot;b&quot;:&quot;b2&quot;},\r\n {&quot;a&quot;:&quot;a33&quot;,&quot;b&quot;:&quot;b3&quot;},\r\n {&quot;a&quot;:&quot;a4&quot;,&quot;b&quot;:&quot;b4&quot;}\r\n]\r\n```\r\nI wrote the following command:\r\n\r\n```\r\nwhile IFS=&quot;,&quot;, read f1 f2\r\ndo\r\n  jq --argjson k1 $f1 --argjson k2 $f2 &#39;(.[] | select(.b == $k2) | .a) |= $k1&#39; sample.json| sponge sample.json\r\ndone &lt; changes.csv\r\n```\r\nAlthough, for each iteration it is able to filter and update the value of key &quot;a&quot;, but when I try to sponge the results into the json file, it is unable to do so. Don&#39;t know where exactly I am missing out.",
        "link": "https://stackoverflow.com/questions/75164791/update-a-json-file-using-csv-file-contents",
        "title": "Update a json file using csv file contents"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1674122292,
                "creation_date": 1674122292,
                "answer_id": 75170477,
                "question_id": 75170352,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By using `+=` to update your objects you&#39;re losing the context of what you&#39;re updating. So naturally you won&#39;t be able to reference the _current_ item. Instead you should use updating assignment instead. That way `.` refers to the current input and you can reference the other property directly.\r\n\r\n```\r\n.url as $URL | .issues[] |= . + { &quot;extra&quot; : &quot;\\( $URL )\\( .number )&quot;  }\r\n```",
                "title": "Creating composite value using other fields"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1674155518,
                "last_edit_date": 1674155518,
                "creation_date": 1674122367,
                "answer_id": 75170494,
                "question_id": 75170352,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use another variable for `.number`, just use `|=` instead of `+=` to keep the context:\r\n\r\n    .url as $url | .issues[] |= .number as $num | .extra = $url + ($num | tostring)",
                "title": "Creating composite value using other fields"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1674122927,
                "creation_date": 1674122927,
                "answer_id": 75170600,
                "question_id": 75170352,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Store the `.url` into a variable, traverse to the level of the `.issues[]` items, and update `|=` the `.extra` field. Use string interpolation `&quot;\\(…)&quot;` or `tostring` or `@text` to convert the numeral into a string, in order to add it to the previously stored url string:\r\n```sh\r\n. as {$url} | .issues[] |= (.extra = $url + &quot;\\(.number)&quot;)\r\n```\r\n```json\r\n{\r\n  &quot;url&quot;: &quot;https::/abc/&quot;,\r\n  &quot;issues&quot;: {\r\n    &quot;1&quot;: {\r\n      &quot;number&quot;: 1,\r\n      &quot;extra&quot;: &quot;https::/abc/1&quot;\r\n    },\r\n    &quot;2&quot;: {\r\n      &quot;number&quot;: 2,\r\n      &quot;extra&quot;: &quot;https::/abc/2&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/BhCqv_H7k59)",
                "title": "Creating composite value using other fields"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1674155518,
        "creation_date": 1674121694,
        "question_id": 75170352,
        "body_markdown": "Consider this json document\r\n\r\n```\r\n$ DATA=&#39;{ &quot;url&quot;: &quot;https::/abc/&quot;, &quot;issues&quot;: { &quot;1&quot;: { &quot;number&quot;: 1}, &quot;2&quot;: {&quot;number&quot;: 2 } } }&#39;\r\n\r\n$ echo $DATA | jq .\r\n{\r\n  &quot;url&quot;: &quot;https::/abc/&quot;,\r\n  &quot;issues&quot;: {\r\n    &quot;1&quot;: {\r\n      &quot;number&quot;: 1\r\n    },\r\n    &quot;2&quot;: {\r\n      &quot;number&quot;: 2\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI&#39;m trying to add a new field, called `extra` to the `issues` object that is a composite of the `.url` field and the `.number` fields. \r\n\r\nSo the result should look like this\r\n\r\n```\r\n{\r\n  &quot;url&quot;: &quot;https::/abc/&quot;,\r\n  &quot;issues&quot;: {\r\n    &quot;1&quot;: {\r\n      &quot;number&quot;: 1,\r\n      &quot;extra&quot;: &quot;https::/abc/1&quot;\r\n    },\r\n    &quot;2&quot;: {\r\n      &quot;number&quot;: 2,\r\n      &quot;extra&quot;: &quot;https::/abc/2&quot;\r\n    }\r\n  }\r\n```\r\n\r\n\r\n\r\nI can get part of the way there with the `.url` field by storing it in the a variable (`$URL`)\r\n\r\n```\r\n$ echo $DATA | jq &#39;.url as $URL | .issues[] += { &quot;extra&quot; : &quot;\\( $URL )&quot;  } &#39;\r\n{\r\n  &quot;url&quot;: &quot;https::/abc/&quot;,\r\n  &quot;issues&quot;: {\r\n    &quot;1&quot;: {\r\n      &quot;number&quot;: 1,\r\n      &quot;extra&quot;: &quot;https::/abc/&quot;\r\n    },\r\n    &quot;2&quot;: {\r\n      &quot;number&quot;: 2,\r\n      &quot;extra&quot;: &quot;https::/abc/&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nThe problem comes with getting access to `.number`. \r\n\r\nJust referencing `.number` in the composite value returns `null`\r\n```\r\n$ echo $DATA | jq &#39;.url as $URL | .issues[] += { &quot;extra&quot; : &quot;\\( $URL )\\( .number )&quot;  } &#39;\r\n{\r\n  &quot;url&quot;: &quot;https::/abc/&quot;,\r\n  &quot;issues&quot;: {\r\n    &quot;1&quot;: {\r\n      &quot;number&quot;: 1,\r\n      &quot;extra&quot;: &quot;https::/abc/null&quot;\r\n    },\r\n    &quot;2&quot;: {\r\n      &quot;number&quot;: 2,\r\n      &quot;extra&quot;: &quot;https::/abc/null&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nnext attempt was to try to store `.number` in a variable, but that didn&#39;t work\r\n\r\n```\r\n$ echo $DATA | jq &#39;.url as $URL | .issues[].number as $NUM  += { &quot;extra&quot; : &quot;\\( $URL )\\( $NUM )&quot;  } &#39;\r\njq: error: syntax error, unexpected +=, expecting &#39;|&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.url as $URL | .issues[].number as $NUM  += { &quot;extra&quot; : &quot;\\( $URL )\\( $NUM )&quot;  }                                          \r\njq: 1 compile error\r\n```\r\n\r\nAny ideas on what I&#39;m missing?",
        "link": "https://stackoverflow.com/questions/75170352/creating-composite-value-using-other-fields",
        "title": "Creating composite value using other fields"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674142179,
                "post_id": 75174502,
                "comment_id": 132655699,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1674142212,
                "post_id": 75174502,
                "comment_id": 132655713,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1535561,
                    "reputation": 8861,
                    "user_id": 1431720,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://www.gravatar.com/avatar/f5a1388d4d3b2bf03b11bb5658c68c29?s=256&d=identicon&r=PG",
                    "display_name": "Robert",
                    "link": "https://stackoverflow.com/users/1431720/robert"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674142340,
                "post_id": 75174502,
                "comment_id": 132655767,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1674142566,
                "post_id": 75174502,
                "comment_id": 132655834,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22841325,
                    "reputation": 85,
                    "user_id": 16988279,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7902a347904d525f3f206a20a1b84618?s=256&d=identicon&r=PG",
                    "display_name": "Ed Rogers",
                    "link": "https://stackoverflow.com/users/16988279/ed-rogers"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1674145746,
                "post_id": 75174502,
                "comment_id": 132656990,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674201376,
                "post_id": 75174502,
                "comment_id": 132667298,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1674150154,
                "last_edit_date": 1674150154,
                "creation_date": 1674144085,
                "answer_id": 75175028,
                "question_id": 75174502,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s see …\r\n\r\n0. Fix the input to be valid and well-formed JSON.\r\n1. Get the index of each array element with `to_entries`.\r\n2. Use `map(select(…))` pattern to extract all keys (i.e. the index) which match your predicate.\r\n3. &quot;Pad&quot; your extracted keys with adjacent keys: `+ range(3) - 1`.\r\n4. Store in variable.\r\n5. Use `map(select(…))` again on the entries to extract any item where the index matches one of the previously-extracted indices \r\n\r\nPutting it all together:\r\n\r\n```\r\nto_entries\r\n| map(select(.value.type.name==&quot;Pass&quot;).key + range(3) - 1) as $keys\r\n| map(select(.key|IN($keys[])).value)\r\n```\r\n\r\n`range(3)-1` produces the stream `-1,0,1` which means that all indices within range 1 will be checked. To check all indices with a max distance of 2, use `range(5)-2`.\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;class&quot;: &quot;Something2&quot;,\r\n    &quot;type&quot;: {\r\n      &quot;name&quot;: &quot;Carry&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;class&quot;: &quot;Something3&quot;,\r\n    &quot;type&quot;: {\r\n      &quot;name&quot;: &quot;Pass&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;class&quot;: &quot;Something4&quot;,\r\n    &quot;type&quot;: {\r\n      &quot;name&quot;: &quot;Pass&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;class&quot;: &quot;Something5&quot;,\r\n    &quot;type&quot;: {\r\n      &quot;name&quot;: &quot;Carry&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;class&quot;: &quot;Something9&quot;,\r\n    &quot;type&quot;: {\r\n      &quot;name&quot;: &quot;Carry&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;class&quot;: &quot;Something10&quot;,\r\n    &quot;type&quot;: {\r\n      &quot;name&quot;: &quot;Pass&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;class&quot;: &quot;Something1&quot;,\r\n    &quot;type&quot;: {\r\n      &quot;name&quot;: &quot;Carry&quot;\r\n    }\r\n  }\r\n]\r\n```",
                "title": "Use Bash and jq to filter array of objects based on values in an inner array, plus x objects before and after matching objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1674219870,
        "creation_date": 1674141817,
        "last_edit_date": 1674219870,
        "question_id": 75174502,
        "body_markdown": "Similar to [this problem](https://stackoverflow.com/questions/26701538/how-to-filter-an-array-of-objects-based-on-values-in-an-inner-array-with-jq) except I am trying to include objects before and after the matched objects.\r\n\r\nSo for example I want to find all objects with type.name=&#39;pass&#39;, plus any object that is within X (say 2) of this object, either before or after. \r\n\r\nThis JSON:\r\n\r\n```\r\n    [\r\n     {\r\n       &quot;class&quot;: &quot;Something1&quot;,\r\n       &quot;type&quot;: {\r\n         &quot;name&quot;: &quot;Foul&quot;\r\n       }\r\n     },\r\n     {\r\n       &quot;class&quot;: &quot;Something2&quot;,\r\n       &quot;type&quot;: {\r\n         &quot;name&quot;: &quot;Carry&quot;\r\n       }\r\n     },\r\n     {\r\n       &quot;class&quot;: &quot;Something3&quot;,\r\n       &quot;type&quot;: {\r\n         &quot;name&quot;: &quot;Pass&quot;\r\n       }\r\n     },\r\n     {\r\n       &quot;class&quot;: &quot;Something4&quot;,\r\n       &quot;type&quot;: {\r\n         &quot;name&quot;: &quot;Pass&quot;\r\n       }\r\n     },\r\n     {\r\n       &quot;class&quot;: &quot;Something5&quot;,\r\n       &quot;type&quot;: {\r\n         &quot;name&quot;: &quot;Carry&quot;\r\n       }\r\n     },\r\n     {\r\n       &quot;class&quot;: &quot;Something6&quot;,\r\n       &quot;type&quot;: {\r\n         &quot;name&quot;: &quot;Carry&quot;\r\n       }\r\n     },\r\n     {\r\n       &quot;class&quot;: &quot;Something7&quot;,\r\n       &quot;type&quot;: {\r\n         &quot;name&quot;: &quot;Other&quot;\r\n       }\r\n     },\r\n     {\r\n       &quot;class&quot;: &quot;Something8&quot;,\r\n       &quot;type&quot;: {\r\n         &quot;name&quot;: &quot;Other&quot;\r\n       }\r\n     },\r\n     {\r\n       &quot;class&quot;: &quot;Something9&quot;,\r\n       &quot;type&quot;: {\r\n         &quot;name&quot;: &quot;Carry&quot;\r\n       }\r\n     },\r\n     {\r\n       &quot;class&quot;: &quot;Something10&quot;,\r\n       &quot;type&quot;: {\r\n         &quot;name&quot;: &quot;Pass&quot;\r\n       }\r\n     },\r\n     {\r\n       &quot;class&quot;: &quot;Something1&quot;,\r\n       &quot;type&quot;: {\r\n         &quot;name&quot;: &quot;Carry&quot;\r\n       }\r\n     },\r\n     {\r\n       &quot;class&quot;: &quot;Something2&quot;,\r\n       &quot;type&quot;: {\r\n         &quot;name&quot;: &quot;Carry&quot;\r\n       }\r\n     },\r\n     {\r\n       &quot;class&quot;: &quot;Something3&quot;,\r\n       &quot;type&quot;: {\r\n         &quot;name&quot;: &quot;Carry&quot;\r\n       }\r\n     },\r\n     {\r\n       &quot;class&quot;: &quot;Something4&quot;,\r\n       &quot;type&quot;: {\r\n         &quot;name&quot;: &quot;Other&quot;\r\n       }\r\n     },\r\n     {\r\n       &quot;class&quot;: &quot;Something5&quot;,\r\n       &quot;type&quot;: {\r\n         &quot;name&quot;: &quot;Carry&quot;\r\n       }\r\n     }\r\n    ]\r\n```\r\n\r\n\r\nWould output a new JSON string:\r\n\r\n```\r\n    [\r\n      {\r\n        &quot;class&quot;: &quot;Something1&quot;,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;Foul&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;class&quot;: &quot;Something2&quot;,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;Carry&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;class&quot;: &quot;Something3&quot;,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;Pass&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;class&quot;: &quot;Something4&quot;,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;Pass&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;class&quot;: &quot;Something5&quot;,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;Carry&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;class&quot;: &quot;Something6&quot;,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;Carry&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;class&quot;: &quot;Something8&quot;,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;Other&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;class&quot;: &quot;Something9&quot;,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;Carry&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;class&quot;: &quot;Something10&quot;,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;Pass&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;class&quot;: &quot;Something1&quot;,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;Carry&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;class&quot;: &quot;Something2&quot;,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;Carry&quot;\r\n        }\r\n      }\r\n    ]\r\n```\r\n\r\nOr it could output the index of the above objects in a list which can then be used to search the original JSON. \r\n\r\nI can filter by &quot;type.name&quot; thanks to the answer quoted above, but I could not work out how to include surrounding objects. \r\n\r\n```\r\n    $ passes=$(cat file.json | jq -c &#39;[ .[] | select( .type.name | contains(&quot;Pass&quot;)) ]&#39;)\r\n```\r\n\r\nThe files I am working with are 140,000+ lines long so efficiency is important. \r\n\r\nEdit: Thanks @Gilles Quenot for fixing the code formatting.\r\n\r\nEdit: Corrected errors in JSON and explained approach taken so far.\r\n",
        "link": "https://stackoverflow.com/questions/75174502/use-bash-and-jq-to-filter-array-of-objects-based-on-values-in-an-inner-array-pl",
        "title": "Use Bash and jq to filter array of objects based on values in an inner array, plus x objects before and after matching objects?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1674632935,
                "last_edit_date": 1674632935,
                "creation_date": 1674145093,
                "answer_id": 75175231,
                "question_id": 75175190,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the `keys_unsorted` builtin, since the underlying object is a dictionary and _not_ a list\r\n\r\n```none\r\n.top_facts_mapping | keys_unsorted[0] as $k | .[$k] | .[keys_unsorted[0]]\r\n```\r\n\r\nThe above filter could be re-written with a simple function\r\n\r\n```none\r\ndef get_firstkey_val: keys_unsorted[0] as $k | .[$k];\r\n\r\n.top_facts_mapping | \r\n  get_firstkey_val | get_firstkey_val\r\n```\r\n\r\nOr with some jq trick-play, assumes the path provided `top_facts_mapping` is guaranteed to exist\r\n\r\n```none\r\ngetpath([ paths | select(.[-3] == &quot;top_facts_mapping&quot; ) ] | first)\r\n```\r\n\r\nSince the `paths` built-in constructs the root to leaf paths as arrays, we all paths containing the second to last field (denoted by `.[-3]`) as `&quot;top_facts_mapping&quot;` which returns paths inside it\r\n\r\nFrom which `first` selects the first entity in the list i.e. below list \r\n\r\n```json\r\n[\r\n  &quot;top_facts_mapping&quot;,\r\n  &quot;AWS&quot;,\r\n  &quot;ECS&quot;\r\n]\r\n```\r\n\r\nUse `getpath/1` to obtain the JSON value at the obtained path.\r\n\r\nIf there is a risk of the key `top_facts_mapping` not being present in the JSON, `getpath/1` could return an error as written above. Fix it by adding a proper check\r\n\r\n```none\r\n([ paths | select(.[-3] == &quot;top_facts_mapping&quot; ) ] | first) as $p | \r\nif $p | length &gt; 0 then getpath($p) else empty end\r\n```",
                "title": "Access to first key of a nested json using jq and obtain its value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1674150414,
                "creation_date": 1674150414,
                "answer_id": 75176310,
                "question_id": 75175190,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `to_entries` to turn the object into an array of key-value pairs, then select the first value using `[0].value`\r\n\r\n```sh\r\n.top_facts_mapping | to_entries[0].value | to_entries[0].value\r\n```\r\n```json\r\n{\r\n  &quot;attachments&quot;: [\r\n    &quot;restart_ecs&quot;\r\n  ],\r\n  &quot;text&quot;: [\r\n    &quot;Great!&quot;\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/JsEVJityeDq)\r\n\r\nIf at one level the object may be empty, you can prepend each `to_entries` with `try` (optionally followed by a `catch` clause)",
                "title": "Access to first key of a nested json using jq and obtain its value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1674152123,
                "creation_date": 1674152123,
                "answer_id": 75176623,
                "question_id": 75175190,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a stream-based approach which disassembles the input using the `--stream` option, filters for the &quot;top_facts_mapping&quot; key on top level `.[0][0]`, truncates the stream to descend 3 levels, re-assembles the stream using `fromstream`, and outputs the `first` match:\r\n```sh\r\njq --stream -n &#39;first(fromstream(3| truncate_stream(inputs | select(.[0][0] == &quot;top_facts_mapping&quot;))))&#39;\r\n```\r\n```json\r\n{\r\n  &quot;attachments&quot;: [\r\n    &quot;restart_ecs&quot;\r\n  ],\r\n  &quot;text&quot;: [\r\n    &quot;Great!&quot;\r\n  ]\r\n}\r\n```",
                "title": "Access to first key of a nested json using jq and obtain its value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1674632935,
        "creation_date": 1674144906,
        "last_edit_date": 1674149836,
        "question_id": 75175190,
        "body_markdown": "I have the following JSON:\r\n\r\n    {\r\n        &quot;query&quot;: &quot;rest ec&quot;,\r\n        &quot;elected_facts_mapping&quot;: {\r\n            &quot;AWS&quot;: {\r\n                &quot;ECS&quot;: {\r\n                    &quot;attachments&quot;: [\r\n                        &quot;restart_ecs&quot;\r\n                    ],\r\n                    &quot;text&quot;: [\r\n                        &quot;Great!&quot;\r\n                    ]\r\n                }\r\n            }\r\n        },\r\n        &quot;top_facts_mapping&quot;: {\r\n            &quot;AWS&quot;: {\r\n                &quot;ECS&quot;: {\r\n                    &quot;attachments&quot;: [\r\n                        &quot;restart_ecs&quot;\r\n                    ],\r\n                    &quot;text&quot;: [\r\n                        &quot;Great!&quot;\r\n                    ]\r\n                },\r\n                &quot;EC2&quot;: {\r\n                    &quot;attachments&quot;: [\r\n                        &quot;create_ec2&quot;\r\n                    ],\r\n                    &quot;text&quot;: [\r\n                        &quot;Awesome&quot;\r\n                    ]\r\n                }\r\n            },\r\n            &quot;GitHub&quot;: {\r\n                &quot;Pull&quot;: {\r\n                    &quot;attachments&quot;: [\r\n                        &quot;pull_req&quot;\r\n                    ],\r\n                    &quot;text&quot;: [\r\n                        &quot;Be right on it&quot;\r\n                    ]\r\n                }\r\n            },\r\n            &quot;testtttt&quot;: {\r\n                &quot;test&quot;: {\r\n                    &quot;attachments&quot;: [\r\n                        &quot;hello_world&quot;\r\n                    ],\r\n                    &quot;text&quot;: [\r\n                        &quot;Be right on it&quot;\r\n                    ]\r\n                }\r\n            },\r\n            &quot;fgjgh&quot;: {\r\n                &quot;fnfgj&quot;: {\r\n                    &quot;attachments&quot;: [\r\n                        &quot;hello_world&quot;\r\n                    ],\r\n                    &quot;text&quot;: [\r\n                        &quot;Be right on it&quot;\r\n                    ]\r\n                }\r\n            },\r\n            &quot;tessttertre&quot;: {\r\n                &quot;gfdgfdgfd&quot;: {\r\n                    &quot;attachments&quot;: [\r\n                        &quot;hello_world&quot;\r\n                    ],\r\n                    &quot;text&quot;: [\r\n                        &quot;Great!&quot;\r\n                    ]\r\n                }\r\n            }\r\n        },\r\n        &quot;elected_facts_with_prefix_text&quot;: null\r\n    }\r\n\r\nAnd I want to access to `top_facts_mapping&#39;s` first key `AWS` and it&#39;s first key `ECS`\r\n\r\nI am trying to do this (in my DSL):\r\n\r\n    &#39;.span | fromjson&#39;\r\n    &#39;.span_data.top_facts_mapping | keys[0]&#39;\r\n    &#39;.span_data.top_facts_mapping[${top_facts_prepare_top_fact_topic}] | keys[0]&#39;\r\n    &#39;.top_facts_prepare_top_fact_topic_subtopic[${top_facts_prepare_top_fact_topic}][${top_facts_prepare_top_fact_topic_subtopic}]&#39;",
        "link": "https://stackoverflow.com/questions/75175190/access-to-first-key-of-a-nested-json-using-jq-and-obtain-its-value",
        "title": "Access to first key of a nested json using jq and obtain its value"
    },
    {
        "tags": [
            "json",
            "jq",
            "stdin"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1674336859,
                "creation_date": 1674336859,
                "answer_id": 75196720,
                "question_id": 75196689,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By default, `jq` reads from `stdin`. The `-R` flag lets you read raw input streamed linewise. Using `[inputs]` in combination with the `-n` flag lets you collect the lines into an array.\r\n```sh\r\n… | jq -Rn &#39;{cmd: &quot;In&quot;, lines: [inputs]}&#39;\r\n```",
                "title": "how transform stdin input to some json field in list of lines using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1674336859,
        "creation_date": 1674336549,
        "question_id": 75196689,
        "body_markdown": "I need a utility that\r\n  - read from stdin, split as lines\r\n  - write to stdout json object, {&quot;cmd&quot;: &quot;In&quot;, &quot;lines&quot;: [lines from stdin]}\r\n\r\nI heard jq being quite powerful, how to acheive above with jq or similar tools.\r\n",
        "link": "https://stackoverflow.com/questions/75196689/how-transform-stdin-input-to-some-json-field-in-list-of-lines-using-jq",
        "title": "how transform stdin input to some json field in list of lines using jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "optimization",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1674579148,
                "last_edit_date": 1674579148,
                "creation_date": 1674476983,
                "answer_id": 75209523,
                "question_id": 75208673,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t overthink it; add a fixed header and use `inputs` together with `-n`/`--null-input` to format the actual content:\r\n\r\n```\r\njq -n &#39;[&quot;name&quot;, &quot;value_a&quot;, &quot;value_b&quot;],\r\n(inputs | [.name?, .value_a?, .value_b?])\r\n| @csv&#39; input.json\r\n```\r\n\r\nOutput:\r\n\r\n```csv\r\n&quot;name&quot;,&quot;value_a&quot;,&quot;value_b&quot;\r\n&quot;name_0&quot;,&quot;value_a_0&quot;,&quot;val_b_0&quot;\r\n&quot;name_1&quot;,&quot;value_a_1&quot;,&quot;val_b_1&quot;\r\n&quot;name_2&quot;,&quot;value_a_2&quot;,&quot;val_b_2&quot;\r\n&quot;name_3&quot;,&quot;value_a_3&quot;,&quot;val_b_3&quot;\r\n&quot;name_4&quot;,&quot;value_a_4&quot;,&quot;val_b_4&quot;\r\n```",
                "title": "jq convert jsonlines to csv with header without slurp"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1674545661,
                "creation_date": 1674545661,
                "answer_id": 75218585,
                "question_id": 75208673,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "it&#39;s not jq, but I add it because I think it&#39;s interesting to know it.\r\n\r\nUsing [Miller][1] and run\r\n\r\n```\r\nmlr --j2c cat input.jsonl &gt;output.csv\r\n```\r\n\r\nyou get\r\n\r\n```\r\nname,value_a,value_b\r\nname_0,value_a_0,val_b_0\r\nname_1,value_a_1,val_b_1\r\nname_2,value_a_2,val_b_2\r\nname_3,value_a_3,val_b_3\r\nname_4,value_a_4,val_b_4\r\n```\r\n\r\n\r\n  [1]: https://miller.readthedocs.io/en/latest/installing-miller/",
                "title": "jq convert jsonlines to csv with header without slurp"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1675125177,
        "creation_date": 1674472279,
        "last_edit_date": 1675125177,
        "question_id": 75208673,
        "body_markdown": "a potentially huge json-lines file with objects of known structure is to be converted to csv with headers.\r\n\r\nexample\r\n\r\n```\r\n{&quot;name&quot;:&quot;name_0&quot;,&quot;value_a&quot;:&quot;value_a_0&quot;,&quot;value_b&quot;:&quot;val_b_0&quot;}\r\n{&quot;name&quot;:&quot;name_1&quot;,&quot;value_a&quot;:&quot;value_a_1&quot;,&quot;value_b&quot;:&quot;val_b_1&quot;}\r\n{&quot;name&quot;:&quot;name_2&quot;,&quot;value_a&quot;:&quot;value_a_2&quot;,&quot;value_b&quot;:&quot;val_b_2&quot;}\r\n{&quot;name&quot;:&quot;name_3&quot;,&quot;value_a&quot;:&quot;value_a_3&quot;,&quot;value_b&quot;:&quot;val_b_3&quot;}\r\n{&quot;name&quot;:&quot;name_4&quot;,&quot;value_a&quot;:&quot;value_a_4&quot;,&quot;value_b&quot;:&quot;val_b_4&quot;}\r\n```\r\n\r\nexpected output\r\n\r\n```\r\n&quot;name&quot;,&quot;value_a&quot;,&quot;value_b&quot;\r\n&quot;name_0&quot;,&quot;value_a_0&quot;,&quot;val_b_0&quot;\r\n&quot;name_1&quot;,&quot;value_a_1&quot;,&quot;val_b_1&quot;\r\n&quot;name_2&quot;,&quot;value_a_2&quot;,&quot;val_b_2&quot;\r\n&quot;name_3&quot;,&quot;value_a_3&quot;,&quot;val_b_3&quot;\r\n&quot;name_4&quot;,&quot;value_a_4&quot;,&quot;val_b_4&quot;\r\n```\r\n\r\ncurrently tried\r\n\r\n```\r\n(if (input_line_number == 1 ) then ([.|to_entries|.[].key]|@csv) else empty end), \r\n(.|to_entries|[.[].value]|@csv  )\r\n```\r\n\r\nHowever this relies on the order in the json\r\nas an alternative I have substituted it with directly selecting the values in the order I want.\r\n\r\n```\r\n(if (input_line_number == 1 ) then (&quot;\\&quot;name\\&quot;,\\&quot;value_a\\&quot;,\\&quot;value_b\\&quot;&quot;) else empty end), (.|[.name?,.value_a?,.value_b?]|@csv  ) \r\n```\r\n\r\n[jqplay](https://jqplay.org/s/N5rdE9cOu-g)\r\n\r\nany better solution? especially regarding the if, as it feels bulky.\r\n\r\nI mainly don&#39;t want to use slurp because it will resort to load the whole file into memory",
        "link": "https://stackoverflow.com/questions/75208673/jq-convert-jsonlines-to-csv-with-header-without-slurp",
        "title": "jq convert jsonlines to csv with header without slurp"
    },
    {
        "tags": [
            "json",
            "csv",
            "command-line",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674482184,
                "post_id": 75210490,
                "comment_id": 132716885,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674482671,
                "post_id": 75210490,
                "comment_id": 132717050,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1674482996,
                "creation_date": 1674482996,
                "answer_id": 75210678,
                "question_id": 75210490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming valid JSON input:\r\n\r\n```json\r\n{\r\n  &quot;tables&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;PrimaryResult&quot;,\r\n      &quot;columns&quot;: [\r\n        { &quot;name&quot;: &quot;name&quot;,   &quot;type&quot;: &quot;string&quot;  },\r\n        { &quot;name&quot;: &quot;id&quot;,     &quot;type&quot;: &quot;string&quot;  },\r\n        { &quot;name&quot;: &quot;custom&quot;, &quot;type&quot;: &quot;dynamic&quot; }\r\n      ],\r\n      &quot;rows&quot;: [\r\n        &quot;Alpha&quot;,\r\n        &quot;1&quot;,\r\n        &quot;{\\&quot;age\\&quot;:\\&quot;23\\&quot;,\\&quot;number\\&quot;:\\&quot;xyz\\&quot;}&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAnd assuming fixed headers:\r\n\r\n```\r\njq -r &#39;[&quot;name&quot;, &quot;id&quot;, &quot;age&quot;, &quot;number&quot;],\r\n(.tables[].rows | [.[0,1], (.[2] | fromjson | .age, .number)])\r\n| @csv&#39; input.json\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n&quot;name&quot;,&quot;id&quot;,&quot;age&quot;,&quot;number&quot;\r\n&quot;Alpha&quot;,&quot;1&quot;,&quot;23&quot;,&quot;xyz&quot;\r\n```\r\n\r\nIf any of the assumptions is wrong, you need to clarify your requirements, e.g.\r\n\r\n* How are column names determined?\r\n* What happens if the input contains multiple tables?\r\n* As the &quot;dynamic&quot; object always of the same shape? Or can it sometimes contain fewer, more, or different columns?",
                "title": "How to parse nested json to csv using command line"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1674487566,
                "last_edit_date": 1674487566,
                "creation_date": 1674485684,
                "answer_id": 75211217,
                "question_id": 75210490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming that the `.rows` array is a 2D array of rows and fields, and that a column of type &quot;dynamic&quot; always expects a JSON-encoded object whose fields represent further columns but may or may not always be present in every row.\r\n\r\nThen you could go with transposing the headers array and the rows array in order to integratively process each column by their type, especially collecting all keys from the &quot;dynamic&quot; type on the fly, and then transpose it back to get the row-based CSV output.\r\n\r\n#### Input (I have added another row for illustration):\r\n```json\r\n{\r\n  &quot;tables&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;PrimaryResult&quot;,\r\n      &quot;columns&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;name&quot;,\r\n          &quot;type&quot;: &quot;string&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;id&quot;,\r\n          &quot;type&quot;: &quot;string&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;custom&quot;,\r\n          &quot;type&quot;: &quot;dynamic&quot;\r\n        }\r\n      ],\r\n      &quot;rows&quot;: [\r\n        [\r\n          &quot;Alpha&quot;,\r\n          &quot;1&quot;,\r\n          &quot;{\\&quot;age\\&quot;:\\&quot;23\\&quot;,\\&quot;number\\&quot;:\\&quot;123\\&quot;}&quot;\r\n        ],\r\n        [\r\n          &quot;Beta&quot;,\r\n          &quot;2&quot;,\r\n          &quot;{\\&quot;age\\&quot;:\\&quot;45\\&quot;,\\&quot;word\\&quot;:\\&quot;xyz\\&quot;}&quot;\r\n        ]\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n#### Filter:\r\n```sh\r\njq -r &#39;\r\n  .tables[] | [.columns, .rows[]] | transpose | map(\r\n    if first.type == &quot;string&quot; then first |= .name\r\n    elif first.type == &quot;dynamic&quot; then\r\n      .[1:] | map(fromjson)\r\n      | (map(keys[]) | unique) as $keys\r\n      | [$keys, (.[] | [.[$keys[]]])] | transpose[]\r\n    else empty end\r\n  )\r\n  | transpose[] | @csv\r\n&#39;\r\n```\r\n\r\n#### Output:\r\n```csv\r\n&quot;name&quot;,&quot;id&quot;,&quot;age&quot;,&quot;number&quot;,&quot;word&quot;\r\n&quot;Alpha&quot;,&quot;1&quot;,&quot;23&quot;,&quot;123&quot;,\r\n&quot;Beta&quot;,&quot;2&quot;,&quot;45&quot;,,&quot;xyz&quot;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/rsv9kNOmvDJ)",
                "title": "How to parse nested json to csv using command line"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1674487566,
        "creation_date": 1674482028,
        "last_edit_date": 1674482125,
        "question_id": 75210490,
        "body_markdown": "I want to parse a nested json to csv. The data looks similar to this.\r\n\r\n```\r\n{&quot;tables&quot;:[{&quot;name&quot;:&quot;PrimaryResult&quot;,&quot;columns&quot;:[{&quot;name&quot;:&quot;name&quot;,&quot;type&quot;:&quot;string&quot;},{&quot;name&quot;:&quot;id&quot;,&quot;type&quot;:&quot;string&quot;},{&quot;name&quot;:&quot;custom&quot;,&quot;type&quot;:&quot;dynamic&quot;}]&quot;rows&quot;:[[&quot;Alpha&quot;,&quot;1&quot;,&quot;{\\&quot;age\\&quot;:\\&quot;23\\&quot;,\\&quot;number\\&quot;:\\&quot;xyz\\&quot;}]]]}\r\n```\r\n\r\nI want csv file as:\r\n\r\n```\r\nname  id  age  number\r\nalpha  1  23    xyz\r\n```\r\n\r\nI tried:\r\n\r\n```\r\njq -r &quot;.tables | .[] | .columns | map(.name)|@csv&quot; demo.json &gt; demo.csv\r\njq -r &quot;.tables | .[] | .rows |.[]|@csv&quot; demo.json &gt;&gt; demo.csv\r\n```\r\n\r\nBut I am not getting expected result.\r\n\r\nOutput: \r\n\r\n```\r\nname   id  custom\r\nalpha  1   {&quot;age&quot;:&quot;23&quot;,&quot;number&quot;:&quot;xyz}\r\n\r\nExpected:\r\nname  id  age  number\r\nalpha  1  23    xyz\r\n```",
        "link": "https://stackoverflow.com/questions/75210490/how-to-parse-nested-json-to-csv-using-command-line",
        "title": "How to parse nested json to csv using command line"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674502477,
                "post_id": 75212907,
                "comment_id": 132723602,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674502511,
                "post_id": 75212907,
                "comment_id": 132723615,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1674495635,
                "last_edit_date": 1674495635,
                "creation_date": 1674494827,
                "answer_id": 75212997,
                "question_id": 75212907,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t know what role the argument `[&quot;1&quot;,&quot;2&quot;,&quot;3&quot;]` should play, but apart from that, you can convert the object items from string to boolean using `fromjson`, then aggregate them appropriately, and use this result in a `map(select(…))` clause to filter the input array.\r\n\r\nNow, if you want to remove items\r\n&gt; if at least one key is not &quot;true&quot;\r\n\r\nmeaning you want to keep only those that are entirely `true`, use the `all` aggregator:\r\n\r\n```sh\r\njq &#39;map(select(map(fromjson) | all))&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;1&quot;: &quot;true&quot;,\r\n    &quot;2&quot;: &quot;true&quot;,\r\n    &quot;3&quot;: &quot;true&quot;\r\n  }\r\n]\r\n\r\n```\r\n[Demo](https://jqplay.org/s/WEVgZ9Y5W3_B)\r\n\r\nBut if, as your desired output suggests, you want to remove those items that are entirely `false`, meaning to keep only those where there is at least one value which is `true`, use the `any` aggregator:\r\n\r\n```sh\r\njq &#39;map(select(map(fromjson) | any))&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;1&quot;: &quot;false&quot;,\r\n    &quot;2&quot;: &quot;true&quot;,\r\n    &quot;3&quot;: &quot;true&quot;\r\n  },\r\n  {\r\n    &quot;1&quot;: &quot;true&quot;,\r\n    &quot;2&quot;: &quot;true&quot;,\r\n    &quot;3&quot;: &quot;true&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/iQoTuq-WkDm)",
                "title": "Remove JSON element if key equals true (jq)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1674495635,
        "creation_date": 1674494307,
        "last_edit_date": 1674494860,
        "question_id": 75212907,
        "body_markdown": "Given JSON:\r\n\r\n    [\r\n      {\r\n        &quot;1&quot;: &quot;false&quot;\r\n        &quot;2&quot;: &quot;true&quot;,\r\n        &quot;3&quot;: &quot;true&quot;\r\n      },\r\n      {\r\n        &quot;1&quot;: &quot;false&quot;\r\n        &quot;2&quot;: &quot;false&quot;,\r\n        &quot;3&quot;: &quot;false&quot;\r\n      },\r\n      {\r\n        &quot;1&quot;: &quot;true&quot;\r\n        &quot;2&quot;: &quot;true&quot;,\r\n        &quot;3&quot;: &quot;true&quot;\r\n      }\r\n    ]\r\n\r\nGiven array as an argument passed to jq:\r\n\r\n    [&quot;1&quot;,&quot;2&quot;,&quot;3&quot;]\r\n\r\nNeed to remove JSON element using jq tool if at least one key is not &quot;true&quot;.\r\n\r\nDesired output:\r\n\r\n    [\r\n      {\r\n        &quot;1&quot;: &quot;false&quot;\r\n        &quot;2&quot;: &quot;true&quot;,\r\n        &quot;3&quot;: &quot;true&quot;\r\n      },\r\n      {\r\n        &quot;1&quot;: &quot;true&quot;\r\n        &quot;2&quot;: &quot;true&quot;,\r\n        &quot;3&quot;: &quot;true&quot;\r\n      }\r\n    ]\r\n\r\nGiven JSON:\r\n\r\n    [\r\n      {\r\n        &quot;1&quot;: &quot;false&quot;\r\n        &quot;2&quot;: &quot;true&quot;,\r\n        &quot;3&quot;: &quot;true&quot;\r\n      },\r\n      {\r\n        &quot;1&quot;: &quot;false&quot;\r\n        &quot;2&quot;: &quot;false&quot;,\r\n        &quot;3&quot;: &quot;false&quot;\r\n      },\r\n      {\r\n        &quot;1&quot;: &quot;true&quot;\r\n        &quot;2&quot;: &quot;true&quot;,\r\n        &quot;3&quot;: &quot;true&quot;\r\n      }\r\n    ]\r\n\r\nGiven array as an argument passed to jq:\r\n\r\n    [&quot;1&quot;,&quot;2&quot;,&quot;3&quot;]\r\n\r\nNeed to remove JSON element using jq tool if at least one key is not &quot;true&quot;.\r\n\r\nDesired output:\r\n\r\n    [\r\n      {\r\n        &quot;1&quot;: &quot;false&quot;\r\n        &quot;2&quot;: &quot;true&quot;,\r\n        &quot;3&quot;: &quot;true&quot;\r\n      },\r\n      {\r\n        &quot;1&quot;: &quot;true&quot;\r\n        &quot;2&quot;: &quot;true&quot;,\r\n        &quot;3&quot;: &quot;true&quot;\r\n      }\r\n    ]\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75212907/remove-json-element-if-key-equals-true-jq",
        "title": "Remove JSON element if key equals true (jq)"
    },
    {
        "tags": [
            "arrays",
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1674507387,
                "last_edit_date": 1674507387,
                "creation_date": 1674506961,
                "answer_id": 75214898,
                "question_id": 75214867,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Sure. Specify `-c`/`--compact-output` and use `map` to extract an array:\r\n\r\n```\r\njq -c &#39;.definition.services | map(.image.name)&#39; input.json\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n[&quot;img1&quot;,&quot;img2&quot;,&quot;img3&quot;]\r\n```\r\n\r\nIf your requirement is to have the unquoted names (I would be surprised, but who knows), then resort to `join/1` and `-r`/`--raw-output`:\r\n\r\n```\r\njq -r &#39;&quot;[\\(.definition.services | map(.image.name) | join(&quot;,&quot;))]&quot;&#39; input.json\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n[img1,img2,img3]\r\n```\r\n\r\nAll in one go, producing exactly the required output from your question (minus the blanks):\r\n\r\n```\r\njq -r &#39;\r\n  .definition.services\r\n  | &quot;images=[\\(map(.image.name) | join(&quot;,&quot;))]&quot;,\r\n    &quot;tags=[\\(map(.image.tag) | join(&quot;,&quot;))]&quot;\r\n&#39; input.json\r\n```\r\n\r\nBut maybe you need those quotes after all? Leverage the fact that arrays will be stringified for you:\r\n\r\n```\r\njq -r &#39;\r\n  .definition.services\r\n  | &quot;images=\\(map(.image.name))&quot;,\r\n    &quot;tags=\\(map(.image.tag))&quot;\r\n&#39; input.json\r\n```\r\n\r\nOutput:\r\n\r\n```\r\nimages=[&quot;img1&quot;,&quot;img2&quot;,&quot;img3&quot;]\r\ntags=[&quot;2.0.1&quot;,&quot;1.4.0&quot;,&quot;1.2.5&quot;]\r\n```",
                "title": "Extract values from an array in json in one line in Linux bash. With jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1674507387,
        "creation_date": 1674506781,
        "question_id": 75214867,
        "body_markdown": "Given such a json (very simplified from my real use case), which file is service-def-test.json:\r\n\r\n\t{\r\n\t\t&quot;definition&quot;: {\r\n\t\t\t&quot;services&quot;: [{\r\n\t\t\t\t\t&quot;image&quot;: {\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;img1&quot;,\r\n\t\t\t\t\t\t&quot;tag&quot;: &quot;2.0.1&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}, {\r\n\t\t\t\t\t&quot;image&quot;: {\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;img2&quot;,\r\n\t\t\t\t\t\t&quot;tag&quot;: &quot;1.4.0&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}, {\r\n\t\t\t\t\t&quot;image&quot;: {\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;img3&quot;,\r\n\t\t\t\t\t\t&quot;tag&quot;: &quot;1.2.5&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t}\r\n\t}\r\n\r\nI would like to get twice a one-line list of values, so that I could export each line to a variable and proceed it eventually:\r\n\r\n    images=[img1, img2, img3]\r\n    tags=[2.0.1, 1.4.0, 1.2.5]\r\n\r\njq is probably the way to go\r\n   \r\n    jq -r .definition.services[].image.name service-def-test.json\r\n\r\ngives \r\n\r\n    img1\r\n    img2\r\n    img3\r\n\r\nHow could I transform that to one line?\r\nCould jq directly output what I want? I tried options like -c but I did not manage to have the output in one line.\r\nOther though is about used sed or awk to transform the output.\r\n\r\nWhat would be your simplest solution?",
        "link": "https://stackoverflow.com/questions/75214867/extract-values-from-an-array-in-json-in-one-line-in-linux-bash-with-jq",
        "title": "Extract values from an array in json in one line in Linux bash. With jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10275035,
                    "reputation": 121775,
                    "user_id": 7582247,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KPNHoVDG.png?s=256",
                    "display_name": "Ted Lyngmo",
                    "link": "https://stackoverflow.com/users/7582247/ted-lyngmo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674573146,
                "post_id": 75223364,
                "comment_id": 132739933,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1674573401,
                "creation_date": 1674573401,
                "answer_id": 75223514,
                "question_id": 75223364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your stream really looks like in your question, this should do:\r\n```jq\r\njq &#39;INDEX(.id)&#39; test.json\r\n```\r\nOutput:\r\n```json\r\n{\r\n  &quot;1&quot;: {\r\n    &quot;id&quot;: &quot;1&quot;,\r\n    &quot;userId&quot;: &quot;fa51531d&quot;\r\n  },\r\n  &quot;2&quot;: {\r\n    &quot;id&quot;: &quot;2&quot;,\r\n    &quot;userId&quot;: &quot;a167869a&quot;\r\n  }\r\n}\r\n```",
                "title": "Transform JSON array to object with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1674573572,
                "creation_date": 1674573572,
                "answer_id": 75223548,
                "question_id": 75223364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are trying to recreate the whole input object, the stream-based approach is rendered pointless. That said, using this approach, there&#39;s no need to truncate. So either replace `1` with `0`:\r\n```sh\r\njq -n --stream &#39;fromstream(0|truncate_stream(inputs)) | INDEX(.id)&#39;\r\n```\r\nOr just omit it entirely (which reveals its futility):\r\n```sh\r\njq -n --stream &#39;fromstream(inputs) | INDEX(.id)&#39;\r\n```\r\n\r\n---\r\nWhat would make more sense, is to output a stream of objects, each indexed as with `INDEX`. Maybe you were looking for this:\r\n```sh\r\njq -n --stream &#39;fromstream(1|truncate_stream(inputs)) | {(.id):.}&#39;\r\n```\r\n```json\r\n{\r\n  &quot;1&quot;: {\r\n    &quot;id&quot;: &quot;1&quot;,\r\n    &quot;userId&quot;: &quot;fa51531d&quot;\r\n  }\r\n}\r\n{\r\n  &quot;2&quot;: {\r\n    &quot;id&quot;: &quot;2&quot;,\r\n    &quot;userId&quot;: &quot;a167869a&quot;\r\n  }\r\n}\r\n```",
                "title": "Transform JSON array to object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1674573572,
        "creation_date": 1674572606,
        "last_edit_date": 1674572678,
        "question_id": 75223364,
        "body_markdown": "I&#39;m trying to transform array to object by specific key. It works fine without using stream, but not possible when stream is applied.\r\n\r\n\r\nData:\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;1&quot;,\r\n    &quot;userId&quot;: &quot;fa51531d&quot;\r\n    }\r\n    ,\r\n    {\r\n    &quot;id&quot;: &quot;2&quot;,\r\n    &quot;userId&quot;: &quot;a167869a&quot;\r\n  }\r\n]\r\n```\r\n\r\nI tried running this command but it throws an error.\r\n\r\n\r\n&gt; jq -n --stream &#39;fromstream(1|truncate_stream(inputs)) |  INDEX(.id)&#39; test.json &gt; result.json\r\n\r\n\r\n\r\nData above should be transformed to:\r\n\r\n```\r\n{\r\n  &quot;1&quot;: {\r\n    &quot;userId&quot;: &quot;fa51531d&quot;,\r\n    &quot;id&quot;: &quot;1&quot;\r\n  },\r\n  &quot;2&quot;: {\r\n    &quot;userId&quot;: &quot;a167869a&quot;,\r\n    &quot;id&quot;: &quot;2&quot;\r\n  },\r\n}\r\n```\r\n\r\nI want to achieve the same result as with `jq &#39;INDEX(.id)` but I need to use stream (because of big JSON file).\r\n",
        "link": "https://stackoverflow.com/questions/75223364/transform-json-array-to-object-with-jq",
        "title": "Transform JSON array to object with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 24382013,
                    "reputation": 65,
                    "user_id": 18313400,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GivmraS2ORZ-YMmnqpxQpo624diBbX-ILy_Idee=k-s256",
                    "display_name": "DrGeek",
                    "link": "https://stackoverflow.com/users/18313400/drgeek"
                },
                "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": 1674618028,
                "post_id": 75229438,
                "comment_id": 132751073,
                "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": 1674623628,
                "post_id": 75229438,
                "comment_id": 132751766,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674641133,
                "post_id": 75229438,
                "comment_id": 132755954,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24382013,
                    "reputation": 65,
                    "user_id": 18313400,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GivmraS2ORZ-YMmnqpxQpo624diBbX-ILy_Idee=k-s256",
                    "display_name": "DrGeek",
                    "link": "https://stackoverflow.com/users/18313400/drgeek"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674665919,
                "post_id": 75229438,
                "comment_id": 132764632,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1674670665,
                "last_edit_date": 1674670665,
                "creation_date": 1674670327,
                "answer_id": 75238127,
                "question_id": 75229438,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By transforming the unprocessed, raw output generated by `mgmt_cli`, the solution becomes almost trivial since the JSON already contains the &quot;to&quot; and &quot;from&quot; properties.\r\n\r\nInput (shortened to the relevant bits):\r\n\r\n```json\r\n{\r\n  &quot;uid&quot;: &quot;38271c2f-ab44-4e25-9aa4-e219cb6e12cf&quot;,\r\n  &quot;name&quot;: &quot;Network&quot;,\r\n  &quot;rulebase&quot;: [\r\n    {\r\n      &quot;uid&quot;: &quot;38acf747-85ee-4962-a3e7-d3cd678c388f&quot;,\r\n      &quot;name&quot;: &quot;Internal Rules&quot;,\r\n      &quot;type&quot;: &quot;access-section&quot;,\r\n      &quot;from&quot;: 1,\r\n      &quot;to&quot;: 3\r\n    },\r\n    {\r\n      &quot;uid&quot;: &quot;da0fdbf6-360b-44a4-94a8-b01894d3b5a0&quot;,\r\n      &quot;name&quot;: &quot;cleanup rule&quot;,\r\n      &quot;type&quot;: &quot;access-section&quot;,\r\n      &quot;from&quot;: 4,\r\n      &quot;to&quot;: 4\r\n    }\r\n  ],\r\n  &quot;from&quot;: 1,\r\n  &quot;to&quot;: 4,\r\n  &quot;total&quot;: 4\r\n}\r\n```\r\n\r\nJq transformation:\r\n\r\n```\r\n... | jq -r &#39;.rulebase[]\r\n| if .from == .to then &quot;\\(.name) (\\(.from))&quot;\r\nelse &quot;\\(.name) (\\(.from)-\\(.to))&quot;\r\nend&#39;\r\n```\r\n\r\nOutput:\r\n\r\n```\r\nInternal Rules (1-3)\r\ncleanup rule (4)\r\n```\r\n\r\nOr perhaps (but I find the if/then more straightforward):\r\n\r\n```\r\n.rulebase[]\r\n| (select(.from == .to) | &quot;\\(.name) (\\(.from)-\\(.to))&quot;)\r\n// &quot;\\(.name) (\\(.from)&quot;\r\n```",
                "title": "One jq command to get expected output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1674670665,
        "creation_date": 1674617131,
        "last_edit_date": 1674665852,
        "question_id": 75229438,
        "body_markdown": "I want to format below json code and print only specific values.\r\n\r\nI tried using below command and got the below json output. But when I further try to parse the code for end result it didn&#39;t worked as expected. \r\n\r\nSo, a little help can make things work for me.\r\n\r\n\r\n**Command that results in below JSON code output:**\r\n```\r\nmgmt_cli -r true -d 192.168.86.201 show access-rulebase name Network --format json | jq --raw-output &#39; .rulebase[].rulebase[] | {name: .name, rule_number: .&quot;rule-number&quot;}&#39;\r\n```\r\n\r\n**JSON Code:**\r\n```\r\n{\r\n  &quot;name&quot;: &quot;MgmtRule&quot;,\r\n  &quot;rule_number&quot;: 1\r\n}\r\n{\r\n  &quot;name&quot;: null,\r\n  &quot;rule_number&quot;: 2\r\n}\r\n{\r\n  &quot;name&quot;: null,\r\n  &quot;rule_number&quot;: 3\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Inside Rules&quot;,\r\n  &quot;rule_number&quot;: 4\r\n}\r\n{\r\n  &quot;name&quot;: null,\r\n  &quot;rule_number&quot;: 5\r\n}\r\n{\r\n  &quot;name&quot;: null,\r\n  &quot;rule_number&quot;: 6\r\n}\r\n{\r\n  &quot;name&quot;: null,\r\n  &quot;rule_number&quot;: 7\r\n}\r\n{\r\n  &quot;name&quot;: null,\r\n  &quot;rule_number&quot;: 8\r\n}\r\n{\r\n  &quot;name&quot;: null,\r\n  &quot;rule_number&quot;: 9\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Cleanup rule&quot;,\r\n  &quot;rule_number&quot;: 10\r\n}\r\n```\r\n\r\n**Further formatting jq command that I added to the above command to get the end result:**\r\n\r\n```\r\njq --slurp &#39;&quot;\\(.[0])-\\(.[length -1])&quot;&#39;\r\n```\r\n\r\n**Unexpected Output:**\r\n\r\n```\r\n&quot;{\\&quot;name\\&quot;:\\&quot;MgmtRule\\&quot;,\\&quot;rule_number\\&quot;:1}-{\\&quot;name\\&quot;:\\&quot;Cleanup rule\\&quot;,\\&quot;rule_number\\&quot;:10}&quot;\r\n```\r\n\r\n**Expected Output:**\r\n\r\n```\r\nMgmtRule (1-3)\r\nInside Rules (4-9)\r\nCleanup rule (10)\r\n```\r\n\r\n**Raw output:**\r\n\r\nShort form of original raw output:\r\n\r\n```\r\n{\r\n  &quot;uid&quot; : &quot;38271c2f-ab44-4e25-9aa4-e219cb6e12cf&quot;,\r\n  &quot;name&quot; : &quot;Network&quot;,\r\n  &quot;rulebase&quot; : [ {\r\n    &quot;uid&quot; : &quot;38acf747-85ee-4962-a3e7-d3cd678c388f&quot;,\r\n    &quot;name&quot; : &quot;Internal Rules&quot;,\r\n    &quot;type&quot; : &quot;access-section&quot;,\r\n    &quot;from&quot; : 1,\r\n    &quot;to&quot; : 3,\r\n    &quot;rulebase&quot; : [ {\r\n      &quot;uid&quot; : &quot;bdd9d868-51b2-4210-8c37-f0237cd560fa&quot;,\r\n      &quot;name&quot; : &quot;Test&quot;,\r\n      &quot;type&quot; : &quot;access-rule&quot;,\r\n      &quot;domain&quot; : {\r\n        &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-0800200c9fde&quot;,\r\n        &quot;name&quot; : &quot;SMC User&quot;,\r\n        &quot;domain-type&quot; : &quot;domain&quot;\r\n      },\r\n      &quot;rule-number&quot; : 1,\r\n      &quot;track&quot; : {\r\n        &quot;type&quot; : &quot;598ead32-aa42-4615-90ed-f51a5928d41d&quot;,\r\n        &quot;per-session&quot; : false,\r\n        &quot;per-connection&quot; : true,\r\n        &quot;accounting&quot; : false,\r\n        &quot;enable-firewall-session&quot; : false,\r\n        &quot;alert&quot; : &quot;none&quot;\r\n      },\r\n      &quot;source&quot; : [ &quot;6ddb84da-ef72-45c8-b2c4-bb3a849a6aa9&quot; ],\r\n      &quot;source-negate&quot; : false,\r\n      &quot;destination&quot; : [ &quot;375f4a15-1a7d-0b48-8ffc-2e9eb4e512ae&quot; ],\r\n      &quot;destination-negate&quot; : false,\r\n      &quot;service&quot; : [ &quot;97aeb443-9aea-11d5-bd16-0090272ccb30&quot;, &quot;18ec9eaa-1657-4240-ab97-5f234623336b&quot; ],\r\n      &quot;service-negate&quot; : false,\r\n      &quot;service-resource&quot; : &quot;&quot;,\r\n      &quot;vpn&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;action&quot; : &quot;6c488338-8eec-4103-ad21-cd461ac2c472&quot;,\r\n      &quot;action-settings&quot; : {\r\n        &quot;enable-identity-captive-portal&quot; : false\r\n      },\r\n      &quot;content&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;content-negate&quot; : false,\r\n      &quot;content-direction&quot; : &quot;any&quot;,\r\n      &quot;time&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;custom-fields&quot; : {\r\n        &quot;field-1&quot; : &quot;&quot;,\r\n        &quot;field-2&quot; : &quot;&quot;,\r\n        &quot;field-3&quot; : &quot;&quot;\r\n      },\r\n      &quot;meta-info&quot; : {\r\n        &quot;lock&quot; : &quot;unlocked&quot;,\r\n        &quot;validation-state&quot; : &quot;ok&quot;,\r\n        &quot;last-modify-time&quot; : {\r\n          &quot;posix&quot; : 1674486777583,\r\n          &quot;iso-8601&quot; : &quot;2023-01-23T20:42+0530&quot;\r\n        },\r\n        &quot;last-modifier&quot; : &quot;admin&quot;,\r\n        &quot;creation-time&quot; : {\r\n          &quot;posix&quot; : 1674486722309,\r\n          &quot;iso-8601&quot; : &quot;2023-01-23T20:42+0530&quot;\r\n        },\r\n        &quot;creator&quot; : &quot;admin&quot;\r\n      },\r\n      &quot;comments&quot; : &quot;&quot;,\r\n      &quot;enabled&quot; : true,\r\n      &quot;install-on&quot; : [ &quot;6c488338-8eec-4103-ad21-cd461ac2c476&quot; ],\r\n      &quot;available-actions&quot; : {\r\n        &quot;edit&quot; : &quot;true&quot;,\r\n        &quot;delete&quot; : &quot;true&quot;,\r\n        &quot;clone&quot; : &quot;not_supported&quot;\r\n      }\r\n    }, {\r\n      &quot;uid&quot; : &quot;bb93b38a-c672-49ec-afb0-8a90e8518437&quot;,\r\n      &quot;type&quot; : &quot;access-rule&quot;,\r\n      &quot;domain&quot; : {\r\n        &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-0800200c9fde&quot;,\r\n        &quot;name&quot; : &quot;SMC User&quot;,\r\n        &quot;domain-type&quot; : &quot;domain&quot;\r\n      },\r\n      &quot;rule-number&quot; : 2,\r\n      &quot;track&quot; : {\r\n        &quot;type&quot; : &quot;598ead32-aa42-4615-90ed-f51a5928d41d&quot;,\r\n        &quot;per-session&quot; : false,\r\n        &quot;per-connection&quot; : true,\r\n        &quot;accounting&quot; : false,\r\n        &quot;enable-firewall-session&quot; : false,\r\n        &quot;alert&quot; : &quot;none&quot;\r\n      },\r\n      &quot;source&quot; : [ &quot;6ddb84da-ef72-45c8-b2c4-bb3a849a6aa9&quot; ],\r\n      &quot;source-negate&quot; : false,\r\n      &quot;destination&quot; : [ &quot;8dbb91f3-786b-4d11-a029-45ee5b7d59cf&quot; ],\r\n      &quot;destination-negate&quot; : false,\r\n      &quot;service&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;service-negate&quot; : false,\r\n      &quot;service-resource&quot; : &quot;&quot;,\r\n      &quot;vpn&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;action&quot; : &quot;6c488338-8eec-4103-ad21-cd461ac2c472&quot;,\r\n      &quot;action-settings&quot; : {\r\n        &quot;enable-identity-captive-portal&quot; : false\r\n      },\r\n      &quot;content&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;content-negate&quot; : false,\r\n      &quot;content-direction&quot; : &quot;any&quot;,\r\n      &quot;time&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;custom-fields&quot; : {\r\n        &quot;field-1&quot; : &quot;&quot;,\r\n        &quot;field-2&quot; : &quot;&quot;,\r\n        &quot;field-3&quot; : &quot;&quot;\r\n      },\r\n      &quot;meta-info&quot; : {\r\n        &quot;lock&quot; : &quot;unlocked&quot;,\r\n        &quot;validation-state&quot; : &quot;ok&quot;,\r\n        &quot;last-modify-time&quot; : {\r\n          &quot;posix&quot; : 1674488952100,\r\n          &quot;iso-8601&quot; : &quot;2023-01-23T21:19+0530&quot;\r\n        },\r\n        &quot;last-modifier&quot; : &quot;admin&quot;,\r\n        &quot;creation-time&quot; : {\r\n          &quot;posix&quot; : 1674488917458,\r\n          &quot;iso-8601&quot; : &quot;2023-01-23T21:18+0530&quot;\r\n        },\r\n        &quot;creator&quot; : &quot;admin&quot;\r\n      },\r\n      &quot;comments&quot; : &quot;&quot;,\r\n      &quot;enabled&quot; : true,\r\n      &quot;install-on&quot; : [ &quot;6c488338-8eec-4103-ad21-cd461ac2c476&quot; ],\r\n      &quot;available-actions&quot; : {\r\n        &quot;edit&quot; : &quot;true&quot;,\r\n        &quot;delete&quot; : &quot;true&quot;,\r\n        &quot;clone&quot; : &quot;not_supported&quot;\r\n      }\r\n    }, {\r\n      &quot;uid&quot; : &quot;925f210e-ce4f-4139-870e-3cd53f46d832&quot;,\r\n      &quot;type&quot; : &quot;access-rule&quot;,\r\n      &quot;domain&quot; : {\r\n        &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-0800200c9fde&quot;,\r\n        &quot;name&quot; : &quot;SMC User&quot;,\r\n        &quot;domain-type&quot; : &quot;domain&quot;\r\n      },\r\n      &quot;rule-number&quot; : 3,\r\n      &quot;track&quot; : {\r\n        &quot;type&quot; : &quot;598ead32-aa42-4615-90ed-f51a5928d41d&quot;,\r\n        &quot;per-session&quot; : false,\r\n        &quot;per-connection&quot; : true,\r\n        &quot;accounting&quot; : false,\r\n        &quot;enable-firewall-session&quot; : false,\r\n        &quot;alert&quot; : &quot;none&quot;\r\n      },\r\n      &quot;source&quot; : [ &quot;6ddb84da-ef72-45c8-b2c4-bb3a849a6aa9&quot; ],\r\n      &quot;source-negate&quot; : false,\r\n      &quot;destination&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;destination-negate&quot; : false,\r\n      &quot;service&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;service-negate&quot; : false,\r\n      &quot;service-resource&quot; : &quot;&quot;,\r\n      &quot;vpn&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;action&quot; : &quot;6c488338-8eec-4103-ad21-cd461ac2c473&quot;,\r\n      &quot;action-settings&quot; : { },\r\n      &quot;content&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;content-negate&quot; : false,\r\n      &quot;content-direction&quot; : &quot;any&quot;,\r\n      &quot;time&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;custom-fields&quot; : {\r\n        &quot;field-1&quot; : &quot;&quot;,\r\n        &quot;field-2&quot; : &quot;&quot;,\r\n        &quot;field-3&quot; : &quot;&quot;\r\n      },\r\n      &quot;meta-info&quot; : {\r\n        &quot;lock&quot; : &quot;unlocked&quot;,\r\n        &quot;validation-state&quot; : &quot;ok&quot;,\r\n        &quot;last-modify-time&quot; : {\r\n          &quot;posix&quot; : 1674490197006,\r\n          &quot;iso-8601&quot; : &quot;2023-01-23T21:39+0530&quot;\r\n        },\r\n        &quot;last-modifier&quot; : &quot;admin&quot;,\r\n        &quot;creation-time&quot; : {\r\n          &quot;posix&quot; : 1674490169763,\r\n          &quot;iso-8601&quot; : &quot;2023-01-23T21:39+0530&quot;\r\n        },\r\n        &quot;creator&quot; : &quot;admin&quot;\r\n      },\r\n      &quot;comments&quot; : &quot;&quot;,\r\n      &quot;enabled&quot; : true,\r\n      &quot;install-on&quot; : [ &quot;6c488338-8eec-4103-ad21-cd461ac2c476&quot; ],\r\n      &quot;available-actions&quot; : {\r\n        &quot;edit&quot; : &quot;true&quot;,\r\n        &quot;delete&quot; : &quot;true&quot;,\r\n        &quot;clone&quot; : &quot;not_supported&quot;\r\n      }\r\n    } ]\r\n  }, {\r\n    &quot;uid&quot; : &quot;da0fdbf6-360b-44a4-94a8-b01894d3b5a0&quot;,\r\n    &quot;name&quot; : &quot;cleanup rule&quot;,\r\n    &quot;type&quot; : &quot;access-section&quot;,\r\n    &quot;from&quot; : 4,\r\n    &quot;to&quot; : 4,\r\n    &quot;rulebase&quot; : [ {\r\n      &quot;uid&quot; : &quot;2b922948-da96-4c9d-a654-063e0183f9ae&quot;,\r\n      &quot;name&quot; : &quot;Cleanup rule&quot;,\r\n      &quot;type&quot; : &quot;access-rule&quot;,\r\n      &quot;domain&quot; : {\r\n        &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-0800200c9fde&quot;,\r\n        &quot;name&quot; : &quot;SMC User&quot;,\r\n        &quot;domain-type&quot; : &quot;domain&quot;\r\n      },\r\n      &quot;rule-number&quot; : 4,\r\n      &quot;track&quot; : {\r\n        &quot;type&quot; : &quot;598ead32-aa42-4615-90ed-f51a5928d41d&quot;,\r\n        &quot;per-session&quot; : false,\r\n        &quot;per-connection&quot; : true,\r\n        &quot;accounting&quot; : false,\r\n        &quot;enable-firewall-session&quot; : false,\r\n        &quot;alert&quot; : &quot;none&quot;\r\n      },\r\n      &quot;source&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;source-negate&quot; : false,\r\n      &quot;destination&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;destination-negate&quot; : false,\r\n      &quot;service&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;service-negate&quot; : false,\r\n      &quot;service-resource&quot; : &quot;&quot;,\r\n      &quot;vpn&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;action&quot; : &quot;6c488338-8eec-4103-ad21-cd461ac2c473&quot;,\r\n      &quot;action-settings&quot; : { },\r\n      &quot;content&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;content-negate&quot; : false,\r\n      &quot;content-direction&quot; : &quot;any&quot;,\r\n      &quot;time&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;custom-fields&quot; : {\r\n        &quot;field-1&quot; : &quot;&quot;,\r\n        &quot;field-2&quot; : &quot;&quot;,\r\n        &quot;field-3&quot; : &quot;&quot;\r\n      },\r\n      &quot;meta-info&quot; : {\r\n        &quot;lock&quot; : &quot;unlocked&quot;,\r\n        &quot;validation-state&quot; : &quot;ok&quot;,\r\n        &quot;last-modify-time&quot; : {\r\n          &quot;posix&quot; : 1674486751969,\r\n          &quot;iso-8601&quot; : &quot;2023-01-23T20:42+0530&quot;\r\n        },\r\n        &quot;last-modifier&quot; : &quot;admin&quot;,\r\n        &quot;creation-time&quot; : {\r\n          &quot;posix&quot; : 1668629634218,\r\n          &quot;iso-8601&quot; : &quot;2022-11-17T01:43+0530&quot;\r\n        },\r\n        &quot;creator&quot; : &quot;System&quot;\r\n      },\r\n      &quot;comments&quot; : &quot;&quot;,\r\n      &quot;enabled&quot; : true,\r\n      &quot;install-on&quot; : [ &quot;6c488338-8eec-4103-ad21-cd461ac2c476&quot; ],\r\n      &quot;available-actions&quot; : {\r\n        &quot;edit&quot; : &quot;true&quot;,\r\n        &quot;delete&quot; : &quot;true&quot;,\r\n        &quot;clone&quot; : &quot;not_supported&quot;\r\n      }\r\n    } ]\r\n  } ],\r\n  &quot;objects-dictionary&quot; : [ {\r\n    &quot;uid&quot; : &quot;6c488338-8eec-4103-ad21-cd461ac2c472&quot;,\r\n    &quot;name&quot; : &quot;Accept&quot;,\r\n    &quot;type&quot; : &quot;RulebaseAction&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;a0bbbc99-adef-4ef8-bb6d-defdefdefdef&quot;,\r\n      &quot;name&quot; : &quot;Check Point Data&quot;,\r\n      &quot;domain-type&quot; : &quot;data domain&quot;\r\n    },\r\n    &quot;icon&quot; : &quot;Actions/actionsAccept&quot;,\r\n    &quot;color&quot; : &quot;none&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;8dbb91f3-786b-4d11-a029-45ee5b7d59cf&quot;,\r\n    &quot;name&quot; : &quot;All_Internet&quot;,\r\n    &quot;type&quot; : &quot;address-range&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-0800200c9fde&quot;,\r\n      &quot;name&quot; : &quot;SMC User&quot;,\r\n      &quot;domain-type&quot; : &quot;domain&quot;\r\n    },\r\n    &quot;ipv4-address-first&quot; : &quot;0.0.0.0&quot;,\r\n    &quot;ipv4-address-last&quot; : &quot;255.255.255.255&quot;,\r\n    &quot;icon&quot; : &quot;Objects/ip&quot;,\r\n    &quot;color&quot; : &quot;sienna&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot;,\r\n    &quot;name&quot; : &quot;Any&quot;,\r\n    &quot;type&quot; : &quot;CpmiAnyObject&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;a0bbbc99-adef-4ef8-bb6d-defdefdefdef&quot;,\r\n      &quot;name&quot; : &quot;Check Point Data&quot;,\r\n      &quot;domain-type&quot; : &quot;data domain&quot;\r\n    },\r\n    &quot;icon&quot; : &quot;General/globalsAny&quot;,\r\n    &quot;color&quot; : &quot;black&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;6c488338-8eec-4103-ad21-cd461ac2c473&quot;,\r\n    &quot;name&quot; : &quot;Drop&quot;,\r\n    &quot;type&quot; : &quot;RulebaseAction&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;a0bbbc99-adef-4ef8-bb6d-defdefdefdef&quot;,\r\n      &quot;name&quot; : &quot;Check Point Data&quot;,\r\n      &quot;domain-type&quot; : &quot;data domain&quot;\r\n    },\r\n    &quot;icon&quot; : &quot;Actions/actionsDrop&quot;,\r\n    &quot;color&quot; : &quot;none&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;375f4a15-1a7d-0b48-8ffc-2e9eb4e512ae&quot;,\r\n    &quot;name&quot; : &quot;dummy&quot;,\r\n    &quot;type&quot; : &quot;simple-gateway&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-0800200c9fde&quot;,\r\n      &quot;name&quot; : &quot;SMC User&quot;,\r\n      &quot;domain-type&quot; : &quot;domain&quot;\r\n    },\r\n    &quot;icon&quot; : &quot;NetworkObjects/management&quot;,\r\n    &quot;color&quot; : &quot;black&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;6ddb84da-ef72-45c8-b2c4-bb3a849a6aa9&quot;,\r\n    &quot;name&quot; : &quot;H_192.168.86.111&quot;,\r\n    &quot;type&quot; : &quot;host&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-0800200c9fde&quot;,\r\n      &quot;name&quot; : &quot;SMC User&quot;,\r\n      &quot;domain-type&quot; : &quot;domain&quot;\r\n    },\r\n    &quot;ipv4-address&quot; : &quot;192.168.86.111&quot;,\r\n    &quot;icon&quot; : &quot;Objects/host&quot;,\r\n    &quot;color&quot; : &quot;black&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;97aeb443-9aea-11d5-bd16-0090272ccb30&quot;,\r\n    &quot;name&quot; : &quot;https&quot;,\r\n    &quot;type&quot; : &quot;service-tcp&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;a0bbbc99-adef-4ef8-bb6d-defdefdefdef&quot;,\r\n      &quot;name&quot; : &quot;Check Point Data&quot;,\r\n      &quot;domain-type&quot; : &quot;data domain&quot;\r\n    },\r\n    &quot;port&quot; : &quot;443&quot;,\r\n    &quot;icon&quot; : &quot;Protocols/HTTP&quot;,\r\n    &quot;color&quot; : &quot;red&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;598ead32-aa42-4615-90ed-f51a5928d41d&quot;,\r\n    &quot;name&quot; : &quot;Log&quot;,\r\n    &quot;type&quot; : &quot;Track&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;a0bbbc99-adef-4ef8-bb6d-defdefdefdef&quot;,\r\n      &quot;name&quot; : &quot;Check Point Data&quot;,\r\n      &quot;domain-type&quot; : &quot;data domain&quot;\r\n    },\r\n    &quot;icon&quot; : &quot;Track/tracksLog&quot;,\r\n    &quot;color&quot; : &quot;none&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;6c488338-8eec-4103-ad21-cd461ac2c476&quot;,\r\n    &quot;name&quot; : &quot;Policy Targets&quot;,\r\n    &quot;type&quot; : &quot;Global&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;a0bbbc99-adef-4ef8-bb6d-defdefdefdef&quot;,\r\n      &quot;name&quot; : &quot;Check Point Data&quot;,\r\n      &quot;domain-type&quot; : &quot;data domain&quot;\r\n    },\r\n    &quot;icon&quot; : &quot;General/globalsAny&quot;,\r\n    &quot;color&quot; : &quot;none&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;18ec9eaa-1657-4240-ab97-5f234623336b&quot;,\r\n    &quot;name&quot; : &quot;ssh&quot;,\r\n    &quot;type&quot; : &quot;service-tcp&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;a0bbbc99-adef-4ef8-bb6d-defdefdefdef&quot;,\r\n      &quot;name&quot; : &quot;Check Point Data&quot;,\r\n      &quot;domain-type&quot; : &quot;data domain&quot;\r\n    },\r\n    &quot;port&quot; : &quot;22&quot;,\r\n    &quot;icon&quot; : &quot;Services/TCPService&quot;,\r\n    &quot;color&quot; : &quot;red&quot;\r\n  } ],\r\n  &quot;from&quot; : 1,\r\n  &quot;to&quot; : 4,\r\n  &quot;total&quot; : 4\r\n}\r\n```\r\n\r\n**Elements that I&#39;m trying to fetch and get the end result from above raw output:**\r\n\r\n```\r\n&quot;name&quot; &amp; &quot;rule-number&quot;\r\n```\r\n\r\n**Expected Output from above raw data:**\r\n\r\n```\r\nInternal Rules (1-3)\r\ncleanup rule (4)\r\n```",
        "link": "https://stackoverflow.com/questions/75229438/one-jq-command-to-get-expected-output",
        "title": "One jq command to get expected output"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1674625609,
                "last_edit_date": 1674625609,
                "creation_date": 1674625384,
                "answer_id": 75230082,
                "question_id": 75230039,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could just subtract that one from the array of keys:\r\n```sh\r\njq -c &#39;keys - [&quot;key_to_filter&quot;]&#39;\r\n```\r\n[Demo](https://jqplay.org/s/JTYjz_vjkWJ)\r\n\r\nMore verbosely but also more efficiently (if it matters), you could use a `map` to `select` what you want:\r\n```sh\r\njq -c &#39;keys | map(select(. != &quot;key_to_filter&quot;))&#39;\r\n```\r\n[Demo](https://jqplay.org/s/iZ0-zgNK5xm)\r\n\r\nAs @artild pointed out in a [comment](https://stackoverflow.com/questions/75230039/how-to-filter-a-key-using-jq-in-bash/75230082#comment132752059_75230082), you could also first `del`ete the item in question, and just then get all keys:\r\n```sh\r\njq -c &#39;del(.key_to_filter) | keys&#39;\r\n```\r\n[Demo](https://jqplay.org/s/o2TMs7SqUFd)\r\n\r\nOutput:\r\n```json\r\n[&quot;a_key&quot;,&quot;c_key&quot;]\r\n```\r\n\r\nNote that `keys` returns a sorted array. If you want them unsorted, use `keys_unsorted` instead.",
                "title": "How to filter a key using jq in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1674629521,
        "creation_date": 1674625078,
        "last_edit_date": 1674629521,
        "question_id": 75230039,
        "body_markdown": "I have the following JSON:\r\n\r\n```json\r\n{\r\n  &quot;a_key&quot;: &quot;A&quot;,\r\n  &quot;key_to_filter&quot;: &quot;B&quot;,\r\n  &quot;c_key&quot;: &quot;C&quot;\r\n}\r\n```\r\nI want to get all the keys using `jq` as a compressed response (using `jq -c &quot;keys&quot;`).\r\n\r\nHow can I get all the keys of this JSON without the key &quot;key_to_filter&quot;? \r\n\r\nIn other words, I need [&quot;a_key&quot;, &quot;c_key&quot;]",
        "link": "https://stackoverflow.com/questions/75230039/how-to-filter-a-key-using-jq-in-bash",
        "title": "How to filter a key using jq in bash"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "del"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674644500,
                "post_id": 75232983,
                "comment_id": 132757091,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1674646577,
                "last_edit_date": 1674646577,
                "creation_date": 1674644643,
                "answer_id": 75233050,
                "question_id": 75232983,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If all the objects in your array only contain a single property:\r\n\r\n```\r\n.Category |= map(select(keys_unsorted[0] | contains(&quot;Other&quot;) | not))\r\n```\r\n\r\nIf you want to delete objects of which any property&#39;s key starts with &quot;Other&quot;:\r\n\r\n```\r\n.Category |= map(select(any(keys_unsorted[]; contains(&quot;Other&quot;)) | not))\r\n```\r\n\r\nAnd finally, if you only want to delete those objects with only &quot;Other&quot; properties:\r\n\r\n```\r\n.Category |= map(select(all(keys_unsorted[]; contains(&quot;Other&quot;)) | not))\r\n```\r\n\r\nIt&#39;s also possible to use the `del` filter:\r\n\r\n```\r\ndel(.Category[] | select(keys_unsorted[0] | contains(&quot;Other&quot;)))\r\ndel(.Category[] | select(any(keys_unsorted[]; contains(&quot;Other&quot;))))\r\ndel(.Category[] | select(all(keys_unsorted[]; contains(&quot;Other&quot;))))\r\n```",
                "title": "How to delete an element which has a key which contains a certain substing using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1674646577,
        "creation_date": 1674644306,
        "question_id": 75232983,
        "body_markdown": "I have the following JSON:\r\n\r\n```\r\n{\r\n  &quot;Category&quot;: [\r\n\t{\r\n\t  &quot;SomeKey_1&quot;: {\r\n\t\t&quot;Property1&quot;: 1,\r\n\t\t&quot;Property2&quot;: false\r\n\t  }\r\n\t},\r\n\t{\r\n\t  &quot;SomeKey_2&quot;: {\r\n\t\t&quot;Property1&quot;: 2,\r\n\t\t&quot;Property2&quot;: true\r\n\t  }\r\n\t},\r\n\t{\r\n\t  &quot;OtherKey_1&quot;: {\r\n\t\t&quot;Property1&quot;: 3,\r\n\t\t&quot;Property2&quot;: false\r\n\t  }\r\n\t},\r\n\t{\r\n\t  &quot;OtherKey_2&quot;: {\r\n\t\t&quot;Property1&quot;: 4,\r\n\t\t&quot;Property2&quot;: false\r\n\t  }\r\n\t}\r\n  ]\r\n}\r\n```\r\nand I would like to delete from the Category[] array those element whose key starts with or contains &quot;Other&quot;.\r\nSo as the result I would like to have this:\r\n```\r\n{\r\n  &quot;Category&quot;: [\r\n\t{\r\n\t  &quot;SomeKey_1&quot;: {\r\n\t\t&quot;Property1&quot;: 1,\r\n\t\t&quot;Property2&quot;: false\r\n\t  }\r\n\t},\r\n\t{\r\n\t  &quot;SomeKey_2&quot;: {\r\n\t\t&quot;Property1&quot;: 2,\r\n\t\t&quot;Property2&quot;: true\r\n\t  }\r\n\t}\r\n  ]\r\n}\r\n```\r\n\r\nI tried to use the Select command but there I am able to select based on the values not the keys.",
        "link": "https://stackoverflow.com/questions/75232983/how-to-delete-an-element-which-has-a-key-which-contains-a-certain-substing-using",
        "title": "How to delete an element which has a key which contains a certain substing using jq?"
    },
    {
        "tags": [
            "http",
            "jq",
            "github-api"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1674720945,
                "last_edit_date": 1674720945,
                "creation_date": 1674720640,
                "answer_id": 75243514,
                "question_id": 75243413,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; curl, postman, fetch\r\n\r\nYour goal is to make an HTTP Request, not use the `gh` CLI.\r\n\r\n---\r\n\r\n[GitHub&#39;s GraphQL API][1] is what you seek:\r\n\r\n&gt; To create integrations, retrieve data, and automate your workflows, use the GitHub GraphQL API. The GitHub GraphQL API offers more precise and flexible queries than the GitHub REST API.\r\n\r\n[GraphQL][2] only returns the data requested. The data is &quot;processed&quot; on the API server and then sent to the client.\r\n\r\n\r\n  [1]: https://docs.github.com/en/graphql\r\n  [2]: https://graphql.org/",
                "title": "Is GitHub CLI &quot;--jq&quot; argument (to select values from the response) processed on the server or on the client?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1674720944,
                "creation_date": 1674720944,
                "answer_id": 75243553,
                "question_id": 75243413,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The response is filtered on the client. You can verify yourself by taking a look at [the source code](https://github.com/cli/cli/blob/trunk/pkg/cmd/api/api.go#L390):\r\n\r\n\r\n&gt;     if opts.FilterOutput != &quot;&quot; &amp;&amp; serverError == &quot;&quot; {\r\n&gt;     \t// TODO: reuse parsed query across pagination invocations\r\n&gt;     \terr = jq.Evaluate(responseBody, bodyWriter, opts.FilterOutput)\r\n&gt;     \tif err != nil {\r\n&gt;     \t\treturn\r\n&gt;     \t}\r\n&gt;     }\r\n\r\n",
                "title": "Is GitHub CLI &quot;--jq&quot; argument (to select values from the response) processed on the server or on the client?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1674720945,
        "creation_date": 1674719758,
        "question_id": 75243413,
        "body_markdown": "according to examples from https://cli.github.com/manual/gh_api:\r\n```\r\n# print only specific fields from the response\r\n$ gh api repos/{owner}/{repo}/issues --jq &#39;.[].title&#39;\r\n```\r\nGitHUb CLI (gh) can use the &#39;-q&#39; or &#39;--jq&#39; argument followed by a query string to _select values from the response_ and e.g. display only certain fields.\r\n\r\nI&#39;d like to do a similar thing using either CURL, postman or JavaScript fetch().\r\n\r\nSo my question is: is the `--jq` _query string_ sent (somehow) by `gh` CLI as part of an http request and processed on the server (to reduce the amount of data in the response), or is it only applied on the client side as post-processing of the data received ?\r\n\r\nAnd if that query string can be passed to and processed on the server, how should it be specified if I need to make the request not with `gh` but with `curl`, `postman` or javascript `fetch()` method?\r\n\r\nI fear the processing is actually done on the client, meaning the http response will always provide the full data...\r\n\r\nCan someone confirm this?\r\nThanks!",
        "link": "https://stackoverflow.com/questions/75243413/is-github-cli-jq-argument-to-select-values-from-the-response-processed-on",
        "title": "Is GitHub CLI &quot;--jq&quot; argument (to select values from the response) processed on the server or on the client?"
    },
    {
        "tags": [
            "json",
            "bash",
            "dictionary",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3085839,
                    "reputation": 1747,
                    "user_id": 9716110,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/JwpYt.jpg?s=256",
                    "display_name": "Eric Marceau",
                    "link": "https://stackoverflow.com/users/9716110/eric-marceau"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674764799,
                "post_id": 75251218,
                "comment_id": 132788848,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1674765277,
                "last_edit_date": 1674765277,
                "creation_date": 1674764971,
                "answer_id": 75251319,
                "question_id": 75251218,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`map` lets you filter each array item individually. Here, we descend to `.image`, and concatenate the value of `.name`, a literal colon `&quot;:&quot;`, and the value of `.tag`. The mapped array can then be `join`ed with a glue string `&quot;, &quot;`.\r\n```sh\r\njq -r &#39;\r\n  .definition.services\r\n  | &quot;COMPONENT_IMAGES=\\&quot;&quot; + (map(.image | .name + &quot;:&quot; + .tag) | join(&quot;, &quot;)) + &quot;\\&quot;&quot;\r\n&#39;\r\n```\r\n```\r\nCOMPONENT_IMAGES=&quot;img1:2.0.1, img2:1.4.0, img3:1.2.5&quot;\r\n```\r\n[Demo](https://jqplay.org/s/vOZdn6kc1MV)\r\n\r\n---\r\nIf you prefer using [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-%5C%28foo%29), here&#39;s its equivalent:\r\n```sh\r\njq -r &#39;\r\n  .definition.services\r\n  | &quot;COMPONENT_IMAGES=\\&quot;\\(map(.image | &quot;\\(.name):\\(.tag)&quot;) | join(&quot;, &quot;))\\&quot;&quot;\r\n&#39; \r\n```\r\n```\r\nCOMPONENT_IMAGES=&quot;img1:2.0.1, img2:1.4.0, img3:1.2.5&quot;\r\n```\r\n[Demo](https://jqplay.org/s/AM_1kZ-d2vY)\r\n\r\n",
                "title": "Extract values from an array in json in one line in Linux bash with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1674765277,
        "creation_date": 1674764316,
        "question_id": 75251218,
        "body_markdown": "I am extending here my [recent question][1] about jq since my requirements changed and I am still confused with map function.\r\n\r\nGiven such a service-def-test.json (very simplified from my real use case):\r\n\r\n\t{\r\n\t\t&quot;definition&quot;: {\r\n\t\t\t&quot;services&quot;: [{\r\n\t\t\t\t\t&quot;image&quot;: {\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;img1&quot;,\r\n\t\t\t\t\t\t&quot;tag&quot;: &quot;2.0.1&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}, {\r\n\t\t\t\t\t&quot;image&quot;: {\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;img2&quot;,\r\n\t\t\t\t\t\t&quot;tag&quot;: &quot;1.4.0&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}, {\r\n\t\t\t\t\t&quot;image&quot;: {\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;img3&quot;,\r\n\t\t\t\t\t\t&quot;tag&quot;: &quot;1.2.5&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t}\r\n\t}\r\n\r\nI now would like to get a one-line list of values:\r\n\r\n[img1:2.0.1, img2:1.4.0, img3:1.2. \\\r\nto store eventually in a COMPONENT_IMAGES variable.\r\n\r\nFrom the previous answer, \r\n\r\n    jq -r &#39;.definition.services | &quot; &quot;COMPONENT_IMAGES=\\&quot;\\(map(.image.name, .image.tag) | join(&quot;, &quot;))\\&quot;&quot; &#39; service-def-test.json\r\n\r\ngenerates\r\n\r\n    COMPONENT_IMAGES=&quot;img1, 2.0.1, img2, 1.4.0, img3, 1.2.5&quot;\r\n\r\nbut this I want only 3 items in my output array. \r\n\r\nI am looking to get\r\n\r\n    COMPONENT_IMAGES=&quot;img1:2.0.1, img2:1.4.0, img3:1.2.5&quot;\r\n\r\nWhat am I missing here? Thanks!\r\n\r\n  [1]: https://stackoverflow.com/questions/75214867/extract-values-from-an-array-in-json-in-one-line-in-linux-bash-with-jq",
        "link": "https://stackoverflow.com/questions/75251218/extract-values-from-an-array-in-json-in-one-line-in-linux-bash-with-jq",
        "title": "Extract values from an array in json in one line in Linux bash with jq"
    },
    {
        "tags": [
            "jestjs",
            "jq",
            "code-coverage",
            "test-coverage"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1674769708,
                "creation_date": 1674769708,
                "answer_id": 75251984,
                "question_id": 75251868,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can pretty quickly present it as a list of path/value pairs by streaming in the input. You could then join the paths to a more readable form and dump it.\r\n\r\n```\r\n$ jq -r --stream &#39;select(length == 2)|&quot;\\(.[0]|join(&quot;_&quot;)): \\t\\(.[1])&quot;&#39; input.json\r\ntotal_lines_total:      18326\r\ntotal_lines_covered:    11\r\ntotal_lines_skipped:    0\r\ntotal_lines_pct:        0.06\r\ntotal_statements_total:         62625\r\ntotal_statements_covered:       11\r\ntotal_statements_skipped:       0\r\ntotal_statements_pct:   0.01\r\ntotal_functions_total:  19047\r\ntotal_functions_covered:        4\r\ntotal_functions_skipped:        0\r\ntotal_functions_pct:    0.02\r\ntotal_branches_total:   60202\r\ntotal_branches_covered:         11\r\ntotal_branches_skipped:         0\r\ntotal_branches_pct:     0.01\r\ntotal_branchesTrue_total:       0\r\ntotal_branchesTrue_covered:     0\r\ntotal_branchesTrue_skipped:     0\r\ntotal_branchesTrue_pct:         100\r\n```\r\n\r\nIf you want to retain some structure, you&#39;ll need to decide on that first...",
                "title": "Use jq to print only the percentages of coverage from a json-summary file to markdown in github actions"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1674769708,
        "creation_date": 1674768945,
        "question_id": 75251868,
        "body_markdown": "I want to pretty print my json-coverage jest results to github actions. I have a ci.yml file with the following:\r\n\r\n```\r\n- name: Run Unit Tests\r\n        run: |\r\n          yarn test:next:unit --runInBand --coverage --coverageReporters=&quot;text-summary&quot;\r\n      - name: Echo Coverage\r\n        run: |\r\n          cat coverage/coverage-summary.json | head -1 &gt; coverage-testing/coverage.json\r\n```\r\n\r\nThis prints the first line of jest&#39;s coverage-summary in the job terminal and it looks like this:\r\n\r\n```\r\n{&quot;total&quot;: {&quot;lines&quot;:{&quot;total&quot;:18326,&quot;covered&quot;:11,&quot;skipped&quot;:0,&quot;pct&quot;:0.06},&quot;statements&quot;:{&quot;total&quot;:62625,&quot;covered&quot;:11,&quot;skipped&quot;:0,&quot;pct&quot;:0.01},&quot;functions&quot;:{&quot;total&quot;:19047,&quot;covered&quot;:4,&quot;skipped&quot;:0,&quot;pct&quot;:0.02},&quot;branches&quot;:{&quot;total&quot;:60202,&quot;covered&quot;:11,&quot;skipped&quot;:0,&quot;pct&quot;:0.01},&quot;branchesTrue&quot;:{&quot;total&quot;:0,&quot;covered&quot;:0,&quot;skipped&quot;:0,&quot;pct&quot;:100}}\r\n}\r\n```\r\n\r\nI can print this directly to my github action run in the UI by adding this to the ci.yml:\r\n\r\n```\r\n - name: Print to github\r\n        run: cat coverage-testing/coverage.json &gt;&gt; $GITHUB_STEP_SUMMARY   \r\n```\r\n\r\nand it shows up in github action run under annotations\r\n\r\n```\r\njest-next summary\r\n{&quot;total&quot;: {&quot;lines&quot;:{&quot;total&quot;:52,&quot;covered&quot;:11,&quot;skipped&quot;:0,&quot;pct&quot;:21.15},&quot;statements&quot;:{&quot;total&quot;:54,&quot;covered&quot;:11,&quot;skipped&quot;:0,&quot;pct&quot;:20.37},&quot;functions&quot;:{&quot;total&quot;:16,&quot;covered&quot;:4,&quot;skipped&quot;:0,&quot;pct&quot;:25},&quot;branches&quot;:{&quot;total&quot;:18,&quot;covered&quot;:11,&quot;skipped&quot;:0,&quot;pct&quot;:61.11},&quot;branchesTrue&quot;:{&quot;total&quot;:0,&quot;covered&quot;:0,&quot;skipped&quot;:0,&quot;pct&quot;:100}}\r\n\r\nJob summary generated at run-time\r\n```\r\n\r\nNow for the pretty printing. I&#39;ve tried some various jq commands including iterating with to_entries in a way that would make the github action job summary look more like markdown. I got errors because the array was nested and I got those errors to go away by changing -r to -R and adding try, but then nothing printed to github. Since these attempts are all in CI and the jest tests are flaky, changing one thing and waiting is getting cumbersome. Does anyone happen to have a script that does this already? Not picky about how it&#39;s formatted, I&#39;d just like it to look less like json and more like markdown.\r\n",
        "link": "https://stackoverflow.com/questions/75251868/use-jq-to-print-only-the-percentages-of-coverage-from-a-json-summary-file-to-mar",
        "title": "Use jq to print only the percentages of coverage from a json-summary file to markdown in github actions"
    },
    {
        "tags": [
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1674781712,
                "creation_date": 1674781712,
                "answer_id": 75253207,
                "question_id": 75253182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try `add`ing the `--slurp`ed array:\r\n```sh\r\njq -s &#39;{Items: {objects: map(.outputs) | add}}&#39; 1.json 2.json\r\n```\r\n[Demo](https://jqplay.org/s/FpBGluG8P2u)\r\n\r\nAnother approach could be using `reduce` with `inputs` and the `-n` flag:\r\n```sh\r\njq -n &#39;reduce inputs.outputs as $i ({}; .Items.objects += $i)&#39; 1.json 2.json\r\n```\r\n[Demo](https://jqplay.org/s/8PTo77X-xeq)\r\n\r\nOutput:\r\n```json\r\n{\r\n  &quot;Items&quot;: {\r\n    &quot;objects&quot;: {\r\n      &quot;item1&quot;: {\r\n        &quot;name&quot;: &quot;name1&quot;,\r\n        &quot;email&quot;: &quot;email1&quot;\r\n      },\r\n      &quot;item2&quot;: {\r\n        &quot;name&quot;: &quot;name2&quot;,\r\n        &quot;email&quot;: &quot;email2&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n",
                "title": "Merge 2 JSON objects from 2 files using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1674781712,
        "creation_date": 1674781431,
        "question_id": 75253182,
        "body_markdown": "I have two json files&lt;br&gt;\r\n1.json\r\n```\r\n{\r\n  &quot;outputs&quot;: {\r\n     &quot;item1&quot;: {\r\n       &quot;name&quot;: &quot;name1&quot;,\r\n       &quot;email&quot;: &quot;email1&quot;\r\n     }\r\n  }\r\n}\r\n```\r\n2.json\r\n```\r\n{\r\n  &quot;outputs&quot;: {\r\n     &quot;item2&quot;: {\r\n       &quot;name&quot;: &quot;name2&quot;,\r\n       &quot;email&quot;: &quot;email2&quot;\r\n     }\r\n  }\r\n}\r\n```\r\n\r\n\r\n\r\nI&#39;m trying to merge them using jq\r\n```\r\njq -s &#39;{\r\n      &quot;Items&quot; :\r\n      {\r\n            &quot;list&quot; : .[] | .outputs ,\r\n      },\r\n  }&#39; 1.json 2.json\r\n```\r\nand I get just two Items objects, but I want to have one Items object and all item* merged like this\r\n```\r\n{\r\n  &quot;Items&quot;: {\r\n    &quot;objects&quot;: {\r\n      &quot;item1&quot;: {\r\n        &quot;name&quot;: &quot;name1&quot;,\r\n        &quot;email&quot;: &quot;email1&quot;\r\n      },\r\n      &quot;item2&quot;: {\r\n        &quot;name&quot;: &quot;name2&quot;,\r\n        &quot;email&quot;: &quot;email2&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\nI&#39;ve tried `.[0] * .[1]` trick, but I cannot put it into object construction.\r\nHow can do this with jq?",
        "link": "https://stackoverflow.com/questions/75253182/merge-2-json-objects-from-2-files-using-jq",
        "title": "Merge 2 JSON objects from 2 files using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq",
            "echo"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674811245,
                "post_id": 75255995,
                "comment_id": 132796827,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6824624,
                    "reputation": 1,
                    "user_id": 5250668,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/nulnn.jpg?s=256",
                    "display_name": "Jesus Espejo",
                    "link": "https://stackoverflow.com/users/5250668/jesus-espejo"
                },
                "reply_to_user": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674820883,
                "post_id": 75255995,
                "comment_id": 132799574,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674822657,
                "post_id": 75255995,
                "comment_id": 132800110,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674822899,
                "post_id": 75255995,
                "comment_id": 132800180,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1674854291,
                "post_id": 75255995,
                "comment_id": 132809874,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1674810947,
                "creation_date": 1674810947,
                "answer_id": 75256049,
                "question_id": 75255995,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your variable content is already JSON-encoded. Just use quotes when using the variable:\r\n```sh\r\njq . &lt;&lt;&lt; &quot;$jsonWithEscapedCharacters&quot;\r\n```\r\n```json\r\n{\r\n  &quot;fields&quot;: {\r\n    &quot;System.AreaPath&quot;: &quot;Here\\\\double-backslah&quot;,\r\n    &quot;System.IterationPath&quot;: &quot;Ahother\\\\Double-backslash&quot;,\r\n    &quot;System.Title&quot;: &quot;The \\&quot;title\\&quot; with double quotes&quot;\r\n  }\r\n}\r\n```\r\n\r\nLikewise, to retrieve some value (note the use of `-r` to strip the JSON encoding):\r\n```sh\r\njq -r &#39;.fields.&quot;System.Title&quot;&#39; &lt;&lt;&lt; &quot;$jsonWithEscapedCharacters&quot;\r\n```\r\n```\r\nThe &quot;title&quot; with double quotes\r\n```\r\n\r\nLikewise with command substitution when storing that value:\r\n```sh\r\ntitle=&quot;$(jq -r &#39;.fields.&quot;System.Title&quot;&#39; &lt;&lt;&lt; &quot;$jsonWithEscapedCharacters&quot;)&quot;\r\necho &quot;$title&quot;\r\n```\r\n```\r\nThe &quot;title&quot; with double quotes\r\n```",
                "title": "How to echo a jq JSON with double quotes escaped with backslash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1674810947,
        "creation_date": 1674810572,
        "question_id": 75255995,
        "body_markdown": "I&#39;m trying create a function that echoes the a JSON with escaped values with backslash like `&quot;System.Title&quot;: &quot;The \\&quot;title\\&quot; with double quotes&quot;` property and when jq processes the echoed result returns a Parse error.\r\n\r\n\r\nAs you can see in the commented lines I&#39;ve tried several ways to offset the effects of `echo` on backslash but I still cannot echo a parseable JSON.\r\n\r\nHave someone successfully echoed a parseable JSON with escaped characters?\r\n\r\n```\r\njsonWithEscapedCharacters=&#39;{\r\n  &quot;fields&quot;: {\r\n    &quot;System.AreaPath&quot;: &quot;Here\\\\double-backslah&quot;,\r\n    &quot;System.IterationPath&quot;: &quot;Ahother\\\\Double-backslash&quot;,\r\n    &quot;System.Title&quot;: &quot;The \\&quot;title\\&quot; with double quotes&quot;\r\n  }\r\n}&#39;\r\n\r\ngetjsonWithEscapedCharacters() {\r\n  # FAIL echo $jsonWithEscapedCharacters | sed &#39;s/\\\\/\\\\\\\\/g&#39;\r\n  # FAIL echo &quot;$jsonWithEscapedCharacters&quot; | sed &#39;s/\\\\/\\\\\\\\/g&#39;\r\n  # FAIL echo -E &quot;$jsonWithEscapedCharacters&quot; | sed &#39;s/\\\\/\\\\\\\\/g&#39;\r\n  # FAIL echo &quot;$jsonWithEscapedCharacters&quot;\r\n  # FAIL echo -e $jsonWithEscapedCharacters\r\n  echo -e $jsonWithEscapedCharacters\r\n}\r\n\r\nechoedJson=$(getjsonWithEscapedCharacters)\r\n\r\ntitleFromJson=$(jq &#39;.fields[&quot;System.Title&quot;]&#39; &lt;&lt;&lt; $jsonWithEscapedCharacters)\r\ntitle=$(jq &#39;.fields[&quot;System.Title&quot;]&#39; &lt;&lt;&lt; $echoedJson)\r\n\r\necho &quot;expected $titleFromJson, actual: $title&quot;\r\n# jsonWithEscapedCharacters is parsed OK but echoedJson cannot be parsed due to jq Parse error\r\n```",
        "link": "https://stackoverflow.com/questions/75255995/how-to-echo-a-jq-json-with-double-quotes-escaped-with-backslash",
        "title": "How to echo a jq JSON with double quotes escaped with backslash"
    },
    {
        "tags": [
            "linux",
            "bash",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1674816580,
                "creation_date": 1674816580,
                "answer_id": 75257064,
                "question_id": 75256906,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Save the `id` as a variable using `._id as $id`, then you can use `$id` where ever you like:\r\n```\r\n._id as $id | ._source.Bibtex.Article.AuthorList[].Affiliation.Affiliation | [ $id, .[0:rindex(&quot; Electronic address:&quot;)] ] | @csv\r\n```\r\n\r\nOutput:\r\n```\r\n&quot;3233233233&quot;,&quot;Title content, Hematology and Hepatology Honorary Fellow, Honorary Member, American  Society. xxxyyy@hotmail.com.&quot;\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/298G4GJ2Kng)",
                "title": "jq getting multiple fields from same query"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1674844406,
                "last_edit_date": 1674844406,
                "creation_date": 1674822289,
                "answer_id": 75258070,
                "question_id": 75256906,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `[]` to construct an array from your two elements and `@csv` to convert to CSV:\r\n\r\n```\r\njq -r &#39;[\r\n  ._id,\r\n  ._source.Bibtex.Article.AuthorList[]?.Affiliation.Affiliation[:rindex(&quot; Electronic address:&quot;)]\r\n] | @csv&#39;\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n&quot;3233233233&quot;,&quot;Title content, Hematology and Hepatology Honorary Fellow, Honorary Member, American  Society. xxxyyy@hotmail.com.&quot;\r\n```\r\n\r\nMultiple authors will be added as columns to your CSV.\r\n\r\n*****\r\n\r\nIt&#39;s worth nothing that jq allows you to concatenate multiple arrays into a single one. Concatenating streams produces the cartesian product, e.g. `[1]+[2]` produces `[1,2]` and `[1]+([2],[3])` will produce `[1,2][1,3]` (a stream comprising two arrays). You can leverage this fact to produce multiple output lines without capturing the id in a variable first:\r\n\r\n```\r\n[._id]\r\n+ (._source.Bibtex.Article.AuthorList[]? | [ .Affiliation.Affiliation[0:rindex(&quot; Electronic address:&quot;)] ])\r\n| @csv\r\n```",
                "title": "jq getting multiple fields from same query"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1674844406,
        "creation_date": 1674815725,
        "question_id": 75256906,
        "body_markdown": "I have a json of this type:\r\n\r\n```\r\n{\r\n  &quot;_index&quot;: &quot;indexeer&quot;,\r\n  &quot;_type&quot;: &quot;_doc&quot;,\r\n  &quot;_id&quot;: &quot;3233233233&quot;,\r\n  &quot;_score&quot;: 1,\r\n  &quot;_source&quot;: {\r\n    &quot;Bibtex&quot;: {\r\n      &quot;Article&quot;: {\r\n        &quot;AuthorList&quot;: [\r\n          {\r\n            &quot;Affiliation&quot;: {\r\n              &quot;Affiliation&quot;: &quot;Title content, Hematology and Hepatology Honorary Fellow, Honorary Member, American  Society. xxxyyy@hotmail.com.&quot;\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI get the `Affiliation` using `jq` like so:\r\n\r\n```\r\njq -r &#39;._source.Bibtex.Article.AuthorList[]? | .Affiliation.Affiliation | .[0:rindex(&quot; Electronic address:&quot;)]&#39; results.json\r\n```\r\n\r\nIt works great, and gives me excatly the affiliations I need.\r\n\r\nHowever, I now need the `id` field aswell and produce a csv like so:\r\n\r\n```\r\n&quot;3233233233&quot;, &quot;Title content, Hematology and Hepatology Honorary Fellow, Honorary Member, American  Society&quot;\r\n```\r\n\r\nI am able to get the ID seperately, easily like so:\r\n\r\n```\r\njq -r &#39;._id&#39; results.json\r\n```\r\n\r\nbut, how do I combine the two queries to produce a single output consisting of `id` and `affiliation`?\r\n\r\nEssentially I want to combine the two queries.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75256906/jq-getting-multiple-fields-from-same-query",
        "title": "jq getting multiple fields from same query"
    },
    {
        "tags": [
            "json",
            "awk",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1674830005,
                "post_id": 75259486,
                "comment_id": 132802649,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1674830152,
                "post_id": 75259486,
                "comment_id": 132802692,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674830221,
                "post_id": 75259486,
                "comment_id": 132802710,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674830308,
                "post_id": 75259486,
                "comment_id": 132802749,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674830943,
                "post_id": 75259486,
                "comment_id": 132802949,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1674954346,
                "last_edit_date": 1674954346,
                "creation_date": 1674838565,
                "answer_id": 75261109,
                "question_id": 75259486,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[tag:miller] is handy for pretty-printing output.\r\n```sh\r\necho &#39;name,IP,NAT,location,method\r\nH_103.109.135.25,103.109.135.25,1.1.1.1,All,static\r\nH_103.109.135.250,103.109.135.250,,,&#39; \\\r\n| mlr --c2p --barred put &#39;for (i,v in $*) {if (v == &quot;&quot;) {$[i] = &quot;NA&quot;}}&#39;\r\n```\r\n`--c2p` is a shortcut for `--icsv --opprint` which reads CSV input and outputs pretty-printed tabular form.\r\n\r\n```none\r\n+-------------------+-----------------+---------+----------+--------+\r\n| name              | IP              | NAT     | location | method |\r\n+-------------------+-----------------+---------+----------+--------+\r\n| H_103.109.135.25  | 103.109.135.25  | 1.1.1.1 | All      | static |\r\n| H_103.109.135.250 | 103.109.135.250 | NA      | NA       | NA     |\r\n+-------------------+-----------------+---------+----------+--------+\r\n```\r\nThe miller `put` verb takes an awk-like script.\r\n\r\nSee https://miller.readthedocs.io/en/latest/\r\n\r\n---\r\nA bit more functional style:\r\n```sh\r\nmlr --c2p --barred put &#39;$* = apply($*, func(k,v) {return {k: v == &quot;&quot; ? &quot;NA&quot; : v}})&#39;\r\n```\r\n\r\n---\r\nI&#39;d suggest removing quotes and adding &quot;NA&quot; inside jq, and then pipe the output to `column`\r\n```sh\r\njq -r &#39;\r\n  [\r\n    [&quot;name&quot;,&quot;IP&quot;,&quot;NAT&quot;,&quot;location&quot;,&quot;method&quot;],\r\n    ( .objects[]\r\n    | {&quot;nat-settings&quot;: {&quot;ipv4-address&quot;: &quot;NA&quot;, &quot;install-on&quot;: &quot;NA&quot;, method: &quot;NA&quot;}} * .\r\n    | [.name, .&quot;ipv4-address&quot;] + (.&quot;nat-settings&quot; | [.&quot;ipv4-address&quot;, .&quot;install-on&quot;, .method])\r\n    )\r\n  ][] | join(&quot;,&quot;)\r\n&#39; dump | column -s, -t\r\n```\r\nThat assumes that the &quot;nat-settings&quot; object is _missing_ the &quot;ipv4-address&quot;, etc, keys.",
                "title": "format jq output into a table"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1674838601,
                "creation_date": 1674838601,
                "answer_id": 75261115,
                "question_id": 75259486,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is [jbtl](https://github.com/kellyjonbrazil/jtbl) which may produce what you&#39;re looking for. If you have this in `output.jq` for example:\r\n\r\n```jq\r\n.objects\r\n| map(\r\n    { name, IP: .&quot;ipv4-address&quot; } +\r\n    (.&quot;nat-settings&quot; | {\r\n      NAT: (.&quot;ipv4-address&quot; // &quot;NA&quot;), \r\n      location: (.&quot;install-on&quot; // &quot;NA&quot;), \r\n      method: (.method // &quot;NA&quot;)\r\n    })\r\n  )\r\n```\r\n\r\nthen passing the data through this filter and piping it into `jtbl` with the `-m` option, like this:\r\n\r\n```bash\r\ncat dump | jq -f output.jq | jtbl -m\r\n```\r\n\r\ngives this\r\n\r\n```text\r\n| name              | IP              | NAT     | location   | method   |\r\n|-------------------|-----------------|---------|------------|----------|\r\n| H_103.109.135.25  | 103.109.135.25  | 1.1.1.1 | All        | static   |\r\n| H_103.109.135.250 | 103.109.135.250 | NA      | NA         | NA       |\r\n```",
                "title": "format jq output into a table"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1674980953,
                "creation_date": 1674980953,
                "answer_id": 75273554,
                "question_id": 75259486,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would recommend using jq&#39;s `@tsv` and the very standard tool, `column`, e.g. as follows:\r\n```\r\n&lt; dump jq -r &#39;\r\n  [&quot;name&quot;,&quot;IP&quot;,&quot;NAT&quot;,&quot;location&quot;,&quot;method&quot;], \r\n  (.objects[] | [.name, .&quot;ipv4-address&quot;, .&quot;nat-settings&quot;.&quot;ipv4-address&quot;, .&quot;nat-settings&quot;.&quot;install-on&quot;, .&quot;nat-settings&quot;.method]) \r\n  | @tsv&#39; | column -t \r\n```",
                "title": "format jq output into a table"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1674980953,
        "creation_date": 1674829885,
        "last_edit_date": 1674882678,
        "question_id": 75259486,
        "body_markdown": "I want to fetch some data from below JSON code:\r\n\r\nI&#39;m able to get the output using below command but now I want to format it in such a way that my output will look like the expected output.\r\n\r\n**Command:**\r\n```\r\ncat dump | jq -r &#39;[&quot;name&quot;,&quot;IP&quot;,&quot;NAT&quot;,&quot;location&quot;,&quot;method&quot;], \r\n                  (.objects[] | [.name, .&quot;ipv4-address&quot;, .&quot;nat-settings&quot;.&quot;ipv4-address&quot;, .&quot;nat-settings&quot;.&quot;install-on&quot;, .&quot;nat-settings&quot;.method]) \r\n                              | @csv&#39; \r\n                              | sed -e &#39;s/&quot;//g&#39;\r\n``` \r\n\r\n**After using @csv I got below output:**\r\n\r\n```\r\nname,IP,NAT,location,method\r\nH_103.109.135.25,103.109.135.25,1.1.1.1,All,static\r\nH_103.109.135.250,103.109.135.250,,,\r\n```\r\n\r\nand whenever I use @tsv I get **&quot;jq: error: tsv is not a valid format&quot;**\r\n\r\nCan any one suggest me how can I achieve below output:\r\n\r\n**Expected Output:**\r\n\r\n[![enter image description here][1]][1]\r\n\r\n**Raw JSON Code:**\r\n\r\n```\r\n{\r\n  &quot;from&quot; : 1,\r\n  &quot;to&quot; : 2,\r\n  &quot;total&quot; : 2,\r\n  &quot;objects&quot; : [ {\r\n    &quot;uid&quot; : &quot;73b7036d-e8ec-47b7-99b5-19ca89eb5fd0&quot;,\r\n    &quot;name&quot; : &quot;H_103.109.135.25&quot;,\r\n    &quot;type&quot; : &quot;host&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-0800200c9fde&quot;,\r\n      &quot;name&quot; : &quot;SMC User&quot;,\r\n      &quot;domain-type&quot; : &quot;domain&quot;\r\n    },\r\n    &quot;ipv4-address&quot; : &quot;103.109.135.25&quot;,\r\n    &quot;interfaces&quot; : [ ],\r\n    &quot;nat-settings&quot; : {\r\n      &quot;auto-rule&quot; : true,\r\n      &quot;ipv4-address&quot; : &quot;1.1.1.1&quot;,\r\n      &quot;ipv6-address&quot; : &quot;&quot;,\r\n      &quot;install-on&quot; : &quot;All&quot;,\r\n      &quot;method&quot; : &quot;static&quot;\r\n    },\r\n    &quot;comments&quot; : &quot;&quot;,\r\n    &quot;color&quot; : &quot;black&quot;,\r\n    &quot;icon&quot; : &quot;Objects/host&quot;,\r\n    &quot;tags&quot; : [ ],\r\n    &quot;meta-info&quot; : {\r\n      &quot;lock&quot; : &quot;unlocked&quot;,\r\n      &quot;validation-state&quot; : &quot;ok&quot;,\r\n      &quot;last-modify-time&quot; : {\r\n        &quot;posix&quot; : 1674820459413,\r\n        &quot;iso-8601&quot; : &quot;2023-01-27T17:24+0530&quot;\r\n      },\r\n      &quot;last-modifier&quot; : &quot;admin&quot;,\r\n      &quot;creation-time&quot; : {\r\n        &quot;posix&quot; : 1674818326777,\r\n        &quot;iso-8601&quot; : &quot;2023-01-27T16:48+0530&quot;\r\n      },\r\n      &quot;creator&quot; : &quot;admin&quot;\r\n    },\r\n    &quot;read-only&quot; : false,\r\n    &quot;available-actions&quot; : {\r\n      &quot;edit&quot; : &quot;true&quot;,\r\n      &quot;delete&quot; : &quot;true&quot;,\r\n      &quot;clone&quot; : &quot;true&quot;\r\n    }\r\n  }, {\r\n    &quot;uid&quot; : &quot;7300c38a-a496-497a-b9e3-5701fa081393&quot;,\r\n    &quot;name&quot; : &quot;H_103.109.135.250&quot;,\r\n    &quot;type&quot; : &quot;host&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-0800200c9fde&quot;,\r\n      &quot;name&quot; : &quot;SMC User&quot;,\r\n      &quot;domain-type&quot; : &quot;domain&quot;\r\n    },\r\n    &quot;ipv4-address&quot; : &quot;103.109.135.250&quot;,\r\n    &quot;interfaces&quot; : [ ],\r\n    &quot;nat-settings&quot; : {\r\n      &quot;auto-rule&quot; : false\r\n    },\r\n    &quot;comments&quot; : &quot;&quot;,\r\n    &quot;color&quot; : &quot;black&quot;,\r\n    &quot;icon&quot; : &quot;Objects/host&quot;,\r\n    &quot;tags&quot; : [ ],\r\n    &quot;meta-info&quot; : {\r\n      &quot;lock&quot; : &quot;unlocked&quot;,\r\n      &quot;validation-state&quot; : &quot;ok&quot;,\r\n      &quot;last-modify-time&quot; : {\r\n        &quot;posix&quot; : 1674818341888,\r\n        &quot;iso-8601&quot; : &quot;2023-01-27T16:49+0530&quot;\r\n      },\r\n      &quot;last-modifier&quot; : &quot;admin&quot;,\r\n      &quot;creation-time&quot; : {\r\n        &quot;posix&quot; : 1674818341888,\r\n        &quot;iso-8601&quot; : &quot;2023-01-27T16:49+0530&quot;\r\n      },\r\n      &quot;creator&quot; : &quot;admin&quot;\r\n    },\r\n    &quot;read-only&quot; : false,\r\n    &quot;available-actions&quot; : {\r\n      &quot;edit&quot; : &quot;true&quot;,\r\n      &quot;delete&quot; : &quot;true&quot;,\r\n      &quot;clone&quot; : &quot;true&quot;\r\n    }\r\n  } ]\r\n}\r\n\r\n```\r\n\r\n\r\n  [1]: https://i.sstatic.net/tWOc0.png\r\n\r\n**Note:** \r\n\r\nIt&#39;s not mandatory that the output should be printed in table using jq only. &quot;awk&quot; or &quot;sed&quot; is also fine.\r\n\r\nI have extracted data that required from the below raw json data:\r\n\r\n**Extracted data:**\r\n\r\n```\r\n{\r\n    &quot;name&quot;: &quot;H_103.109.135.25&quot;,\r\n    &quot;IP&quot;: &quot;103.109.135.25&quot;,\r\n    &quot;NAT&quot;: &quot;1.1.1.1&quot;,\r\n    &quot;location&quot;: &quot;All&quot;,\r\n    &quot;method&quot;: &quot;static&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;H_103.109.135.250&quot;,\r\n    &quot;IP&quot;: &quot;103.109.135.250&quot;,\r\n    &quot;NAT&quot;: &quot;NA&quot;,\r\n    &quot;location&quot;: &quot;NA&quot;,\r\n    &quot;method&quot;: &quot;NA&quot;\r\n  }\r\n```\r\n\r\nI now just need to format this data into table like below or somewhat similar:\r\n\r\n```\r\n| name              | IP              | NAT     | location   | method   |\r\n|-------------------|-----------------|---------|------------|----------|\r\n| H_103.109.135.25  | 103.109.135.25  | 1.1.1.1 | All        | static   |\r\n| H_103.109.135.250 | 103.109.135.250 | NA      | NA         | NA       |\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/75259486/format-jq-output-into-a-table",
        "title": "format jq output into a table"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1674842327,
                "post_id": 75261408,
                "comment_id": 132806778,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1674844006,
                "post_id": 75261408,
                "comment_id": 132807229,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1674844682,
                "creation_date": 1674844682,
                "answer_id": 75262127,
                "question_id": 75261408,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Function `map` is what you need :\r\n\r\n```\r\njq &#39;.locations | map(select(has(&quot;is_shop&quot;) and has(&quot;has_parking_space&quot;))) | length&#39; my_locations.json\r\n```\r\n\r\nI think you should use function `has`, because you want to test `existence` of the keys, not the value.",
                "title": "How to use jq to return length of filtered array?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1709120093,
                "creation_date": 1709120093,
                "answer_id": 78074074,
                "question_id": 75261408,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If all you want is the number of matching objects, you could efficiently just iterate over the original array, and count on a match (which avoids creating another array that is only used to extract its length).\r\n```sh\r\nreduce .locations[] as $loc (0;\r\n  if all($loc; has(&quot;is_shop&quot;, &quot;has_parking_space&quot;)) then . + 1 end\r\n)\r\n```\r\n\r\nNote for the use of `if`: A missing `else` branch defaults to `else .`, which was introduced in jq 1.7. Prior to that version, you&#39;d have to spell it out: `… then . + 1 else . end`.",
                "title": "How to use jq to return length of filtered array?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1723875660,
                "creation_date": 1723875660,
                "answer_id": 78881527,
                "question_id": 75261408,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just stumble into this post and I discovered another solution. You can pass `--indent 0` to `jq` (so something like `jq &quot;.locations[] | select(.is_shop and .has_parking_space)&quot;`). Then it will print each filtered item in one single line. Then you can count the lines of the output: `jq &quot;your filtering query&quot; | wc -l`",
                "title": "How to use jq to return length of filtered array?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1723875660,
        "creation_date": 1674840322,
        "question_id": 75261408,
        "body_markdown": "My json file is called `my_locations.json` and contains an array called `locations`. I want to filter this array by all objects that have keys `location.is_shop` and `location.has_parking_space`. I then want to return the length of this filtered array.\r\n\r\nHere is my attempt using the program `jq`:\r\n```\r\n$ jq &quot;.locations[] | select(.is_shop and .has_parking_space) | length&quot; my_locations.json\r\n13\r\n13\r\n13\r\n13\r\n13\r\n...\r\n13\r\n```\r\n\r\nSo it outputs the length of each location object in the array instead of the length of the filtered array.\r\n\r\nHow can I return the length of the filtered array?",
        "link": "https://stackoverflow.com/questions/75261408/how-to-use-jq-to-return-length-of-filtered-array",
        "title": "How to use jq to return length of filtered array?"
    },
    {
        "tags": [
            "json",
            "terraform",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674855469,
                "post_id": 75263431,
                "comment_id": 132810161,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16357163,
                    "reputation": 635,
                    "user_id": 11813885,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/i4y0L.png?s=256",
                    "display_name": "tg0h",
                    "link": "https://stackoverflow.com/users/11813885/tg0h"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1674855513,
                "post_id": 75263431,
                "comment_id": 132810173,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11380463,
                    "reputation": 18628,
                    "user_id": 8343484,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Frs71.jpg?s=256",
                    "display_name": "Marko E",
                    "link": "https://stackoverflow.com/users/8343484/marko-e"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674855519,
                "post_id": 75263431,
                "comment_id": 132810174,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1674862120,
                "creation_date": 1674862120,
                "answer_id": 75264299,
                "question_id": 75263431,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`contains` checks if one array is a subarray of the other, recursively (substrings are matched too; note the &quot;d&quot; in &quot;create&quot; vs &quot;created&quot;):\r\n\r\n```\r\n$ jq -n &#39;[&quot;created&quot;] | contains([&quot;create&quot;])&#39;\r\ntrue\r\n```\r\n\r\nYou can use the SQL-style `IN` filter:\r\n\r\n```\r\n$ jq -n &#39;&quot;create&quot; | IN(&quot;created&quot;, &quot;foo&quot;)&#39;\r\nfalse\r\n$ jq -n &#39;&quot;created&quot; | IN(&quot;created&quot;, &quot;bar&quot;)&#39;\r\ntrue\r\n```\r\n\r\nSo for your concrete use case you would probably want something like the following:\r\n\r\n```\r\nterraform show -json tfplan | jq &#39;\r\n  .resource_changes[]\r\n  | select(\r\n    .change.actions as $actions\r\n    | &quot;create&quot; | IN($actions[])\r\n    or &quot;update&quot; | IN($actions[]))&#39;\r\n```\r\n\r\nOr using `any/2`:\r\n\r\n\r\n```\r\nterraform show -json tfplan | jq &#39;\r\n  .resource_changes[]\r\n  | select(any(.change.actions[]; .==&quot;create&quot; or .==&quot;update&quot;))&#39;\r\n```",
                "title": "How to use jq to extract a particular field from a terraform plan to show resources that are updated or changed?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1674871779,
        "creation_date": 1674854144,
        "last_edit_date": 1674871779,
        "question_id": 75263431,
        "body_markdown": "I just want to be able to have a small quick view or list of what is changing with a terraform plan instead of the long output given by a terraform plan.\r\n\r\nSo far I think it can be done with a terraform plan and jq.\r\n\r\nHere is what I have so far -\r\n\r\nI run a plan like this:\r\n```\r\nterraform plan -out=tfplan -no-color -detailed-exitcode\r\n```\r\n\r\nThen I am trying to use jq to get the changes or updates using this:\r\n```\r\nterraform show -json tfplan | jq &#39;.resource_changes[] \r\n                            | select( .change.actions \r\n                                     | contains(&quot;create&quot;) or contains(&quot;update&quot;) )&#39;\r\n```\r\n\r\n\r\nIt gives me the error :\r\n\r\n&gt;     jq: error (at &lt;stdin&gt;:1): array ([&quot;no-op&quot;]) and string (&quot;create&quot;) \r\n&gt;     cannot have their containment checked\r\n\r\nMy jq skills are not the best - can anyone update my jq to work or is there an alternative way to do this?\r\n",
        "link": "https://stackoverflow.com/questions/75263431/how-to-use-jq-to-extract-a-particular-field-from-a-terraform-plan-to-show-resour",
        "title": "How to use jq to extract a particular field from a terraform plan to show resources that are updated or changed?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1674903573,
                "last_edit_date": 1674903573,
                "creation_date": 1674903149,
                "answer_id": 75267081,
                "question_id": 75266992,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be using `group_by` with some `map`s to bring the parts in place:\r\n```sh\r\nmap(.fruit = .fruits[]) | group_by(.fruit)\r\n| map({fruit: first.fruit, liked_by: map(.name)})\r\n```\r\n[Demo](https://jqplay.org/s/zT4DNJUAWlj)\r\n\r\n---\r\n\r\nAnother way would be creating an index (dictionary) using nested `reduce`s, then `map`ping the result back to an array:\r\n```sh\r\nreduce .[] as {$name, $fruits} ({}; reduce $fruits[] as $fruit (.;\r\n  .[$fruit] |= (.fruit = $fruit | .liked_by += [$name])\r\n)) | map(.)\r\n```\r\n[Demo](https://jqplay.org/s/M_zAc_Vy8zF)\r\n\r\n---\r\n\r\nOutput:\r\n```json\r\n[\r\n  {\r\n    &quot;fruit&quot;: &quot;apple&quot;,\r\n    &quot;liked_by&quot;: [\r\n      &quot;Trevor&quot;,\r\n      &quot;Lily&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;fruit&quot;: &quot;banana&quot;,\r\n    &quot;liked_by&quot;: [\r\n      &quot;Trevor&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;fruit&quot;: &quot;haribo&quot;,\r\n    &quot;liked_by&quot;: [\r\n      &quot;Lily&quot;\r\n    ]\r\n  }\r\n]\r\n```",
                "title": "jq reverse data structure and append to array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1674927016,
        "creation_date": 1674902269,
        "last_edit_date": 1674927016,
        "question_id": 75266992,
        "body_markdown": "I have:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Trevor&quot;,\r\n    &quot;fruits&quot;: [&quot;apple&quot;, &quot;banana&quot;]\r\n  }, {\r\n    &quot;name&quot;: &quot;Lily&quot;,\r\n    &quot;fruits&quot;: [&quot;apple&quot;, &quot;haribo&quot;]\r\n  }\r\n]\r\n```\r\n\r\nAnd I want a `jq` filter to kind of reverse the data structure, and get the names in an array:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;fruit&quot;: &quot;apple&quot;,\r\n    &quot;liked_by&quot;: [&quot;Trevor&quot;, &quot;Lily&quot;]\r\n  }, {\r\n    &quot;fruit&quot;: &quot;banana&quot;,\r\n    &quot;liked_by&quot;: [&quot;Trevor&quot;]\r\n  }, {\r\n    &quot;fruit&quot;: &quot;haribo&quot;,\r\n    &quot;liked_by&quot;: [&quot;Lily&quot;]\r\n  }\r\n]\r\n```\r\n\r\nI am trying things like this:\r\n```sh\r\njq &#39;\r\n  [\r\n    .[]\r\n    | .name as $name\r\n    | .fruits[]\r\n    | {&quot;name&quot;: $name, &quot;liked_by&quot;: += [.]}\r\n  ]\r\n&#39; input.json\r\n```",
        "link": "https://stackoverflow.com/questions/75266992/jq-reverse-data-structure-and-append-to-array",
        "title": "jq reverse data structure and append to array"
    },
    {
        "tags": [
            "bash",
            "jq",
            "gnu-parallel"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674914450,
                "post_id": 75268073,
                "comment_id": 132817735,
                "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": 1674918537,
                "post_id": 75268073,
                "comment_id": 132818450,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674922400,
                "post_id": 75268073,
                "comment_id": 132819133,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 452355,
                    "reputation": 5903,
                    "user_id": 848746,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/53f8a63ef3f02b3d02788f4a90fff3e3?s=256&d=identicon&r=PG",
                    "display_name": "AJW",
                    "link": "https://stackoverflow.com/users/848746/ajw"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674923479,
                "post_id": 75268073,
                "comment_id": 132819346,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3380632,
                    "reputation": 15089,
                    "user_id": 2837741,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/AEHnE.png?s=256",
                    "display_name": "daniu",
                    "link": "https://stackoverflow.com/users/2837741/daniu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674925856,
                "post_id": 75268073,
                "comment_id": 132819806,
                "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": 1675024435,
                "post_id": 75268073,
                "comment_id": 132834488,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 150087,
                    "reputation": 34036,
                    "user_id": 363028,
                    "user_type": "registered",
                    "accept_rate": 59,
                    "profile_image": "https://i.sstatic.net/cP1F2.jpg?s=256",
                    "display_name": "Ole Tange",
                    "link": "https://stackoverflow.com/users/363028/ole-tange"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675068528,
                "post_id": 75268073,
                "comment_id": 132840993,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 150087,
                    "reputation": 34036,
                    "user_id": 363028,
                    "user_type": "registered",
                    "accept_rate": 59,
                    "profile_image": "https://i.sstatic.net/cP1F2.jpg?s=256",
                    "display_name": "Ole Tange",
                    "link": "https://stackoverflow.com/users/363028/ole-tange"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675069111,
                "post_id": 75268073,
                "comment_id": 132841154,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1674925435,
                "last_edit_date": 1674925435,
                "creation_date": 1674924796,
                "answer_id": 75269283,
                "question_id": 75268073,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; `results.json` is a large file containing a json on each line\r\n\r\nYou could use `--spreadstdin` and `-n1` to linewise spread the input into your `jq` filter. Without knowing about the structure of your input JSONs, I have just copied over your &quot;vanilla&quot; filter:\r\n\r\n```sh\r\n&lt; results.json &gt; test.out parallel -j0 -n1 -k --spreadstdin &#39;jq -r &#39;\\&#39;&#39;\r\n  ._id as $id | ._source.CitationTextHeader.Article.AuthorList[]?\r\n  | .Affiliation.Affiliation | [$id, .[0:rindex(&quot; Electronic address:&quot;)]]\r\n  | @csv\r\n&#39;\\&#39;\r\n```",
                "title": "using jq and gnu parallel together"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1675093036,
                "last_edit_date": 1675093036,
                "creation_date": 1675092104,
                "answer_id": 75286450,
                "question_id": 75268073,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Without more info this will be a guess:\r\n\r\n~~~\r\ndoit() {\r\n  jq --raw-output &#39;._id as $id | ._source.CitationTextHeader.Article.AuthorList[]? | .Affiliation.Affiliation | [ $id, .[0:rindex(&quot; Electronic address:&quot;)] ] | @csv&#39;\r\n}\r\nexport -f doit\r\ncat results.json | parallel --pipe doit &gt; test.out\r\n~~~\r\n\r\nIt reads blocks of ~1 MB from `results.json` which it passes to `doit`.\r\n\r\nIf that works, you may be able to speed up the processing with:\r\n\r\n~~~\r\nparallel --block -1 -a results.json --pipepart doit &gt; test.out\r\n~~~\r\n\r\nIt will on-the-fly split up `results.json` into n parts (where n = number of CPU threads). Each part will be piped into `doit`. The overhead of this is quite small.\r\n\r\nAdd `--keep-order` if you need the output to be in the same order as input.\r\n\r\nIf your disks are slow and your CPU is fast, this may be even faster:\r\n\r\n~~~\r\nparallel --lb --block -1 -a results.json --pipepart doit &gt; test.out\r\n~~~\r\n\r\nIt will buffer in RAM instead of in tempfiles. `--keep-order` will, however, not be useful here because the output from job 2 will only be read after job 1 is done.\r\n\r\n\r\n\r\n",
                "title": "using jq and gnu parallel together"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1675093036,
        "creation_date": 1674913451,
        "last_edit_date": 1674927517,
        "question_id": 75268073,
        "body_markdown": "I have a `jq` command which I am trying to parallelise using `GNU parallel` but for some reason I am not able to get it to work.\r\n\r\nThe vanilla `jq` query is:\r\n\r\n```\r\njq --raw-output &#39;._id as $id | ._source.CitationTextHeader.Article.AuthorList[]? | .Affiliation.Affiliation | [ $id, .[0:rindex(&quot; Electronic address:&quot;)] ] | @csv&#39; results.json &gt; test.out\r\n```\r\n\r\nI have tried to use it with `parallel` like so:\r\n\r\n```\r\nparallel -j0 --keep-order --spreadstdin &quot;jq --raw-output &#39;._id as $id | ._source.CitationTextHeader.Article.AuthorList[]? | .Affiliation.Affiliation | [ $id, .[0:rindex(&quot; Electronic address:&quot;)] ] | @csv&#39;&quot; &lt; results.json &gt; test.json\r\n```\r\n\r\nbut I get some bizzare compile error:\r\n\r\n```\r\njq: error: syntax error, unexpected &#39;|&#39;, expecting &#39;$&#39; or &#39;[&#39; or &#39;{&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n._id as  | ._source.CitationTextHeader.Article.AuthorList[]? | .Affiliation.Affiliation | [ , .[0:rindex( Electronic address:)] ] | @csv         \r\njq: 1 compile error\r\n```\r\n\r\n\r\nI think it does not like something re: quoting things in the string, but the error is a bit unhelpful. \r\n\r\n\r\n*UPDATE*\r\n\r\nLooking at other threads, I managed to construct this:\r\n\r\n```\r\nparallel -a results.json --results test.json -q jq -r &#39;._id as $id | ._source.CitationTextHeader.Article.AuthorList[]? | .Affiliation.Affiliation | [ $id, .[0:rindex(&quot; Electronic address:&quot;)] ] | @csv&#39;\r\n```\r\n\r\nbut now it complains:\r\n\r\n```\r\nparallel: Error: Command line too long (76224 &gt;= 63664) at input 0:\r\n```\r\n\r\n:(\r\n\r\n\r\nAn aexample (firstline) of the json file:\r\n\r\n```\r\n{\r\n  &quot;_index&quot;: &quot;corpuspm&quot;,\r\n  &quot;_type&quot;: &quot;_doc&quot;,\r\n  &quot;_id&quot;: &quot;6786777&quot;,\r\n  &quot;_score&quot;: 1,\r\n  &quot;_source&quot;: {\r\n    &quot;CitationTextHeader&quot;: {\r\n      &quot;Article&quot;: {\r\n        &quot;AuthorList&quot;: [\r\n          {\r\n            &quot;Affiliation&quot;: {\r\n              &quot;Affiliation&quot;: &quot;title, society, American Pediatric Society. address@hotmail.com.&quot;\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/75268073/using-jq-and-gnu-parallel-together",
        "title": "using jq and gnu parallel together"
    },
    {
        "tags": [
            "json",
            "jq",
            "rolling-computation"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1674976881,
                "last_edit_date": 1674976881,
                "creation_date": 1674975996,
                "answer_id": 75273150,
                "question_id": 75272930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a `derivative` method for this kind of task:\r\n```\r\n# Input: an array\r\n# $delta is the lag (e.g. 1) or lead (e.g. -1)\r\n# p1 is the jq path expression to the quantity within &quot;this&quot; item\r\n# p2 is the jq path expression to the quantity within &quot;that&quot; item\r\n# q  is the jq path expression for the delta value\r\ndef derivative($delta; p1; p2; q):\r\n    . as $in\r\n    | length as $length\r\n    | [ range(0; $length) as $i\r\n        | .[$i]\r\n\t    | if 0 &lt;= $i and $i &lt; $length and 0 &lt;= ($i - $delta) and ($i - $delta) &lt; $length\r\n          then q = ($in[$i] | p1) - ($in[$i - $delta] | p2) \r\n\t      | q |= (if $delta &gt; 0 then . else - . end)\r\n\t      else q = null\r\n\t      end ];\r\n```\r\nIf `$data` holds your data, then based on my understanding of the question, you would invoke it like this:\r\n```\r\n$data\r\n| derivative(-1; .completionTime_epoch_secs; .submitTime_epoch_secs; .delayTillNextStageSubmit)\r\n| derivative( 1; .submitTime_epoch_secs; .completionTime_epoch_secs; .delayFromPrevStageComplete)\r\n```\r\n\r\nPlease note there seems to be an inconsistency between the input and output for stageId 3 in your example: &quot;submitTime_epoch_secs&quot; is shown as 22 and then as 29.",
                "title": "jq to report rolling differences between array element values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1675119235,
                "last_edit_date": 1675119235,
                "creation_date": 1675109117,
                "answer_id": 75289578,
                "question_id": 75272930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\n. as $array | to_entries | map(\r\n    .value.delayFromPrevStageComplete = .value.submitTime_epoch_secs - $array[.key - 1].completionTime_epoch_secs |\r\n    .value.delayTillNextStageSubmit = $array[(.key + 1) % length].submitTime_epoch_secs - .value.completionTime_epoch_secs |\r\n    .value\r\n) | (\r\n    .[0].delayFromPrevStageComplete,\r\n    .[-1].delayTillNextStageSubmit\r\n) = null\r\n```\r\n`to_entries` is used to get the index of each entry as `.key`.\r\n`(.key + 1) % length` is used to avoid an error with the last element.",
                "title": "jq to report rolling differences between array element values"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1675119235,
        "creation_date": 1674972598,
        "last_edit_date": 1675074080,
        "question_id": 75272930,
        "body_markdown": "I have an input like below which just has stageIds, along with their submit and completion time in unix time seconds\r\n```\r\n[\r\n  {\r\n    &quot;stageId&quot;: 1,\r\n    &quot;submitTime_epoch_secs&quot;: 5,\r\n    &quot;completionTime_epoch_secs&quot;: 10\r\n  },\r\n  {\r\n    &quot;stageId&quot;: 2,\r\n    &quot;submitTime_epoch_secs&quot;: 15,\r\n    &quot;completionTime_epoch_secs&quot;: 17\r\n  },\r\n  {\r\n    &quot;stageId&quot;: 3,\r\n    &quot;submitTime_epoch_secs&quot;: 29,\r\n    &quot;completionTime_epoch_secs&quot;: 30\r\n  }\r\n]\r\n```\r\n\r\ndesired output is below, where each stageId, submit, and completion times are compared with previous and next and the delay is added as another key/val per element.\r\n```\r\n[\r\n  {\r\n    &quot;stageId&quot;: 1,\r\n    &quot;submitTime_epoch_secs&quot;: 5,\r\n    &quot;completionTime_epoch_secs&quot;: 10,\r\n    &quot;delayTillNextStageSubmit&quot;,5\r\n    &quot;delayFromPrevStageComplete&quot;,null\r\n  },\r\n  {\r\n    &quot;stageId&quot;: 2,\r\n    &quot;submitTime_epoch_secs&quot;: 15,\r\n    &quot;completionTime_epoch_secs&quot;: 17,\r\n    &quot;delayTillNextStageSubmit&quot;,12\r\n    &quot;delayFromPrevStageComplete&quot;,5\r\n  },\r\n  {\r\n    &quot;stageId&quot;: 3,\r\n    &quot;submitTime_epoch_secs&quot;: 29,\r\n    &quot;completionTime_epoch_secs&quot;: 30,\r\n    &quot;delayTillNextStageSubmit&quot;,null\r\n    &quot;delayFromPrevStageComplete&quot;,12\r\n  }\r\n]\r\n```\r\nhere the stageId 1 delayTillNextStageSubmit is difference between stageId 2 submitTime and stageId 1 completion time, 15 - 10 = 5.\r\n\r\nis this possible with jq?\r\n\r\nI am new to jq, so don&#39;t know how to solve this",
        "link": "https://stackoverflow.com/questions/75272930/jq-to-report-rolling-differences-between-array-element-values",
        "title": "jq to report rolling differences between array element values"
    },
    {
        "tags": [
            "json",
            "linux",
            "yaml",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1674991096,
                "last_edit_date": 1674991096,
                "creation_date": 1674990790,
                "answer_id": 75274413,
                "question_id": 75274375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the update operator `|=`\r\n\r\n```sh\r\n.[].Resources[].TargetService.Properties |= (\r\n  .TaskDefinition = &quot;123&quot;\r\n  | .LoadBalancerInfo.ContainerName = &quot;456&quot;\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/1S_Uuj5uis1)\r\n\r\n---\r\n\r\nNote that `select` only filters its input, it does not descend into the filter criterion. So, if you only want to make the update if the `.Properties` field exists, use `select` **and** descend into it.\r\n\r\n```sh\r\n( .[].Resources[].TargetService\r\n  | select(.Properties).Properties\r\n) |= (\r\n  .TaskDefinition = &quot;123&quot;\r\n  | .LoadBalancerInfo.ContainerName = &quot;456&quot;\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/_NCxc2ZulJE)\r\n\r\n---\r\n\r\nNote that the filter `select(.Properties)` will produce `false` if the content of that field, albeit existing, evaluates to `null` or `false`. If you want to consider such cases also as &quot;existent&quot;, use `has` in the `select` filter to test for it.\r\n\r\n```sh\r\n( .[].Resources[].TargetService\r\n  | select(has(&quot;Properties&quot;)).Properties\r\n) |= (\r\n  .TaskDefinition = &quot;123&quot;\r\n  | .LoadBalancerInfo.ContainerName = &quot;456&quot;\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/zM-CIVTdCPh)",
                "title": "How to replace multiple values in json file using jq and returning the whole content"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1674992011,
                "last_edit_date": 1674992011,
                "creation_date": 1674990805,
                "answer_id": 75274415,
                "question_id": 75274375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need `select`, you can specify the path directly:\r\n\r\n```\r\n.[].Resources[].TargetService.Properties.TaskDefinition = &quot;123&quot;\r\n| .[].Resources[].TargetService.Properties.LoadBalancerInfo.ContainerName = &quot;456&quot;\r\n```\r\n\r\nOr group by the top level property:\r\n\r\n```\r\n.[].Resources[].TargetService.Properties |= (\r\n    .TaskDefinition |= &quot;123&quot;\r\n    | .LoadBalancerInfo.ContainerName |= &quot;456&quot;\r\n)\r\n```\r\n\r\nIt&#39;s also possible to recursively merge the expected object into your existing object using [`*=`](https://stedolan.github.io/jq/manual/v1.6/#Multiplication,division,modulo:*,/,and%):\r\n\r\n```\r\n.[].Resources[].TargetService.Properties *= {\r\n    TaskDefinition: &quot;123&quot;,\r\n    LoadBalancerInfo: {\r\n        ContainerName: &quot;456&quot;\r\n    }\r\n}\r\n```\r\n\r\nOutput of all three variants:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;version&quot;: 0,\r\n    &quot;Resources&quot;: [\r\n      {\r\n        &quot;TargetService&quot;: {\r\n          &quot;Type&quot;: &quot;AWS::ECS::Service&quot;,\r\n          &quot;Properties&quot;: {\r\n            &quot;TaskDefinition&quot;: &quot;123&quot;,\r\n            &quot;LoadBalancerInfo&quot;: {\r\n              &quot;ContainerName&quot;: &quot;def&quot;,\r\n              &quot;ContainerPort&quot;: 456\r\n            }\r\n          }\r\n        }\r\n      }\r\n    ]\r\n  }\r\n]\r\n```",
                "title": "How to replace multiple values in json file using jq and returning the whole content"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1674992025,
                "creation_date": 1674992025,
                "answer_id": 75274547,
                "question_id": 75274375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Both the above solutions works perfectly fine. Thanks @Knittl and @pmf. For others who are stuck with this kind of problem here is my complete command to pass two variables to jq and replace the values in one shot.\r\n\r\n    echo $APP_SPEC | jq --arg TASK_DEFINITION &quot;$NEW_TASK_DEFINITION_ARN&quot; --arg CONTAINER_NAME &quot;$CONTAINER_NAME&quot; &#39;.[].Resources[].TargetService.Properties |= (.TaskDefinition = $TASK_DEFINITION | .LoadBalancerInfo.ContainerName = $CONTAINER_NAME )&#39;\r\n",
                "title": "How to replace multiple values in json file using jq and returning the whole content"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1674992025,
        "creation_date": 1674990371,
        "last_edit_date": 1674990851,
        "question_id": 75274375,
        "body_markdown": "I have a json like this\r\n\r\n```\r\n[{&quot;version&quot;: 0.0,&quot;Resources&quot;: [ {&quot;TargetService&quot;: {&quot;Type&quot;: &quot;AWS::ECS::Service&quot;,&quot;Properties&quot;: {&quot;TaskDefinition&quot;: &quot;abc&quot;,&quot;LoadBalancerInfo&quot;: {&quot;ContainerName&quot;: &quot;def&quot;,&quot;ContainerPort&quot;: 8080}}}} ]}]\r\n```\r\n\r\nMy attempt is to replace **TaskDefinition** key value from &quot;abc&quot; to  &quot;123&quot; and **ContainerName** key value from &quot;def&quot; to &quot;456 in one command and return the whole update json.\r\n\r\nThis is what i tried\r\n\r\n``` \r\necho $APP_SPEC | jq --arg TASK_DEFINITION &quot;123&quot; &#39;(.[].Resources[].TargetService | select(.Properties)).TaskDefinition |=$TASK_DEFINITION&#39;)\r\n```\r\n\r\n\r\nBut the substistuion is not happening properly and the value gets appended at the end of the josn as below. \r\n\r\nIncorrect response:\r\n\r\n``` \r\n[ { &quot;version&quot;: 0, &quot;Resources&quot;: [ { &quot;TargetService&quot;: { &quot;Type&quot;: &quot;AWS::ECS::Service&quot;, &quot;Properties&quot;: { &quot;TaskDefinition&quot;: &quot;abc&quot;, &quot;LoadBalancerInfo&quot;: { &quot;ContainerName&quot;: &quot;container_name&quot;, &quot;ContainerPort&quot;: 8080 } }, &quot;TaskDefinition&quot;: &quot;123&quot; } } ] } ] \r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75274375/how-to-replace-multiple-values-in-json-file-using-jq-and-returning-the-whole-con",
        "title": "How to replace multiple values in json file using jq and returning the whole content"
    },
    {
        "tags": [
            "jq",
            "sparql",
            "wikidata"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1675166371,
                "creation_date": 1675166371,
                "answer_id": 75296820,
                "question_id": 75296612,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `map_values` which works like the outer `map` but for objects, i.e. it retains the object structure, including the field names:\r\n```sh\r\njq &#39;map(map_values(.value))&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;language&quot;: &quot;https://lingualibre.org/entity/Q100&quot;,\r\n    &quot;wikidata&quot;: &quot;Q36157&quot;,\r\n    &quot;code&quot;: &quot;lub&quot;\r\n  },\r\n  {\r\n    &quot;language&quot;: &quot;https://lingualibre.org/entity/Q101&quot;,\r\n    &quot;wikidata&quot;: &quot;Q36284&quot;,\r\n    &quot;code&quot;: &quot;srr&quot;\r\n  }\r\n]\r\n```\r\nNote that this solution lacks the name conversion from `code` to `iso`.",
                "title": "Simplify array of objects with children using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1675166371,
        "creation_date": 1675165376,
        "question_id": 75296612,
        "body_markdown": "From Wikidata, I get the following json:\r\n```bash\r\n# Sparql query\r\nquery=$(cat ./myquery.sparql)\r\nresponse=$(curl -G --data-urlencode query=&quot;${query}&quot; https://wikidata.org/sparql?format=json)\r\necho &quot;${response}&quot; | jq &#39;.results.bindings&#39;\r\n```\r\n\r\n```js\r\n[\r\n  {\r\n    &quot;language&quot;: {\r\n      &quot;type&quot;: &quot;uri&quot;,\r\n      &quot;value&quot;: &quot;https://lingualibre.org/entity/Q100&quot;\r\n    },\r\n    &quot;wikidata&quot;: {\r\n      &quot;type&quot;: &quot;literal&quot;,\r\n      &quot;value&quot;: &quot;Q36157&quot;\r\n    },\r\n    &quot;code&quot;: {\r\n      &quot;type&quot;: &quot;literal&quot;,\r\n      &quot;value&quot;: &quot;lub&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;language&quot;: {\r\n      &quot;type&quot;: &quot;uri&quot;,\r\n      &quot;value&quot;: &quot;https://lingualibre.org/entity/Q101&quot;\r\n    },\r\n    &quot;wikidata&quot;: {\r\n      &quot;type&quot;: &quot;literal&quot;,\r\n      &quot;value&quot;: &quot;Q36284&quot;\r\n    },\r\n    &quot;code&quot;: {\r\n      &quot;type&quot;: &quot;literal&quot;,\r\n      &quot;value&quot;: &quot;srr&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nI would like to have the keys directly paired with their values, such as :\r\n```\r\n[\r\n  {\r\n    &quot;language&quot;: &quot;https://lingualibre.org/entity/Q100&quot;,\r\n    &quot;wikidata&quot;: &quot;Q36157&quot;,\r\n    &quot;iso&quot;: &quot;lub&quot;\r\n  },\r\n  {\r\n    &quot;language&quot;: &quot;https://lingualibre.org/entity/Q101&quot;,\r\n    &quot;wikidata&quot;: &quot;Q36284&quot;,\r\n    &quot;iso&quot;: &quot;srr&quot;\r\n  }\r\n]\r\n```\r\n\r\nI currently have a non-resilient code, which will break whenever the key names change : \r\n\r\n```bash\r\njq &#39;map({&quot;language&quot;:.language.value,&quot;wikidata&quot;:.wikidata.value,&quot;iso&quot;:.code.value})&#39;\r\n```\r\n\r\n**How to pair the keys with their values in a resilient way (not naming the keys) ?**\r\nI want to &quot;prune&quot; the child objects so to only keep the value.",
        "link": "https://stackoverflow.com/questions/75296612/simplify-array-of-objects-with-children-using-jq",
        "title": "Simplify array of objects with children using JQ"
    },
    {
        "tags": [
            "json",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1675171619,
                "creation_date": 1675171619,
                "answer_id": 75297889,
                "question_id": 75296879,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t know if this is the output format you want. How about this?\r\n\r\n```bash\r\ncat output.json | jq &#39;[.LoadBalancers[] | select(.LoadBalancerName | startswith(&quot;elb_name&quot;)) | { LoadBalancerName: .LoadBalancerName } ]&#39;\r\n[\r\n  {\r\n    &quot;LoadBalancerName&quot;: &quot;elb_name_123&quot;\r\n  },\r\n  {\r\n    &quot;LoadBalancerName&quot;: &quot;elb_name_456&quot;\r\n  },\r\n  {\r\n    &quot;LoadBalancerName&quot;: &quot;elb_name_789&quot;\r\n  }\r\n]\r\n```\r\n\r\n```bash\r\n$ cat output.json \r\n{\r\n  &quot;LoadBalancers&quot;: [\r\n    {\r\n      &quot;LoadBalancerArn&quot;: &quot;arn:aws:elasticloadbalancing...&quot;,\r\n      &quot;CreatedTime&quot;: &quot;2023-01-26T22:26:42.313000+00:00&quot;,\r\n      &quot;LoadBalancerName&quot;: &quot;elb_name_123&quot;\r\n    },\r\n    {\r\n      &quot;LoadBalancerArn&quot;: &quot;arn:aws:elasticloadbalancing...&quot;,\r\n      &quot;CreatedTime&quot;: &quot;2023-01-26T22:26:42.313000+00:00&quot;,\r\n      &quot;LoadBalancerName&quot;: &quot;elb_name_456&quot;\r\n    },\r\n    {\r\n      &quot;LoadBalancerArn&quot;: &quot;arn:aws:elasticloadbalancing...&quot;,\r\n      &quot;CreatedTime&quot;: &quot;2023-01-26T22:26:42.313000+00:00&quot;,\r\n      &quot;LoadBalancerName&quot;: &quot;elb_name_789&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "Extract an array of key-value pairs using JQ and from pre-filtered JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1675172042,
                "creation_date": 1675172042,
                "answer_id": 75297961,
                "question_id": 75296879,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need to use an extra `jq` for filtering AWS cli supports jmespath already.\r\n\r\nYou can filter loadbalancers with `starts_with`\r\n\r\n```sh\r\naws elbv2 describe-load-balancers --query &#39;LoadBalancers[?starts_with(LoadBalancerName, `elb_name`)].LoadBalancerName&#39;\r\n```",
                "title": "Extract an array of key-value pairs using JQ and from pre-filtered JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1675172042,
        "creation_date": 1675166674,
        "last_edit_date": 1675170046,
        "question_id": 75296879,
        "body_markdown": "I want to extract an array of key-value pairs from the below JSON, that is generated by the following AWS CLI script. The array should contain the load balancer names.\r\n\r\n```\r\naws elbv2 describe-load-balancers | jq &#39;.LoadBalancers[] | select(.LoadBalancerName | startswith(&quot;MY_LOAD_BALANCER_NAME&quot;))&#39;\r\n```\r\n\r\nI tried adding a JQ filter to the end of this script, as follows, but it did not work:\r\n\r\n\r\n```\r\naws elbv2 describe-load-balancers | jq &#39;.LoadBalancers[] | select(.LoadBalancerName | startswith(&quot;MY_LOAD_BALANCER_NAME&quot;))&#39; | jq -r .LoadBalancers[].LoadBalancerName\r\n```\r\n\r\nHere&#39;s a shorten version of my JSON output:\r\n\r\n```\r\n{\r\n    &quot;LoadBalancers&quot;: [\r\n        {\r\n            &quot;LoadBalancerArn&quot;: &quot;arn:aws:elasticloadbalancing...&quot;,\r\n            &quot;CreatedTime&quot;: &quot;2023-01-26T22:26:42.313000+00:00&quot;,\r\n            &quot;LoadBalancerName&quot;: &quot;elb_name_123&quot;\r\n        },\r\n        {\r\n            &quot;LoadBalancerArn&quot;: &quot;arn:aws:elasticloadbalancing...&quot;,\r\n            &quot;CreatedTime&quot;: &quot;2023-01-26T22:26:42.313000+00:00&quot;,\r\n            &quot;LoadBalancerName&quot;: &quot;elb_name_456&quot;\r\n        },\r\n        {\r\n            &quot;LoadBalancerArn&quot;: &quot;arn:aws:elasticloadbalancing...&quot;,\r\n            &quot;CreatedTime&quot;: &quot;2023-01-26T22:26:42.313000+00:00&quot;,\r\n            &quot;LoadBalancerName&quot;: &quot;elb_name_789&quot;\r\n        }\r\n    ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/75296879/extract-an-array-of-key-value-pairs-using-jq-and-from-pre-filtered-json",
        "title": "Extract an array of key-value pairs using JQ and from pre-filtered JSON"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675172011,
                "post_id": 75297860,
                "comment_id": 132867778,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675172052,
                "post_id": 75297860,
                "comment_id": 132867793,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1675172466,
                "creation_date": 1675172466,
                "answer_id": 75298044,
                "question_id": 75297860,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to use the [`@sh` string interpolation](https://stedolan.github.io/jq/manual/#Formatstringsandescaping) and then use your shell&#39;s `eval`.\r\n\r\nUsing the string interpolation would output something like:\r\n\r\n```\r\nboolStatus=true\r\nname=&#39;abc&#39;\r\n```\r\n\r\nwhich can then be fed to `eval`:\r\n\r\n```\r\nvars=&quot;$(curl ... | jq -r &#39;@sh &quot;boolStatus=\\(.isAutomated)&quot;, @sh &quot;name=\\(.name)&quot;&#39;)&quot;\r\neval &quot;$vars&quot;\r\n```\r\n\r\nor explicitly output the line break:\r\n\r\n```\r\njq -r &#39;@sh &quot;boolStatus=\\(.isAutomated)\\nname=\\(.name)&quot;&#39;\r\n```\r\n\r\nDisclaimer: Note that this will evaluate _any_ shell code and might open your system to malicious code (`@sh` escapes the values, but it&#39;s always a good idea to be aware of this).",
                "title": "how to put 2 elements from jq variables in one request?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1675176248,
                "creation_date": 1675176248,
                "answer_id": 75298842,
                "question_id": 75297860,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use process substitution to allow two uses of `read` to read from the output of `jq`.\r\n\r\n    { read boolStatus; read name; } &lt; &lt;(curl ... | jq -r &#39;.isAutomated, .name&#39;)\r\n\r\n(assuming the name does not contain any newlines).\r\n\r\nAt the very least, you can save the output to process with `jq` twice.\r\n\r\n    response=$(curl ...)\r\n    name=$(echo &quot;$response&quot; | jq -r .name)\r\n    boolStatus=$(echo &quot;$response&quot; | jq -r .isAutomated)",
                "title": "how to put 2 elements from jq variables in one request?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1675176248,
        "creation_date": 1675171487,
        "last_edit_date": 1675171922,
        "question_id": 75297860,
        "body_markdown": "There is a part of the script where each request receives a response and is written to a variable. How to do it in one request with writing to variables?\r\n```\r\nboolStatus=$(curl -X &#39;GET&#39; \\\r\n  &quot;https://tsit-app1/api/v2/workItems/$case?versionNumber=0&quot; \\\r\n  -H &#39;accept: application/json&#39; \\\r\n  -H &quot;Authorization: $apiKey&quot; | jq &#39;.isAutomated&#39;)\r\necho $boolStatus\r\n\r\nname=$(curl -X &#39;GET&#39; \\\r\n  &quot;https://tsit-app1/api/v2/workItems/$case?versionNumber=0&quot; \\\r\n  -H &#39;accept: application/json&#39; \\\r\n  -H &quot;Authorization: $apiKey&quot; | jq &#39;.name&#39;)\r\n  echo $name\r\n\r\nI tried\r\ncurl -X &#39;GET&#39; \\\r\n  &quot;https://tsit-app1/api/v2/workItems/$case?versionNumber=0&quot; \\\r\n  -H &#39;accept: application/json&#39; \\\r\n  -H &quot;Authorization: $apiKey&quot; | jq &#39;&quot;boolStatus=\\(.isAutomated)&quot;, &quot;name=\\(.name)&quot;&#39;\r\n```\r\nbut in echo i get\r\n```\r\n&quot;boolStatus=true&quot;, \r\n&quot;name=bla bla&quot;\r\n```\r\nneed to \r\n```\r\necho $boolStatus \r\ntrue\r\necho $name \r\nbla bla\r\n```",
        "link": "https://stackoverflow.com/questions/75297860/how-to-put-2-elements-from-jq-variables-in-one-request",
        "title": "how to put 2 elements from jq variables in one request?"
    },
    {
        "tags": [
            "jq",
            "yq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675198376,
                "post_id": 75302792,
                "comment_id": 132876245,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675199638,
                "post_id": 75302792,
                "comment_id": 132876591,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2313135,
                    "reputation": 3727,
                    "user_id": 2030808,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/iRrvi.png?s=256",
                    "display_name": "pmqs",
                    "link": "https://stackoverflow.com/users/2030808/pmqs"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675201643,
                "post_id": 75302792,
                "comment_id": 132877065,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1675197442,
                "creation_date": 1675197442,
                "answer_id": 75302867,
                "question_id": 75302792,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do you need that variable elsewhere? Because it just works without:\r\n```sh\r\nyq -p json -P -o json &#39;.[] | .id + &quot;-&quot; + .values[]&#39; data.json\r\n```\r\n```json\r\n&quot;id1-one&quot;\r\n&quot;id1-two&quot;\r\n&quot;id2-three&quot;\r\n```\r\nTested with mikefarah/yq version v4.30.5",
                "title": "Creating a composite string sourced from multiple places in a JSON document"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1675198239,
        "creation_date": 1675196998,
        "question_id": 75302792,
        "body_markdown": "Consider this JSON document\r\n\r\n```\r\necho &#39;\r\n{\r\n    &quot;alpha&quot;: {\r\n        &quot;id&quot;: &quot;id1&quot;,\r\n        &quot;values&quot;: [\r\n            &quot;one&quot;,\r\n            &quot;two&quot;\r\n        ]\r\n    },\r\n\r\n    &quot;beta&quot;: {\r\n        &quot;id&quot;: &quot;id2&quot;,\r\n        &quot;values&quot;: [\r\n            &quot;three&quot;\r\n        ]\r\n    }  \r\n}\r\n&#39; &gt;data.json\r\n```\r\n\r\ncheck syntax\r\n\r\n```\r\n$ yq -p json -P -o j &#39;true  &#39; data.json \r\ntrue\r\n```\r\n\r\nI want to generate a series of strings that combines the `id` field with each of the `values`. So output I need should look like this\r\n\r\n```\r\n&quot;id1-one&quot;\r\n&quot;id1-two&quot;\r\n&quot;id2-three&quot;\r\n```\r\n\r\nThis is what I&#39;ve tried\r\n\r\n```\r\n$ yq -p json -P -o j &#39;.[] | .id as $ID | .values[] | $ID + &quot;-&quot; + . &#39; data.json\r\n&quot;id1-one&quot;\r\n&quot;id2-one&quot;\r\n&quot;id1-two&quot;\r\n&quot;id2-two&quot;\r\n&quot;id1-three&quot;\r\n&quot;id2-three&quot;\r\n```\r\n\r\nThere seems to be a multiplication factor kicking in with the `$ID` variable. Is this the correct approach to get attributes from a different scope, or is there a cleaner way to achieve this?  \r\n\r\nNote -- the real JSON document contains a lot more nesting, so there are multiple nested arrays/objects between the `values` and the `id` attributes.\r\n\r\nOne final point. I tried the same code with `jq` and it worked fine.\r\n\r\n```\r\n$ jq &#39; .[] | .id as $ID | .values[] | $ID + &quot;-&quot; + .  &#39; data.json\r\n&quot;id1-one&quot;\r\n&quot;id1-two&quot;\r\n&quot;id2-three&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/75302792/creating-a-composite-string-sourced-from-multiple-places-in-a-json-document",
        "title": "Creating a composite string sourced from multiple places in a JSON document"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675202340,
                "post_id": 75303367,
                "comment_id": 132877267,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 472765,
                    "reputation": 27299,
                    "user_id": 881441,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Ktk8b.jpg?s=256",
                    "display_name": "Stephen Quan",
                    "link": "https://stackoverflow.com/users/881441/stephen-quan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675204455,
                "post_id": 75303367,
                "comment_id": 132877840,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675221677,
                "post_id": 75303367,
                "comment_id": 132880422,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1675227854,
                "last_edit_date": 1675227854,
                "creation_date": 1675204729,
                "answer_id": 75303883,
                "question_id": 75303367,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The tool `jq` can be used for JSON-manipulation:\r\n\r\n```sh\r\njq &#39;.[1].Name = &quot;Tom&quot; | .[1].Pet = &quot;rabbit&quot;&#39; data.json\r\n```\r\n\r\nThis will output the modified file on the console.\r\n\r\nNote that in general `jq [filter] data.json &gt; data.json` will not work and even when it seems to, overwriting the input file in this way should be avoided.  One option would be to use a shell variable:\r\n\r\n```sh\r\njson_data=$(jq &#39;.[1].Name = &quot;Tom&quot; | .[1].Pet = &quot;rabbit&quot;&#39; data.json)\r\necho $json_data &gt; data.json\r\n```\r\n\r\nAnother option would be to use a temporary file; still another would be to use a utility such as `sponge` in [tag:moreutils].\r\n\r\n---\r\n\r\nNote that your shown file is not valid JSON and so jq will not be able to read it as JSON. To fix it, I have surrounded everything by `[` and `]` and removed the extra comma in the `John` object.",
                "title": "How to dynamically update one json object and put it back into the original json objects?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1675229277,
                "last_edit_date": 1675229277,
                "creation_date": 1675228722,
                "answer_id": 75305962,
                "question_id": 75303367,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; What if we don&#39;t know the exact index position of this object and use a filter of &#39;Name=John&#39;\r\n\r\n```\r\n&lt; data.json jq &#39;\r\n  (map(.Name)| index(&quot;John&quot;)) as $ix \r\n  | (select($ix)\r\n     | .[$ix] |= (.Name = &quot;Tom&quot; | .Pet = &quot;rabbit&quot;)) // .\r\n&#39; | sponge data.json \r\n```\r\n\r\nBut you might want to backup data.json first.",
                "title": "How to dynamically update one json object and put it back into the original json objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1675237599,
        "creation_date": 1675200804,
        "last_edit_date": 1675237599,
        "question_id": 75303367,
        "body_markdown": "How to dynamically update one JSON object and put it back into the original JSON objects variable?\r\n\r\nI have one variable with the following JSON data in it.\r\n\r\n\r\n```json\r\ntest=&#39;[\r\n  {\r\n    &quot;Name&quot;: &quot;James&quot;,\r\n    &quot;Mobile&quot;: 12345678,\r\n    &quot;Gender&quot;: &quot;Male&quot;,\r\n    &quot;Boolean&quot;: true,\r\n    &quot;Pet&quot;: &quot;cat&quot;\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;John&quot;,\r\n    &quot;Mobile&quot;: 1234567875,\r\n    &quot;Gender&quot;: &quot;Male&quot;,\r\n    &quot;Boolean&quot;: true,\r\n    &quot;Pet&quot;: &quot;rat&quot;\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;Jennifer&quot;,\r\n    &quot;Mobile&quot;: 1234567890,\r\n    &quot;Gender&quot;: &quot;Female&quot;,\r\n    &quot;Boolean&quot;: true,\r\n    &quot;Pet&quot;: &quot;Dog&quot;\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;Julia&quot;,\r\n    &quot;Mobile&quot;: 1234567890,\r\n    &quot;Gender&quot;: &quot;Female&quot;,\r\n    &quot;Boolean&quot;: true,\r\n    &quot;Pet&quot;: &quot;Dog&quot;\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;Jeff&quot;,\r\n    &quot;Mobile&quot;: 9871234567890,\r\n    &quot;Gender&quot;: &quot;Male&quot;,\r\n    &quot;Boolean&quot;: true,\r\n    &quot;Pet&quot;: &quot;Fish&quot;\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;Jones&quot;,\r\n    &quot;Mobile&quot;: 79871234567890,\r\n    &quot;Gender&quot;: &quot;Female&quot;,\r\n    &quot;Boolean&quot;: true,\r\n    &quot;Pet&quot;: &quot;Parrot&quot;\r\n  }\r\n]&#39;\r\n\r\nitems=$(echo &quot;$test&quot; | jq -c -r &#39;.[]&#39;)\r\nfor item in ${items[@]}; do\r\n    uName=$(echo $item | jq -r &#39;.Name&#39;)\r\n    if [ &quot;$uName&quot; == &quot;John&quot; ]; then\r\n        echo &quot;$item&quot;\r\n        echo &quot; &quot;\r\n        modifiedTest=$(echo &quot;$item&quot; | jq  &#39;.Name = &quot;Tom&quot;&#39;)\r\n        modifiedTest=$(echo &quot;$modifiedTest&quot; | jq  &#39;.Pet = &quot;rabbit&quot;&#39;)\r\n        echo &quot;$modifiedTest&quot;\r\n    fi    \r\ndone\r\n\r\n```\r\nNow let&#39;s say we have the below second JSON object from the above JSON objects\r\n```json\r\n{\r\n  &quot;Name&quot;: &quot;John&quot;,\r\n  &quot;Mobile&quot;: 1234567875,\r\n  &quot;Gender&quot;: &quot;Male&quot;,\r\n  &quot;Boolean&quot;: true,\r\n  &quot;Pet&quot;: &quot;rat&quot;\r\n}\r\n```\r\nWe have updated the above-picked JSON object fields with below\r\n\r\n```json\r\n{\r\n  &quot;Name&quot;: &quot;Tom&quot;,\r\n  &quot;Mobile&quot;: 1234567875,\r\n  &quot;Gender&quot;: &quot;Male&quot;,\r\n  &quot;Boolean&quot;: true,\r\n  &quot;Pet&quot;: &quot;rabbit&quot;\r\n}\r\n```\r\n\r\nNow how can we add/update the above modified JSON object back into the original objects list variable &#39;test&#39; at the exact position (2nd position in this case) but using a filter of &#39;Name=John&#39; and in a dynamic way we don&#39;t know exact index position of this object using bash scripting?\r\n",
        "link": "https://stackoverflow.com/questions/75303367/how-to-dynamically-update-one-json-object-and-put-it-back-into-the-original-json",
        "title": "How to dynamically update one json object and put it back into the original json objects?"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "intersect"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1675247349,
                "creation_date": 1675247349,
                "answer_id": 75308819,
                "question_id": 75308708,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n``` none\r\n$ jq &#39;del(.[(keys - (input | keys))[]])&#39; nl-NL.json en-US.json\r\n{\r\n  &quot;car&quot;: &quot;auto&quot;,\r\n  &quot;bike&quot;: &quot;fiets&quot;,\r\n  &quot;tree&quot;: &quot;boom&quot;\r\n}\r\n```",
                "title": "Use jq to remove key/value pairs based on other file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1675247663,
                "creation_date": 1675247663,
                "answer_id": 75308890,
                "question_id": 75308708,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To reduce the `nl-NL.json` file to the keys present in `en-US.json`, you could read in the latter as reference, then [`select`](https://stedolan.github.io/jq/manual/#select%28boolean_expression%29) from the input turned into entries those keys that are present in the reference file. [`in`](https://stedolan.github.io/jq/manual/#in) checks &quot;whether or not the input key is in the given object&quot;.\r\n```sh\r\njq --argfile ref en-US.json &#39;with_entries(select(.key | in($ref)))&#39; nl-NL.json\r\n```\r\n```json\r\n{\r\n  &quot;car&quot;: &quot;auto&quot;,\r\n  &quot;bike&quot;: &quot;fiets&quot;,\r\n  &quot;tree&quot;: &quot;boom&quot;\r\n}\r\n```",
                "title": "Use jq to remove key/value pairs based on other file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1675247663,
        "creation_date": 1675246867,
        "question_id": 75308708,
        "body_markdown": "I have 2 json files containing translations for my app:\r\n\r\nen-US.json:\r\n\r\n```json\r\n{\r\n    &quot;car&quot;: &quot;car&quot;,\r\n    &quot;bike&quot;: &quot;bike&quot;,\r\n    &quot;tree&quot;: &quot;tree&quot;,\r\n}\r\n```\r\n\r\nnl-NL.json:\r\n\r\n```json\r\n{\r\n    &quot;car&quot;: &quot;auto&quot;,\r\n    &quot;bike&quot;: &quot;fiets&quot;,\r\n    &quot;tree&quot;: &quot;boom&quot;,\r\n    &quot;house&quot;: &quot;huis&quot;\r\n}\r\n```\r\n\r\nAs you can see, I have removed the `house` from the en-US.json file (among many others). How could I remove the same `house` entry from my nl-NL.json file with jq? I basically want to get the intersection of both files, based on key.\r\n\r\nI&#39;ve been playing with `jq &#39;keys&#39;` to get all keys, but that does not work. I think it should be found in the direction of `jq --slurpfile en en-US.json &#39;del($en)&#39; nl-NL.json` but that totally does not work :(  Any suggestions?",
        "link": "https://stackoverflow.com/questions/75308708/use-jq-to-remove-key-value-pairs-based-on-other-file",
        "title": "Use jq to remove key/value pairs based on other file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1675252091,
                "post_id": 75309624,
                "comment_id": 132887248,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9239129,
                    "reputation": 155,
                    "user_id": 6862843,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e4f3684b6c064cc9928b06002f089a3a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "B Jam",
                    "link": "https://stackoverflow.com/users/6862843/b-jam"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675257037,
                "post_id": 75309624,
                "comment_id": 132888845,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1675327671,
                "post_id": 75309624,
                "comment_id": 132906019,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9239129,
                    "reputation": 155,
                    "user_id": 6862843,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e4f3684b6c064cc9928b06002f089a3a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "B Jam",
                    "link": "https://stackoverflow.com/users/6862843/b-jam"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675330765,
                "post_id": 75309624,
                "comment_id": 132906960,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1675253466,
                "creation_date": 1675253466,
                "answer_id": 75310002,
                "question_id": 75309624,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one way:\r\n``` none\r\n$ jq &#39;map(.theId) as $ids | input | map(select(.id | IN($ids[])))&#39; fileB fileA\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;bird&quot;,\r\n    &quot;content&quot;: {\r\n      &quot;key1&quot;: &quot;a&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;cat&quot;,\r\n    &quot;content&quot;: {\r\n      &quot;key1&quot;: &quot;c&quot;\r\n    }\r\n  }\r\n]\r\n```",
                "title": "Select objects from file A where value of path appear in file B in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1675254096,
                "last_edit_date": 1675254096,
                "creation_date": 1675253677,
                "answer_id": 75310042,
                "question_id": 75309624,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple solution using [`--slurpfile`](https://stedolan.github.io/jq/manual/#Invokingjq):\r\n\r\n```\r\njq --slurpfile b fileB &#39;map(select(.id|IN($b[][].theId)))&#39; fileA\r\n```",
                "title": "Select objects from file A where value of path appear in file B in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1675330652,
        "creation_date": 1675251529,
        "last_edit_date": 1675330652,
        "question_id": 75309624,
        "body_markdown": "I want to filter with jq the objects from json content of this `fileA`\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;bird&quot;,\r\n    &quot;content&quot;: {\r\n        &quot;key1&quot;: &quot;a&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;dog&quot;,\r\n    &quot;content&quot;: {\r\n        &quot;key1&quot;: &quot;b&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;cat&quot;,\r\n    &quot;content&quot;: {\r\n        &quot;key1&quot;: &quot;c&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nWhere the id appear in this json content of `fileB` called `theId` (the sort order has no importance) :\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;theId&quot;: &quot;cat&quot;\r\n  },\r\n  {\r\n    &quot;theId&quot;: &quot;bird&quot;\r\n  }\r\n]\r\n```\r\n\r\nExpected result (the sort order has no importance) :\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;cat&quot;,\r\n    &quot;content&quot;: {\r\n      &quot;key1&quot;: &quot;c&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;bird&quot;,\r\n    &quot;content&quot;: {\r\n      &quot;key1&quot;: &quot;a&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nI think I can do this in a bash loop :\r\n1. looping on ids from fileB \r\n2. execute jq to extract the given id such as\r\n&gt;```\r\n&gt;jq -c &quot;map(select(.id | contains(\\&quot;$id\\&quot;)))&quot;\r\n&gt;```\r\nbut I have to separate them with **`,`** which seems dirty.\r\n\r\nI don&#39;t know how to say to jq `the filter is composed of values of the given array which is stored in fileB`\r\n\r\nIs it possible ?",
        "link": "https://stackoverflow.com/questions/75309624/select-objects-from-file-a-where-value-of-path-appear-in-file-b-in-jq",
        "title": "Select objects from file A where value of path appear in file B in jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675256478,
                "post_id": 75310489,
                "comment_id": 132888638,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1675256442,
                "creation_date": 1675256442,
                "answer_id": 75310559,
                "question_id": 75310489,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let [tag:jq] do it: -c is the --compact-output option.\r\n```sh\r\nmAuth=$(echo &quot;$Auth&quot; | jq -c .)\r\n```",
                "title": "how to convert json data into single string with no spaces in between using bash scripting?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1675256442,
        "creation_date": 1675256080,
        "question_id": 75310489,
        "body_markdown": "how to convert json data into single string with no spaces in between using bash scripting?\r\n\r\nI have below json data\r\n\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Invalid_Auth&quot;,\r\n    &quot;authType&quot;: &quot;Token&quot;,\r\n    &quot;username&quot;: null,\r\n    &quot;password&quot;: &quot;PASSWORD-MASKED&quot;,\r\n    &quot;header_1&quot;: &quot;Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c&quot;,\r\n    &quot;header_2&quot;: null,\r\n    &quot;header_3&quot;: null,\r\n    &quot;clientId&quot;: null,\r\n    &quot;clientSecret&quot;: null,\r\n    &quot;id&quot;: null,\r\n    &quot;accessTokenUri&quot;: null,\r\n    &quot;authorizationScheme&quot;: null,\r\n    &quot;clientAuthenticationScheme&quot;: null,\r\n    &quot;tokenName&quot;: null,\r\n    &quot;scope&quot;: null,\r\n    &quot;grantType&quot;: null,\r\n    &quot;preEstablishedRedirectUri&quot;: null,\r\n    &quot;useCurrentUri&quot;: null,\r\n    &quot;userAuthorizationUri&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;invalid&quot;: true,\r\n    &quot;lastTestedOn&quot;: null,\r\n    &quot;passwordMasked&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Invalid_Auth_Empty&quot;,\r\n    &quot;authType&quot;: &quot;Token&quot;,\r\n    &quot;username&quot;: null,\r\n    &quot;password&quot;: &quot;PASSWORD-MASKED&quot;,\r\n    &quot;header_1&quot;: &quot;Authorization: Bearer &quot;,\r\n    &quot;header_2&quot;: null,\r\n    &quot;header_3&quot;: null,\r\n    &quot;clientId&quot;: null,\r\n    &quot;clientSecret&quot;: null,\r\n    &quot;id&quot;: null,\r\n    &quot;accessTokenUri&quot;: null,\r\n    &quot;authorizationScheme&quot;: null,\r\n    &quot;clientAuthenticationScheme&quot;: null,\r\n    &quot;tokenName&quot;: null,\r\n    &quot;scope&quot;: null,\r\n    &quot;grantType&quot;: null,\r\n    &quot;preEstablishedRedirectUri&quot;: null,\r\n    &quot;useCurrentUri&quot;: null,\r\n    &quot;userAuthorizationUri&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;invalid&quot;: true,\r\n    &quot;lastTestedOn&quot;: null,\r\n    &quot;passwordMasked&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Invalid_Auth_SQL&quot;,\r\n    &quot;authType&quot;: &quot;Token&quot;,\r\n    &quot;username&quot;: null,\r\n    &quot;password&quot;: &quot;PASSWORD-MASKED&quot;,\r\n    &quot;header_1&quot;: &quot;Authorization: Bearer {{@Injection}}&quot;,\r\n    &quot;header_2&quot;: null,\r\n    &quot;header_3&quot;: null,\r\n    &quot;clientId&quot;: null,\r\n    &quot;clientSecret&quot;: null,\r\n    &quot;id&quot;: null,\r\n    &quot;accessTokenUri&quot;: null,\r\n    &quot;authorizationScheme&quot;: null,\r\n    &quot;clientAuthenticationScheme&quot;: null,\r\n    &quot;tokenName&quot;: null,\r\n    &quot;scope&quot;: null,\r\n    &quot;grantType&quot;: null,\r\n    &quot;preEstablishedRedirectUri&quot;: null,\r\n    &quot;useCurrentUri&quot;: null,\r\n    &quot;userAuthorizationUri&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;invalid&quot;: true,\r\n    &quot;lastTestedOn&quot;: null,\r\n    &quot;passwordMasked&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Default&quot;,\r\n    &quot;authType&quot;: &quot;Basic&quot;,\r\n    &quot;username&quot;: &quot;user1@netbanking.io&quot;,\r\n    &quot;password&quot;: &quot;Welcome@4321&quot;,\r\n    &quot;header_1&quot;: null,\r\n    &quot;header_2&quot;: null,\r\n    &quot;header_3&quot;: null,\r\n    &quot;clientId&quot;: null,\r\n    &quot;clientSecret&quot;: null,\r\n    &quot;id&quot;: null,\r\n    &quot;accessTokenUri&quot;: null,\r\n    &quot;authorizationScheme&quot;: null,\r\n    &quot;clientAuthenticationScheme&quot;: null,\r\n    &quot;tokenName&quot;: null,\r\n    &quot;scope&quot;: null,\r\n    &quot;grantType&quot;: null,\r\n    &quot;preEstablishedRedirectUri&quot;: null,\r\n    &quot;useCurrentUri&quot;: null,\r\n    &quot;userAuthorizationUri&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;invalid&quot;: true,\r\n    &quot;lastTestedOn&quot;: null,\r\n    &quot;passwordMasked&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;UserA&quot;,\r\n    &quot;authType&quot;: &quot;Token&quot;,\r\n    &quot;username&quot;: null,\r\n    &quot;password&quot;: &quot;PASSWORD-MASKED&quot;,\r\n    &quot;header_1&quot;: &quot;Authorization: Bearer {{@CmdCache | curl -s -d &#39;{\\&quot;username\\&quot;:\\&quot;admin\\&quot;,\\&quot;password\\&quot;:\\&quot;secret\\&quot;}&#39; -H \\&quot;Content-Type: application/json\\&quot; -H \\&quot;Accept: application/json\\&quot; -X POST https://ip/user/login | jq --raw-output \\&quot;.info.token\\&quot; }}&quot;,\r\n    &quot;header_2&quot;: null,\r\n    &quot;header_3&quot;: null,\r\n    &quot;clientId&quot;: null,\r\n    &quot;clientSecret&quot;: null,\r\n    &quot;id&quot;: null,\r\n    &quot;accessTokenUri&quot;: null,\r\n    &quot;authorizationScheme&quot;: null,\r\n    &quot;clientAuthenticationScheme&quot;: null,\r\n    &quot;tokenName&quot;: null,\r\n    &quot;scope&quot;: null,\r\n    &quot;grantType&quot;: null,\r\n    &quot;preEstablishedRedirectUri&quot;: null,\r\n    &quot;useCurrentUri&quot;: null,\r\n    &quot;userAuthorizationUri&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;invalid&quot;: true,\r\n    &quot;lastTestedOn&quot;: null,\r\n    &quot;passwordMasked&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;UserB&quot;,\r\n    &quot;authType&quot;: &quot;Token&quot;,\r\n    &quot;username&quot;: null,\r\n    &quot;password&quot;: &quot;PASSWORD-MASKED&quot;,\r\n    &quot;header_1&quot;: &quot;Authorization: Bearer {{@CmdCache | curl -s -d &#39;{\\&quot;username\\&quot;:\\&quot;admin\\&quot;,\\&quot;password\\&quot;:\\&quot;secret\\&quot;}&#39; -H \\&quot;Content-Type: application/json\\&quot; -H \\&quot;Accept: application/json\\&quot; -X POST https://ip/user/login | jq --raw-output \\&quot;.info.token\\&quot; }}&quot;,\r\n    &quot;header_2&quot;: null,\r\n    &quot;header_3&quot;: null,\r\n    &quot;clientId&quot;: null,\r\n    &quot;clientSecret&quot;: null,\r\n    &quot;id&quot;: null,\r\n    &quot;accessTokenUri&quot;: null,\r\n    &quot;authorizationScheme&quot;: null,\r\n    &quot;clientAuthenticationScheme&quot;: null,\r\n    &quot;tokenName&quot;: null,\r\n    &quot;scope&quot;: null,\r\n    &quot;grantType&quot;: null,\r\n    &quot;preEstablishedRedirectUri&quot;: null,\r\n    &quot;useCurrentUri&quot;: null,\r\n    &quot;userAuthorizationUri&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;invalid&quot;: true,\r\n    &quot;lastTestedOn&quot;: null,\r\n    &quot;passwordMasked&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;UserC&quot;,\r\n    &quot;authType&quot;: &quot;Token&quot;,\r\n    &quot;username&quot;: null,\r\n    &quot;password&quot;: &quot;PASSWORD-MASKED&quot;,\r\n    &quot;header_1&quot;: &quot;Authorization: Bearer {{@CmdCache | curl -s -d &#39;{\\&quot;username\\&quot;:\\&quot;admin\\&quot;,\\&quot;password\\&quot;:\\&quot;secret\\&quot;}&#39; -H \\&quot;Content-Type: application/json\\&quot; -H \\&quot;Accept: application/json\\&quot; -X POST https://ip/user/login | jq --raw-output \\&quot;.info.token\\&quot; }}&quot;,\r\n    &quot;header_2&quot;: null,\r\n    &quot;header_3&quot;: null,\r\n    &quot;clientId&quot;: null,\r\n    &quot;clientSecret&quot;: null,\r\n    &quot;id&quot;: null,\r\n    &quot;accessTokenUri&quot;: null,\r\n    &quot;authorizationScheme&quot;: null,\r\n    &quot;clientAuthenticationScheme&quot;: null,\r\n    &quot;tokenName&quot;: null,\r\n    &quot;scope&quot;: null,\r\n    &quot;grantType&quot;: null,\r\n    &quot;preEstablishedRedirectUri&quot;: null,\r\n    &quot;useCurrentUri&quot;: null,\r\n    &quot;userAuthorizationUri&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;invalid&quot;: true,\r\n    &quot;lastTestedOn&quot;: null,\r\n    &quot;passwordMasked&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;ROLE_USER&quot;,\r\n    &quot;authType&quot;: &quot;Token&quot;,\r\n    &quot;username&quot;: null,\r\n    &quot;password&quot;: &quot;PASSWORD-MASKED&quot;,\r\n    &quot;header_1&quot;: &quot;Authorization: Bearer {{@CmdCache | curl -s -d &#39;{\\&quot;username\\&quot;:\\&quot;admin\\&quot;,\\&quot;password\\&quot;:\\&quot;secret\\&quot;}&#39; -H \\&quot;Content-Type: application/json\\&quot; -H \\&quot;Accept: application/json\\&quot; -X POST https://ip/user/login | jq --raw-output \\&quot;.info.token\\&quot; }}&quot;,\r\n    &quot;header_2&quot;: null,\r\n    &quot;header_3&quot;: null,\r\n    &quot;clientId&quot;: null,\r\n    &quot;clientSecret&quot;: null,\r\n    &quot;id&quot;: null,\r\n    &quot;accessTokenUri&quot;: null,\r\n    &quot;authorizationScheme&quot;: null,\r\n    &quot;clientAuthenticationScheme&quot;: null,\r\n    &quot;tokenName&quot;: null,\r\n    &quot;scope&quot;: null,\r\n    &quot;grantType&quot;: null,\r\n    &quot;preEstablishedRedirectUri&quot;: null,\r\n    &quot;useCurrentUri&quot;: null,\r\n    &quot;userAuthorizationUri&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;invalid&quot;: true,\r\n    &quot;lastTestedOn&quot;: null,\r\n    &quot;passwordMasked&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;ROLE_PM&quot;,\r\n    &quot;authType&quot;: &quot;Token&quot;,\r\n    &quot;username&quot;: null,\r\n    &quot;password&quot;: &quot;PASSWORD-MASKED&quot;,\r\n    &quot;header_1&quot;: &quot;Authorization: Bearer {{@CmdCache | curl -s -d &#39;{\\&quot;username\\&quot;:\\&quot;admin\\&quot;,\\&quot;password\\&quot;:\\&quot;secret\\&quot;}&#39; -H \\&quot;Content-Type: application/json\\&quot; -H \\&quot;Accept: application/json\\&quot; -X POST https://ip/user/login | jq --raw-output \\&quot;.info.token\\&quot; }}&quot;,\r\n    &quot;header_2&quot;: null,\r\n    &quot;header_3&quot;: null,\r\n    &quot;clientId&quot;: null,\r\n    &quot;clientSecret&quot;: null,\r\n    &quot;id&quot;: null,\r\n    &quot;accessTokenUri&quot;: null,\r\n    &quot;authorizationScheme&quot;: null,\r\n    &quot;clientAuthenticationScheme&quot;: null,\r\n    &quot;tokenName&quot;: null,\r\n    &quot;scope&quot;: null,\r\n    &quot;grantType&quot;: null,\r\n    &quot;preEstablishedRedirectUri&quot;: null,\r\n    &quot;useCurrentUri&quot;: null,\r\n    &quot;userAuthorizationUri&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;invalid&quot;: true,\r\n    &quot;lastTestedOn&quot;: null,\r\n    &quot;passwordMasked&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;ROLE_ADMIN&quot;,\r\n    &quot;authType&quot;: &quot;Token&quot;,\r\n    &quot;username&quot;: null,\r\n    &quot;password&quot;: &quot;PASSWORD-MASKED&quot;,\r\n    &quot;header_1&quot;: &quot;Authorization: Bearer {{@CmdCache | curl -s -d &#39;{\\&quot;username\\&quot;:\\&quot;admin\\&quot;,\\&quot;password\\&quot;:\\&quot;secret\\&quot;}&#39; -H \\&quot;Content-Type: application/json\\&quot; -H \\&quot;Accept: application/json\\&quot; -X POST https://ip/user/login | jq --raw-output \\&quot;.info.token\\&quot; }}&quot;,\r\n    &quot;header_2&quot;: null,\r\n    &quot;header_3&quot;: null,\r\n    &quot;clientId&quot;: null,\r\n    &quot;clientSecret&quot;: null,\r\n    &quot;id&quot;: null,\r\n    &quot;accessTokenUri&quot;: null,\r\n    &quot;authorizationScheme&quot;: null,\r\n    &quot;clientAuthenticationScheme&quot;: null,\r\n    &quot;tokenName&quot;: null,\r\n    &quot;scope&quot;: null,\r\n    &quot;grantType&quot;: null,\r\n    &quot;preEstablishedRedirectUri&quot;: null,\r\n    &quot;useCurrentUri&quot;: null,\r\n    &quot;userAuthorizationUri&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;invalid&quot;: true,\r\n    &quot;lastTestedOn&quot;: null,\r\n    &quot;passwordMasked&quot;: true\r\n  }\r\n]\r\n```\r\n\r\nwe need to convert above json data into below single line json data with no spaces like below one.\r\n\r\n```\r\n[{&quot;name&quot;:&quot;Invalid_Auth&quot;,&quot;authType&quot;:&quot;Token&quot;,&quot;username&quot;:null,&quot;password&quot;:&quot;PASSWORD-MASKED&quot;,&quot;header_2&quot;:null,&quot;header_3&quot;:null,&quot;clientId&quot;:null,&quot;clientSecret&quot;:null,&quot;id&quot;:null,&quot;accessTokenUri&quot;:null,&quot;authorizationScheme&quot;:null,&quot;clientAuthenticationScheme&quot;:null,&quot;tokenName&quot;:null,&quot;scope&quot;:null,&quot;grantType&quot;:null,&quot;preEstablishedRedirectUri&quot;:null,&quot;useCurrentUri&quot;:null,&quot;userAuthorizationUri&quot;:null,&quot;inactive&quot;:false,&quot;invalid&quot;:true,&quot;lastTestedOn&quot;:null,&quot;passwordMasked&quot;:true},{&quot;name&quot;:&quot;Invalid_Auth_Empty&quot;,&quot;authType&quot;:&quot;Token&quot;,&quot;username&quot;:null,&quot;password&quot;:&quot;PASSWORD-MASKED&quot;,&quot;header_2&quot;:null,&quot;header_3&quot;:null,&quot;clientId&quot;:null,&quot;clientSecret&quot;:null,&quot;id&quot;:null,&quot;accessTokenUri&quot;:null,&quot;authorizationScheme&quot;:null,&quot;clientAuthenticationScheme&quot;:null,&quot;tokenName&quot;:null,&quot;scope&quot;:null,&quot;grantType&quot;:null,&quot;preEstablishedRedirectUri&quot;:null,&quot;useCurrentUri&quot;:null,&quot;userAuthorizationUri&quot;:null,&quot;inactive&quot;:false,&quot;invalid&quot;:true,&quot;lastTestedOn&quot;:null,&quot;passwordMasked&quot;:true},{&quot;name&quot;:&quot;Invalid_Auth_SQL&quot;,&quot;authType&quot;: &quot;Token&quot;,&quot;username&quot;: null,&quot;password&quot;: &quot;PASSWORD-MASKED&quot;,&quot;header_2&quot;: null,&quot;header_3&quot;: null,&quot;clientId&quot;: null,&quot;clientSecret&quot;: null,&quot;id&quot;: null,&quot;accessTokenUri&quot;: null,&quot;authorizationScheme&quot;: null,&quot;clientAuthenticationScheme&quot;: null,&quot;tokenName&quot;: null,&quot;scope&quot;: null,&quot;grantType&quot;: null,&quot;preEstablishedRedirectUri&quot;: null,&quot;useCurrentUri&quot;: null,&quot;userAuthorizationUri&quot;: null,&quot;inactive&quot;: false,&quot;invalid&quot;: true,&quot;lastTestedOn&quot;: null,&quot;passwordMasked&quot;: true},{&quot;name&quot;: &quot;Default&quot;,&quot;authType&quot;: &quot;Basic&quot;,&quot;username&quot;: &quot;user1@netbanking.io&quot;,&quot;password&quot;: &quot;Welcome@4321&quot;,&quot;header_2&quot;: null,&quot;header_3&quot;: null,&quot;clientId&quot;: null,&quot;clientSecret&quot;: null,&quot;id&quot;: null,&quot;accessTokenUri&quot;: null,&quot;authorizationScheme&quot;: null,&quot;clientAuthenticationScheme&quot;: null,&quot;tokenName&quot;: null,&quot;scope&quot;: null,&quot;grantType&quot;: null,&quot;preEstablishedRedirectUri&quot;: null,&quot;useCurrentUri&quot;: null,&quot;userAuthorizationUri&quot;: null,&quot;inactive&quot;: false,&quot;invalid&quot;: true,&quot;lastTestedOn&quot;: null,&quot;passwordMasked&quot;: true},{&quot;name&quot;: &quot;UserA&quot;,&quot;authType&quot;: &quot;Token&quot;,&quot;username&quot;: null,&quot;password&quot;: &quot;PASSWORD-MASKED&quot;,&quot;header_2&quot;: null,&quot;header_3&quot;: null,&quot;clientId&quot;: null,&quot;clientSecret&quot;: null,&quot;id&quot;: null,&quot;accessTokenUri&quot;: null,&quot;authorizationScheme&quot;: null,&quot;clientAuthenticationScheme&quot;: null,&quot;tokenName&quot;: null,&quot;scope&quot;: null,&quot;grantType&quot;: null,&quot;preEstablishedRedirectUri&quot;: null,&quot;useCurrentUri&quot;: null,&quot;userAuthorizationUri&quot;: null,&quot;inactive&quot;: false,&quot;invalid&quot;: true,&quot;lastTestedOn&quot;: null,&quot;passwordMasked&quot;: true},{&quot;name&quot;: &quot;UserB&quot;,&quot;authType&quot;: &quot;Token&quot;,&quot;username&quot;: null,&quot;password&quot;: &quot;PASSWORD-MASKED&quot;,&quot;header_2&quot;: null,&quot;header_3&quot;: null,&quot;clientId&quot;: null,&quot;clientSecret&quot;: null,&quot;id&quot;: null,&quot;accessTokenUri&quot;: null,&quot;authorizationScheme&quot;: null,&quot;clientAuthenticationScheme&quot;: null,&quot;tokenName&quot;: null,&quot;scope&quot;: null,&quot;grantType&quot;: null,&quot;preEstablishedRedirectUri&quot;: null,&quot;useCurrentUri&quot;: null,&quot;userAuthorizationUri&quot;: null,&quot;inactive&quot;: false,&quot;invalid&quot;: true,&quot;lastTestedOn&quot;: null,&quot;passwordMasked&quot;: true},{&quot;name&quot;: &quot;UserC&quot;,&quot;authType&quot;: &quot;Token&quot;,&quot;username&quot;: null,&quot;password&quot;: &quot;PASSWORD-MASKED&quot;,&quot;header_2&quot;: null,&quot;header_3&quot;: null,&quot;clientId&quot;: null,&quot;clientSecret&quot;: null,&quot;id&quot;: null,&quot;accessTokenUri&quot;: null,&quot;authorizationScheme&quot;: null,&quot;clientAuthenticationScheme&quot;: null,&quot;tokenName&quot;: null,&quot;scope&quot;: null,&quot;grantType&quot;: null,&quot;preEstablishedRedirectUri&quot;: null,&quot;useCurrentUri&quot;: null,&quot;userAuthorizationUri&quot;: null,&quot;inactive&quot;: false,&quot;invalid&quot;: true,&quot;lastTestedOn&quot;: null,&quot;passwordMasked&quot;: true},{&quot;name&quot;: &quot;ROLE_USER&quot;,&quot;authType&quot;: &quot;Token&quot;,&quot;username&quot;: null,&quot;password&quot;: &quot;PASSWORD-MASKED&quot;,&quot;header_2&quot;: null,&quot;header_3&quot;: null,&quot;clientId&quot;: null,&quot;clientSecret&quot;: null,&quot;id&quot;: null,&quot;accessTokenUri&quot;: null,&quot;authorizationScheme&quot;: null,&quot;clientAuthenticationScheme&quot;: null,&quot;tokenName&quot;: null,&quot;scope&quot;: null,&quot;grantType&quot;: null,&quot;preEstablishedRedirectUri&quot;: null,&quot;useCurrentUri&quot;: null,&quot;userAuthorizationUri&quot;: null,&quot;inactive&quot;: false,&quot;invalid&quot;: true,&quot;lastTestedOn&quot;: null,&quot;passwordMasked&quot;: true},{&quot;name&quot;: &quot;ROLE_PM&quot;,&quot;authType&quot;: &quot;Token&quot;,&quot;username&quot;: null,&quot;password&quot;: &quot;PASSWORD-MASKED&quot;,&quot;header_2&quot;: null,&quot;header_3&quot;: null,&quot;clientId&quot;: null,&quot;clientSecret&quot;: null,&quot;id&quot;: null,&quot;accessTokenUri&quot;: null,&quot;authorizationScheme&quot;: null,&quot;clientAuthenticationScheme&quot;: null,&quot;tokenName&quot;: null,&quot;scope&quot;: null,&quot;grantType&quot;: null,&quot;preEstablishedRedirectUri&quot;: null,&quot;useCurrentUri&quot;: null,&quot;userAuthorizationUri&quot;: null,&quot;inactive&quot;: false,&quot;invalid&quot;: true,&quot;lastTestedOn&quot;: null,&quot;passwordMasked&quot;: true},{&quot;name&quot;: &quot;ROLE_ADMIN&quot;,&quot;authType&quot;: &quot;Token&quot;,&quot;username&quot;: null,&quot;password&quot;: &quot;PASSWORD-MASKED&quot;,&quot;header_2&quot;: null,&quot;header_3&quot;: null,&quot;clientId&quot;: null,&quot;clientSecret&quot;: null,&quot;id&quot;: null,&quot;accessTokenUri&quot;: null,&quot;authorizationScheme&quot;: null,&quot;clientAuthenticationScheme&quot;: null,&quot;tokenName&quot;: null,&quot;scope&quot;: null,&quot;grantType&quot;: null,&quot;preEstablishedRedirectUri&quot;: null,&quot;useCurrentUri&quot;: null,&quot;userAuthorizationUri&quot;: null,&quot;inactive&quot;: false,&quot;invalid&quot;: true,&quot;lastTestedOn&quot;: null,&quot;passwordMasked&quot;: true}]\r\n\r\n```\r\n\r\nI tried to convert this using ```tr``` tool with below command\r\n\r\n```\r\n# assuming \r\nmAuth=$(echo &quot;$Auth&quot; | jq -R . | tr -d &#39; &#39;)\r\n```\r\n\r\nBut some fields had spaces between key and values.\r\n\r\nSo how we can convert that json data into single line json data with the sample output shown above using bash scripting?\r\n",
        "link": "https://stackoverflow.com/questions/75310489/how-to-convert-json-data-into-single-string-with-no-spaces-in-between-using-bash",
        "title": "how to convert json data into single string with no spaces in between using bash scripting?"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "terraform",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675286721,
                "post_id": 75313913,
                "comment_id": 132898810,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1675273952,
                "creation_date": 1675273952,
                "answer_id": 75314239,
                "question_id": 75313913,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I wouldn&#39;t recommend using command inside TF datasource. Might be hard to debug. There is a [data_source][1] for EBS snapshots.\r\n\r\nAs for your command inside template, in order to debug it you need to simulate the same environment. E.g. instead of running as is, try to repeat what you have in template, like `bash -c` and so on. Also you can [add output to see the template rendered][2] to see if there are any issues.\r\n\r\n\r\n  [1]: https://registry.terraform.io/providers/hashicorp/aws/latest/docs/data-sources/ebs_snapshot\r\n  [2]: https://stackoverflow.com/questions/37887888/print-terraform-template-rendered-output-in-terminal",
                "title": "Terraform - /usr/local/bin/jq: Argument list too long"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1675324916,
                "last_edit_date": 1675324916,
                "creation_date": 1675277322,
                "answer_id": 75314834,
                "question_id": 75313913,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Scroll to bottom of answer.\r\n\r\n&lt;s&gt;\r\nDon&#39;t provide the value as argument, but via directly standard input:\r\n\r\n```\r\naws ... \\\r\n  | jq -rc &#39;.${top}[] ${next}&#39; \\\r\n  | jq -Rsc &#39;./&quot;\\n&quot;&#39; \\\r\n  | jq -c &#39;.[:-1]&#39;\r\n  | jq -Rc &#39;{output:.}&#39;\r\n```\r\n\r\nNote that you are can probably combine most of the separate jq invocations into a single jq program.\r\n&lt;/s&gt;\r\n\r\n*****\r\n\r\nThis pipeline of jq invocations is a massively, _massively_ overcomplicated non-solution. Why convert back and forth between strings and JSON objects, parsing those strings again, when jq can already process the data directly?\r\n\r\n```\r\naws ... | jq -c &#39;{ output: .Snapshots | map(.SnapshotId) | tostring }&#39;\r\n```\r\n\r\nExample output:\r\n\r\n```json\r\n{&quot;output&quot;:&quot;[\\&quot;snap-cafebabe\\&quot;,\\&quot;snap-deadbeef\\&quot;,\\&quot;snap-0123abcd\\&quot;]&quot;}\r\n```\r\n\r\nIf you have to use variables:\r\n\r\n```\r\ntop=Snapshots\r\nnext=SnapshotId\r\naws ... | jq --arg top &quot;$top&quot; --arg next &quot;$next&quot; -c &#39;{ output: .[$top] | map(.[$next]) | tostring }&#39;\r\n```\r\n\r\nor `.[$top] | map(.[$next]) | tostring | { output: . }` or `.[$top] | map(.[$next]) | { output: tostring }`.\r\n\r\nEven if you want or need to string together multiple `jq` invocations, there&#39;s little sense in consuming raw input (`-R`) and try to parse it, if you already have perfectly structured JSON items in stream form.\r\n\r\nHere is what it would look like if you wanted to do it with multiple steps, but always stay in JSON land (and not play ping pong between structured JSON and unstructured text):\r\n\r\n```\r\ntop=Snapshots\r\nnext=SnapshotId\r\naws ... \\\r\n  | jq --arg top &quot;$top&quot; --arg next &quot;$next&quot; &#39;.[$top][][$next]&#39; \\\r\n  | jq -sc &#39;{ output: tostring }&#39;\r\n```\r\n\r\nor the equivalent:\r\n\r\n```\r\ntop=Snapshots\r\nnext=SnapshotId\r\naws ... \\\r\n  | jq --arg top &quot;$top&quot; --arg next &quot;$next&quot; &#39;.[$top] | map(.[$next])&#39; \\\r\n  | jq -c &#39;{ output: tostring }&#39;\r\n```",
                "title": "Terraform - /usr/local/bin/jq: Argument list too long"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1675324916,
        "creation_date": 1675272106,
        "question_id": 75313913,
        "body_markdown": "This is a variation on a question that&#39;s been asked before.\r\n\r\nI&#39;m using an external data source in Terraform to ask it for a list of volume snapshots in AWS Dublin, and JQ in a templatefile to extract the snapshot ids.\r\n\r\n```\r\ndata &quot;external&quot; &quot;volsnapshot_ids&quot; {\r\n\r\n  program    = [\r\n\r\n    &quot;bash&quot;,\r\n\r\n    &quot;-c&quot;,\r\n\r\n    templatefile(&quot;cli.tftpl&quot;, {input_string = &quot;aws ec2 describe-snapshots --region=eu-west-1&quot;, top = &quot;Snapshots&quot;, next = &quot;| .SnapshotId&quot;})]\r\n\r\n}\r\n```\r\nAnd it uses this templatefile:\r\n```\r\n#!/bin/bash\r\n\r\nset -e\r\n\r\nOUTPUT=$(${input_string} | jq  -r -c &#39;.${top}[] ${next}&#39; | jq -R -s -c &#39;split(&quot;\\n&quot;)&#39; | jq &#39;.[:-1]&#39;)\r\n\r\njq -n -c --arg output &quot;$OUTPUT&quot; &#39;{&quot;output&quot;:$output}&#39;\r\n```\r\nThe basic CLI command with JQ works and looks like this:\r\n```\r\naws ec2 describe-snapshots --region=eu-west-1 | jq  -r -c &#39;.Snapshots[] | .SnapshotId&#39; | jq -R -s -c &#39;split(&quot;\\n&quot;)&#39; | jq &#39;.[:-1]&#39; | wc -l\r\n```\r\nIt returns a lot of snapshot ids.\r\n\r\nWhen I run it through Terraform though, it errors:\r\n\r\n```\r\nError: External Program Execution Failed\r\n\r\n│ \r\n\r\n│   with data.external.volsnapshot_ids,\r\n\r\n│   on data.tf line 304, in data &quot;external&quot; &quot;volsnapshot_ids&quot;:\r\n\r\n│  304:   program    = [\r\n\r\n│  305:     &quot;bash&quot;,\r\n\r\n│  306:     &quot;-c&quot;, \r\n\r\n│  307:     templatefile(&quot;cli.tftpl&quot;, {input_string = &quot;aws ec2 describe-snapshots --region=eu-west-1&quot;, top = &quot;Snapshots&quot;, next = &quot;| .SnapshotId&quot;})]\r\n\r\n│ \r\n\r\n│ The data source received an unexpected error while attempting to execute\r\n\r\n│ the program.\r\n\r\n│ \r\n\r\n│ Program: /bin/bash\r\n\r\n│ Error Message: bash: line 6: /usr/local/bin/jq: Argument list too long\r\n\r\n│ \r\n\r\n│ State: exit status 1\r\n```\r\nI think it&#39;s the size of the dataset being returned because it works in regions with less snapshot ids - London works.\r\n\r\nSizewise, here&#39;s London:\r\n\r\n```\r\naws ec2 describe-snapshots --region=eu-west-2 | jq  -r -c &#39;.Snapshots[] | .SnapshotId&#39; | jq -R -s -c &#39;split(&quot;\\n&quot;)&#39; | jq &#39;.[:-1]&#39; | wc -l\r\n20000\r\n```\r\n\r\nAnd here&#39;s Dublin:\r\n\r\n```\r\naws ec2 describe-snapshots --region=eu-west-1 | jq  -r -c &#39;.Snapshots[] | .SnapshotId&#39; | jq -R -s -c &#39;split(&quot;\\n&quot;)&#39; | jq &#39;.[:-1]&#39; | wc -l\r\n42500\r\n```\r\n\r\nIs there a way to fix up the JQ in my templatefile so it can handle big JSON files?",
        "link": "https://stackoverflow.com/questions/75313913/terraform-usr-local-bin-jq-argument-list-too-long",
        "title": "Terraform - /usr/local/bin/jq: Argument list too long"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1675287424,
                "post_id": 75314344,
                "comment_id": 132898988,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1675283756,
                "last_edit_date": 1675283756,
                "creation_date": 1675274755,
                "answer_id": 75314385,
                "question_id": 75314344,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of mapping into an array, and then iterating over it (`map(…)[]`) just create an array and collect its items (`[…]`). Also, you can get rid of the variable binding (`as`) by moving the second part into its own context using parens.\r\n\r\n```sh\r\njq -r &#39;[.key] + (.source_records[] | [.]) | @tsv&#39;\r\n```\r\n\r\n---\r\nAlternatively, instead of using `@tsv` you could build your tab-separated output string yourself. Either by concatenation (`… + …`) or by string interpolation (`&quot;\\(…)&quot;`):\r\n```sh\r\njq -r &#39;.key + &quot;\\t&quot; + .source_records[]&#39;\r\n```\r\n```sh\r\njq -r &#39;&quot;\\(.key)\\t\\(.source_records[])&quot;&#39;\r\n```\r\n\r\n---\r\nOutput:\r\n```\r\n/books/OL1000072M\tia:daywithtroubadou00pern\r\n/books/OL1000072M\tbwb:9780822519157\r\n/books/OL1000072M\tmarc:marc_loc_2016/BooksAll.2016.part25.utf8:103836014:1267\r\n```\r\n",
                "title": "Can this jq map be simplified?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1675291278,
                "creation_date": 1675291278,
                "answer_id": 75316960,
                "question_id": 75314344,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not much shorter, but I think it&#39;s clearer than the original and clearer than the other shorter answers.\r\n\r\n```sh\r\njq -r &#39;.key as $olid | .source_records[] | [ $olid, . ] | @tsv&#39;\r\n```",
                "title": "Can this jq map be simplified?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1675291278,
        "creation_date": 1675274534,
        "question_id": 75314344,
        "body_markdown": "Given this JSON:\r\n\r\n    {\r\n      &quot;key&quot;: &quot;/books/OL1000072M&quot;,\r\n      &quot;source_records&quot;: [\r\n        &quot;ia:daywithtroubadou00pern&quot;,\r\n        &quot;bwb:9780822519157&quot;,\r\n        &quot;marc:marc_loc_2016/BooksAll.2016.part25.utf8:103836014:1267&quot;\r\n      ]\r\n    }\r\n\r\nCan the following `jq` code be simplified? \r\n\r\n    jq -r &#39;.key as $olid | .source_records | map([$olid, .])[] | @tsv&#39;\r\n\r\nThe use of variable assignment feels like cheating and I&#39;m wondering if it can be eliminated. The goal is to map the `key` value onto each of the `source_records` values and output a two column TSV.\r\n",
        "link": "https://stackoverflow.com/questions/75314344/can-this-jq-map-be-simplified",
        "title": "Can this jq map be simplified?"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1675334615,
                "last_edit_date": 1675334615,
                "creation_date": 1675325499,
                "answer_id": 75320249,
                "question_id": 75320078,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s because you are not quoting your variable when expanding:\r\n\r\n```\r\njq &#39;map(select(.name == &quot;testtoken1&quot;) |= (.header_1 = &quot;&#39;${auth}&#39;&quot; ))&#39;\r\n```\r\n\r\nshould be\r\n\r\n```\r\njq &#39;map(select(.name == &quot;testtoken1&quot;) |= (.header_1 = &quot;&#39;&quot;${auth}&quot;&#39;&quot; ))&#39;\r\n```\r\n\r\nBut you shouldn&#39;t be interpolating the jq program/filter with shell variables in the first place. Define a jq variable instead and don&#39;t worry about messing up your jq filter:\r\n\r\n```\r\njq --arg auth &quot;$auth&quot; &#39;map(select(.name == &quot;testtoken1&quot;) |= (.header_1 = $auth))&#39;\r\n```",
                "title": "How to make curl/jq treat a string with spaces characters as single string?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1675334615,
        "creation_date": 1675324341,
        "question_id": 75320078,
        "body_markdown": "How do we make curl/jq treat a string with spaces characters as a single string?\r\n\r\nI have JSON data in a variable\r\n\r\n```\r\nauthArray=[\r\n  {\r\n    &quot;name&quot;: &quot;testtoken1&quot;,\r\n    &quot;authType&quot;: &quot;Token&quot;,\r\n    &quot;username&quot;: null,\r\n    &quot;password&quot;: &quot;PASSWORD-MASKED&quot;,\r\n    &quot;header_1&quot;: &quot;Authorization: Bearer {{@CmdCache | curl -s -d &#39;{username: admin@qtech.ai, password: admin5665}&#39; -H Content-Type:application/json -H Accept:application/json -X POST https://dev.qtech.ai/login | jq --raw-output .token}}&quot;,\r\n    &quot;header_2&quot;: null,\r\n    &quot;header_3&quot;: null,\r\n    &quot;clientId&quot;: null,\r\n    &quot;clientSecret&quot;: null,\r\n    &quot;id&quot;: null,\r\n    &quot;accessTokenUri&quot;: null,\r\n    &quot;authorizationScheme&quot;: null,\r\n    &quot;clientAuthenticationScheme&quot;: null,\r\n    &quot;tokenName&quot;: null,\r\n    &quot;scope&quot;: null,\r\n    &quot;grantType&quot;: null,\r\n    &quot;preEstablishedRedirectUri&quot;: null,\r\n    &quot;useCurrentUri&quot;: null,\r\n    &quot;userAuthorizationUri&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;invalid&quot;: false,\r\n    &quot;lastTestedOn&quot;: null,\r\n    &quot;passwordMasked&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Invalid_Auth&quot;,\r\n    &quot;authType&quot;: &quot;Token&quot;,\r\n    &quot;username&quot;: null,\r\n    &quot;password&quot;: &quot;PASSWORD-MASKED&quot;,\r\n    &quot;header_1&quot;: &quot;Authorization:BearereyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c&quot;,\r\n    &quot;header_2&quot;: null,\r\n    &quot;header_3&quot;: null,\r\n    &quot;clientId&quot;: null,\r\n    &quot;clientSecret&quot;: null,\r\n    &quot;id&quot;: null,\r\n    &quot;accessTokenUri&quot;: null,\r\n    &quot;authorizationScheme&quot;: null,\r\n    &quot;clientAuthenticationScheme&quot;: null,\r\n    &quot;tokenName&quot;: null,\r\n    &quot;scope&quot;: null,\r\n    &quot;grantType&quot;: null,\r\n    &quot;preEstablishedRedirectUri&quot;: null,\r\n    &quot;useCurrentUri&quot;: null,\r\n    &quot;userAuthorizationUri&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;invalid&quot;: true,\r\n    &quot;lastTestedOn&quot;: null,\r\n    &quot;passwordMasked&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Invalid_Auth_Empty&quot;,\r\n    &quot;authType&quot;: &quot;Token&quot;,\r\n    &quot;username&quot;: null,\r\n    &quot;password&quot;: &quot;PASSWORD-MASKED&quot;,\r\n    &quot;header_1&quot;: &quot;Authorization:Bearer&quot;,\r\n    &quot;header_2&quot;: null,\r\n    &quot;header_3&quot;: null,\r\n    &quot;clientId&quot;: null,\r\n    &quot;clientSecret&quot;: null,\r\n    &quot;id&quot;: null,\r\n    &quot;accessTokenUri&quot;: null,\r\n    &quot;authorizationScheme&quot;: null,\r\n    &quot;clientAuthenticationScheme&quot;: null,\r\n    &quot;tokenName&quot;: null,\r\n    &quot;scope&quot;: null,\r\n    &quot;grantType&quot;: null,\r\n    &quot;preEstablishedRedirectUri&quot;: null,\r\n    &quot;useCurrentUri&quot;: null,\r\n    &quot;userAuthorizationUri&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;invalid&quot;: true,\r\n    &quot;lastTestedOn&quot;: null,\r\n    &quot;passwordMasked&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Invalid_Auth_SQL&quot;,\r\n    &quot;authType&quot;: &quot;Token&quot;,\r\n    &quot;username&quot;: null,\r\n    &quot;password&quot;: &quot;PASSWORD-MASKED&quot;,\r\n    &quot;header_1&quot;: &quot;Authorization:Bearer{{@Injection}}&quot;,\r\n    &quot;header_2&quot;: null,\r\n    &quot;header_3&quot;: null,\r\n    &quot;clientId&quot;: null,\r\n    &quot;clientSecret&quot;: null,\r\n    &quot;id&quot;: null,\r\n    &quot;accessTokenUri&quot;: null,\r\n    &quot;authorizationScheme&quot;: null,\r\n    &quot;clientAuthenticationScheme&quot;: null,\r\n    &quot;tokenName&quot;: null,\r\n    &quot;scope&quot;: null,\r\n    &quot;grantType&quot;: null,\r\n    &quot;preEstablishedRedirectUri&quot;: null,\r\n    &quot;useCurrentUri&quot;: null,\r\n    &quot;userAuthorizationUri&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;invalid&quot;: true,\r\n    &quot;lastTestedOn&quot;: null,\r\n    &quot;passwordMasked&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Default&quot;,\r\n    &quot;authType&quot;: &quot;Basic&quot;,\r\n    &quot;username&quot;: &quot;changeme@apisec.ai&quot;,\r\n    &quot;password&quot;: &quot;PASSWORD-MASKED&quot;,\r\n    &quot;header_1&quot;: null,\r\n    &quot;header_2&quot;: null,\r\n    &quot;header_3&quot;: null,\r\n    &quot;clientId&quot;: null,\r\n    &quot;clientSecret&quot;: null,\r\n    &quot;id&quot;: null,\r\n    &quot;accessTokenUri&quot;: null,\r\n    &quot;authorizationScheme&quot;: null,\r\n    &quot;clientAuthenticationScheme&quot;: null,\r\n    &quot;tokenName&quot;: null,\r\n    &quot;scope&quot;: null,\r\n    &quot;grantType&quot;: null,\r\n    &quot;preEstablishedRedirectUri&quot;: null,\r\n    &quot;useCurrentUri&quot;: null,\r\n    &quot;userAuthorizationUri&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;invalid&quot;: false,\r\n    &quot;lastTestedOn&quot;: null,\r\n    &quot;passwordMasked&quot;: true\r\n  }\r\n]\r\n\r\n```\r\n\r\nI am trying to update 1st object named testtoken1&#39;s &#39;header_1&#39; field in that array with the below dynamically updated string with code given as well\r\n\r\n```\r\nauth=&#39;&quot;Authorization: Bearer {{@CmdCache | curl -s -d &#39;{&quot;username&quot;:&quot;jackie@xxxx.com&quot;,&quot;password&quot;:&quot;Welcome123&quot;}&#39; -H &#39;&quot;Content-Type: application/json&quot;&#39; -H &#39;&quot;Accept: application/json&quot;&#39; -X POST &#39;&quot;https://dev.qtech.ai/login&quot;&#39; | jq --raw-output &#39;&quot;.token&quot;&#39; }}&quot;&#39;\r\n\r\nmAuth=$(echo $authArray | jq &#39;map(select(.name == &quot;testtoken1&quot;) |= (.header_1 = &quot;&#39;${auth}&#39;&quot; ))&#39; | jq -c . )\r\n```\r\nWhen I execute the above code, I&#39;m getting below jq error message\r\n```\r\njq: Unknown option -d\r\nUse jq --help for help with command-line options,\r\nor see the jq manpage, or online docs  at https://stedolan.github.io/jq\r\n```\r\nIt&#39;s throwing error because of space characters in that ```auth``` variable, if I remove those spaces characters from that variable it&#39;s working perfectly.\r\n\r\n\r\n\r\nAbove commands output needs to used with below code eventually.\r\n```\r\nudto=$(echo $(_jq &#39;.&#39;) | jq &#39;.auths = &#39;${mAuth}&#39;&#39;)\r\ncurl -s --location --request PUT &quot;${HOST}/api/v1/projects/$PROJECT_ID/env/$eId&quot; --header &quot;Accept: application/json&quot; --header &quot;Content-Type: application/json&quot; --header &quot;Authorization: Bearer &quot;$token&quot;&quot; -d &quot;$udto&quot;\r\n```\r\n\r\nBut our use case is as such, we want to put ```auth``` variable as it is so that we don&#39;t have to make/add space characters back again from the UI of the app and when we run that command from UI by pressing Run button which we will execute that curl structure/syntax command in the background.\r\n\r\n\r\n\r\nSo, how can we make/pass that variable as it is along with space characters using curl, jq, and bash shell scripting?",
        "link": "https://stackoverflow.com/questions/75320078/how-to-make-curl-jq-treat-a-string-with-spaces-characters-as-single-string",
        "title": "How to make curl/jq treat a string with spaces characters as single string?"
    },
    {
        "tags": [
            "json",
            "bash",
            "aes",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1675325594,
                "post_id": 75320082,
                "comment_id": 132905460,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675329851,
                "post_id": 75320082,
                "comment_id": 132906656,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24496046,
                    "reputation": 41,
                    "user_id": 18412305,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14Gg7k1WGAC7TiSQaNcF9dGYKYZnVFkfUZ8vMxQFohQ=k-s256",
                    "display_name": "Akira_Yam",
                    "link": "https://stackoverflow.com/users/18412305/akira-yam"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675351261,
                "post_id": 75320082,
                "comment_id": 132914292,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675351920,
                "post_id": 75320082,
                "comment_id": 132914566,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675355310,
                "post_id": 75320082,
                "comment_id": 132915734,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24496046,
                    "reputation": 41,
                    "user_id": 18412305,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14Gg7k1WGAC7TiSQaNcF9dGYKYZnVFkfUZ8vMxQFohQ=k-s256",
                    "display_name": "Akira_Yam",
                    "link": "https://stackoverflow.com/users/18412305/akira-yam"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675459374,
                "post_id": 75320082,
                "comment_id": 132941264,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1675351553,
        "creation_date": 1675324362,
        "last_edit_date": 1675351553,
        "question_id": 75320082,
        "body_markdown": "This is a two part process of which the goal is to take a target file and the contents of a folder and outputs a Json-formatted template store and encrypts them with AES-256. The script I am having a problem with is just the opposite.Its purpose is to take the encrypted AES-256 file, decrypt it, then take the resulting Json and break it out into the original files and text file stored within. For some reason I am getting this error though:\r\n\r\n    jq: error (at &lt;stdin&gt;:7): Cannot index string with string &quot;files&quot;\r\n\r\n**The original bash script used to store in Json-formatted template store, and encrypt in AES-256:**\r\n\r\n    #!/bin/bash\r\n    #Note: This script will require an installation of jq to operate correctly\r\n    # Check whether the user has provided correct inputs\r\n    if [ &quot;$1&quot; = &quot;&quot; ] || [ &quot;$2&quot; = &quot;&quot; ]; then\r\n            echo &quot;Error – Please pass two parameters: a specific text document and the contents of a folder as inputs to the script&quot;\r\n            exit 1\r\n    fi\r\n    \r\n    # Set source text document and folder name\r\n    TEXT_DOC=&quot;$1&quot;\r\n    FOLDER=&quot;$2&quot;\r\n    \r\n    # Create an empty JSON-formatted template store\r\n    echo &quot;{}&quot; &gt; template.json\r\n    \r\n    # Read text document into array\r\n    IFS=$&#39;\\n&#39;\r\n    text=(&quot;$(&lt;$TEXT_DOC)&quot;)\r\n    \r\n    # Loop through text document and populate template array\r\n    for var in &quot;${text[@]}&quot;; do\r\n        key=$(echo &quot;$var&quot; | cut -f1 -d&quot;;&quot;)\r\n        value=$(echo &quot;$var&quot; | cut -f2 -d&quot;;&quot;)\r\n        jq --arg key &quot;$key&quot; --arg value &quot;$value&quot; &#39;. + {($key): ($value)}&#39; template.json &gt; template_temp.json\r\n        mv template_temp.json template.json\r\n    done\r\n    \r\n    # Loop through folder and add it&#39;s contents to the template array\r\n    for FILE in `find $FOLDER -type f`; do\r\n        content=$(&lt;$FILE)\r\n        filename=$(echo &quot;$FILE&quot; | cut -f2 -d&quot;/&quot;)\r\n        jq --arg filename &quot;$filename&quot; --arg content &quot;$content&quot; &#39;. + {($filename): ($content)}&#39; template.json &gt; template_temp.json\r\n        mv template_temp.json template.json\r\n    done\r\n    \r\n    # Encrypt the template array with AES-256\r\n    openssl aes-256-cbc -a -salt -pbkdf2 -in template.json -out &quot;${FOLDER%?}.enc&quot;\r\n    \r\n    # Remove plain text template array\r\n    rm template.json\r\n    \r\n    echo &quot;JSON-formatted template store successfully encrypted with AES-256&quot;\r\n\r\n**The troublesome script that is supposed to reverse the process:**\r\n\r\n    #!/bin/bash\r\n    set -x\r\n    # This script will decrypt the given AES-256 encrypted file and output the contained files into the given Output_folder directory\r\n    \r\n    # Read the encrypted file and store it in a variable\r\n    fileToDecrypt=&quot;$1&quot;\r\n    outputDir=&quot;Output_folder&quot;\r\n    \r\n    # Create the output directory if it does not exist\r\n    if [ ! -d &quot;$outputDir&quot; ]\r\n    then\r\n        mkdir $outputDir\r\n    fi\r\n    \r\n    # Decrypt the given encrypted file and save the content in the output directory\r\n    openssl aes-256-cbc -d -a -pbkdf2 -in $fileToDecrypt -out &quot;$outputDir/decrypted_file.json&quot;\r\n    \r\n    # Extract each file stored in the decrypted json content and save it to output directory\r\n    cat &quot;$outputDir/decrypted_file.json&quot; | jq -r &#39;.[] | .files[] | &quot;\\(.name)&quot;&#39; | while read file ; do\r\n        echo &quot;Extracting decrypted_file.json to directory $outputDir&quot;\r\n        cp &quot;$file&quot; &quot;$outputDir&quot;\r\n    done\r\n\r\nI believe that the script is successfully unencrypting it from the AES-256 format and is getting hung up on the jq command.\r\n\r\n**The resulting Json after decrypting:**\r\n\r\n    {\r\n      &quot;fake yaml file\\r&quot;: &quot;fake yaml file\\r&quot;,\r\n      &quot;Fakefile1.txt&quot;: &quot;Fakecontents1=stuff1\\r\\nFakecontents2=stuff2\\r\\nFakecontents3=stuff3\\r\\nFakecontents4\\r\\nFakecontents5\\r\\nFakecontents6&quot;,\r\n      &quot;Fakefile2.txt&quot;: &quot;Fakecontents1=stuff1\\r\\nFakecontents2=stuff2\\r\\nFakecontents3=stuff3\\r\\nFakecontents4\\r\\nFakecontents5\\r\\nFakecontents6&quot;,\r\n      &quot;Fakefile3.txt&quot;: &quot;Fakecontents1=stuff1\\r\\nFakecontents2=stuff2\\r\\nFakecontents3=stuff3\\r\\nFakecontents4\\r\\nFakecontents5\\r\\nFakecontents6&quot;,\r\n      &quot;Fakefile4.txt&quot;: &quot;Fakecontents1=stuff1\\r\\nFakecontents2=stuff2\\r\\nFakecontents3=stuff3\\r\\nFakecontents4\\r\\nFakecontents5\\r\\nFakecontents6&quot;\r\n    }\r\n\r\n**The Expected File Structure:**\r\n\r\n    ├── Output_folder\r\n    |   └──azure-pipelines.yaml\r\n    |   └── Config-Store\r\n    │&#160;   &#160; └── Fakefile1.txt\r\n    │&#160;   &#160; └── Fakefile2.txt\r\n    │   &#160;&#160; └── Fakefile3.txt\r\n    │&#160;   &#160; └── Fakefile4.txt\r\n\r\nOf course the input files were only dummy files for testing purposes. Does anyone have any idea what I am doing wrong? Note: I am running these scripts using Ubuntu 20.04 on Windows. ",
        "link": "https://stackoverflow.com/questions/75320082/getting-error-jq-error-at-stdin7-cannot-index-string-with-string-files",
        "title": "Getting Error jq: error (at &lt;stdin&gt;:7): Cannot index string with string &quot;files&quot;"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1675367434,
                "post_id": 75328040,
                "comment_id": 132919568,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1489588,
                    "reputation": 1666,
                    "user_id": 1397021,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/0adef4eba6f9d237fc3965076a604366?s=256&d=identicon&r=PG",
                    "display_name": "Abhishek Chandran",
                    "link": "https://stackoverflow.com/users/1397021/abhishek-chandran"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675369177,
                "post_id": 75328040,
                "comment_id": 132920022,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675369469,
                "post_id": 75328040,
                "comment_id": 132920094,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1489588,
                    "reputation": 1666,
                    "user_id": 1397021,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/0adef4eba6f9d237fc3965076a604366?s=256&d=identicon&r=PG",
                    "display_name": "Abhishek Chandran",
                    "link": "https://stackoverflow.com/users/1397021/abhishek-chandran"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675369765,
                "post_id": 75328040,
                "comment_id": 132920187,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1675369812,
                "post_id": 75328040,
                "comment_id": 132920206,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1489588,
                    "reputation": 1666,
                    "user_id": 1397021,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/0adef4eba6f9d237fc3965076a604366?s=256&d=identicon&r=PG",
                    "display_name": "Abhishek Chandran",
                    "link": "https://stackoverflow.com/users/1397021/abhishek-chandran"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675370455,
                "post_id": 75328040,
                "comment_id": 132920375,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1489588,
                    "reputation": 1666,
                    "user_id": 1397021,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/0adef4eba6f9d237fc3965076a604366?s=256&d=identicon&r=PG",
                    "display_name": "Abhishek Chandran",
                    "link": "https://stackoverflow.com/users/1397021/abhishek-chandran"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675376238,
                "post_id": 75328040,
                "comment_id": 132921773,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1675370613,
                "last_edit_date": 1675370613,
                "creation_date": 1675367154,
                "answer_id": 75328237,
                "question_id": 75328040,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[Note: this response was made to the original question, which has since been changed.  The response essentially assumes the input consists of JSONLines interspersed with other lines.)\r\n\r\nSince the goal seems to be to ignore lines that don&#39;t have valid key-value pairs, you can simply use `catch empty`:\r\n```\r\nwhile read -r line ; do \r\n    echo export &quot;$line&quot;\r\ndone &lt; &lt;(test.json jq -r -R  &#39;\r\n  try fromjson catch empty\r\n  | objects\r\n  | to_entries[]\r\n  | &quot;\\(.key)=\\&quot;\\(.value|@sh)\\&quot;&quot; \r\n&#39;)\r\n\r\n```\r\nNote also the use of `@sh` and of the shell&#39;s `read`, and the fact that `.value` (in jq) and `$line` (in the shell) are both quoted. These are all important for robustness, though further refinements might still be necessary for additional robustness.\r\n\r\n",
                "title": "Bash: Ignore key value pairs from a JSON that failed to parse using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1675372913,
                "last_edit_date": 1675372913,
                "creation_date": 1675370486,
                "answer_id": 75328707,
                "question_id": 75328040,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a response to the revised question.  Unfortunately, it will only be useful in certain limited cases, not including the example you give.  (Basically, it depends on jq&#39;s parser being able to recover before the end of file.)\r\n```\r\nwhile read -r line ; do \r\n    echo export &quot;$line&quot;\r\ndone &lt; &lt;(&lt; test.json jq -rn &#39;\r\n  def do:\r\n    try inputs catch null\r\n    | objects\r\n    | to_entries[]\r\n    | &quot;\\(.key)=\\&quot;\\(.value|@sh)\\&quot;&quot; ;\r\n  recurse(do) | select(.)\r\n&#39;)\r\n```\r\n\r\nNote that further refinements may be warranted, especially if there is potentially something fishy about the key names being used as shell variable names.\r\n",
                "title": "Bash: Ignore key value pairs from a JSON that failed to parse using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1675375376,
                "creation_date": 1675375376,
                "answer_id": 75329407,
                "question_id": 75328040,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Perhaps there is an algorithm that will repair the broken JSON produced by the upstream system.  If not, the following is a horrible but possibly useful &quot;hack&quot; that will at least capture KEY1 and KEY2 in the example in the Q:\r\n```\r\njq -Rr &#39;\r\n   capture(&quot;\\&quot;(?&lt;key&gt;[^\\&quot;]*)\\&quot;[ \\t]*:[ \\t]*(?&lt;value&gt;[^}]+)&quot;) \r\n   | (.value |= sub(&quot;[ \\t]+$&quot;; &quot;&quot;) )  # trailing whitespace\r\n   | if .value|test(&quot;^\\&quot;.*\\&quot;&quot;) then .value |= sub(&quot;\\&quot;[ \\t]*[,}[ \\t]*$&quot;; &quot;\\&quot;&quot;) else . end\r\n   | select(.value | test(&quot;^\\&quot;.*\\&quot;$&quot;) or (contains(&quot;\\&quot;&quot;)|not) )  # a string or not a string\r\n   | &quot;\\(.key)=\\(.value|@sh)&quot; \r\n&#39;\r\n```",
                "title": "Bash: Ignore key value pairs from a JSON that failed to parse using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1675375699,
                "creation_date": 1675375699,
                "answer_id": 75329459,
                "question_id": 75328040,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The broken JSON in the example could be repaired in a number of ways, e.g.:\r\n\r\n\r\n    sed &#39;/\\\\n$/{N; s/\\\\n\\n/\\\\n/;}&#39;\r\n\r\nproduces:\r\n```\r\n{\r\n &quot;KEY1&quot;:&quot;ABC&quot;,\r\n &quot;KEY2&quot;:&quot;XYZ&quot;,\r\n &quot;KEY3&quot;:&quot;---ABC---\\ndskfjlksfj&quot;\r\n\r\n}\r\n```\r\nAt least that&#39;s JSON :-)",
                "title": "Bash: Ignore key value pairs from a JSON that failed to parse using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1675375699,
        "creation_date": 1675365790,
        "last_edit_date": 1675369132,
        "question_id": 75328040,
        "body_markdown": "I&#39;m writing a bash script to read a JSON file and export the key-value pairs as environment variables. Though I could extract the key-value pairs, I&#39;m struggling to skip those entries that failed to parse by `jq`. \r\n\r\nJSON (key3 should fail to parse)\r\n```\r\n{\r\n &quot;KEY1&quot;:&quot;ABC&quot;,\r\n &quot;KEY2&quot;:&quot;XYZ&quot;,\r\n &quot;KEY3&quot;:&quot;---ABC---\\n\r\ndskfjlksfj&quot;\r\n\r\n}\r\n```\r\n\r\nHere is what I tried\r\n```\r\nfor pair in $(cat test.json  | jq -r -R  &#39;. as $line | try fromjson catch $line | to_entries | map(&quot;\\(.key)=\\(.value)&quot;) | .[]&#39; ); do\r\n    echo $pair\r\n    export $pair\r\ndone\r\n```\r\n\r\nAnd this is the error\r\n```\r\njq: error (at &lt;stdin&gt;:1): string (&quot;{&quot;) has no keys\r\njq: error (at &lt;stdin&gt;:2): string (&quot;  \\&quot;key1...) has no keys\r\n\r\n```\r\n\r\nMy code is based on these posts:\r\n 1. https://stackoverflow.com/questions/25378013/how-to-convert-a-json-object-to-key-value-format-in-jq\r\n 2. https://stackoverflow.com/questions/69333650/how-to-ignore-broken-json-line-in-jq\r\n 3. https://stackoverflow.com/questions/41599314/ignore-unparseable-json-with-jq\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75328040/bash-ignore-key-value-pairs-from-a-json-that-failed-to-parse-using-jq",
        "title": "Bash: Ignore key value pairs from a JSON that failed to parse using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1675422910,
                "creation_date": 1675422910,
                "answer_id": 75334922,
                "question_id": 75334848,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "you can use the following JQ expression:\r\n\r\n    jq &#39;to_entries[] | select(.key | test(&quot;.*foo.*|.*bar.*&quot;)) | .value[] | .id&#39;\r\n\r\n\r\n[JQ playground example][1]\r\n\r\n\r\n  [1]: https://www.devtoolsdaily.com/jq_playground/?#%7B%22inputText%22%3A%22%7B%5Cn%20%20%5C%22key-foo-1.0%5C%22%3A%20%5B%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22key1%5C%22%3A%20%5C%22foo%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22key2%5C%22%3A%20%5C%22bar%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22id%5C%22%3A%20%5C%2201%5C%22%5Cn%20%20%20%20%7D%2C%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22key1%5C%22%3A%20%5C%22foo%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22key2%5C%22%3A%20%5C%22bar%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22id%5C%22%3A%20%5C%2223%5C%22%5Cn%20%20%20%20%7D%5Cn%20%20%5D%2C%5Cn%20%20%5C%22key-bar-1.0%5C%22%3A%20%5B%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22key1%5C%22%3A%20%5C%22foo%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22key2%5C%22%3A%20%5C%22bar%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22id%5C%22%3A%20%5C%2245%5C%22%5Cn%20%20%20%20%7D%2C%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22key1%5C%22%3A%20%5C%22foo%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22key2%5C%22%3A%20%5C%22bar%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22id%5C%22%3A%20%5C%2267%5C%22%5Cn%20%20%20%20%7D%5Cn%20%20%5D%2C%5Cn%20%20%5C%22key-baz-1.0%5C%22%3A%20%5B%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22key1%5C%22%3A%20%5C%22foo%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22key2%5C%22%3A%20%5C%22bar%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22id%5C%22%3A%20%5C%2289%5C%22%5Cn%20%20%20%20%7D%5Cn%20%20%5D%5Cn%7D%22%2C%22filterExpr%22%3A%22to_entries%5B%5D%20%7C%20select(.key%20%7C%20test(%5C%22.*foo.*%7C.*bar.*%5C%22))%20%7C%20.value%5B%5D%20%7C%20.id%22%2C%22rawOutput%22%3Afalse%7D",
                "title": "jq - get dict element based on key regex"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1675422972,
                "creation_date": 1675422972,
                "answer_id": 75334933,
                "question_id": 75334848,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could go with:\r\n```sh\r\njq -r &#39;.[keys_unsorted[] | select(test(&quot;.*foo.*|.bar..&quot;))][].id&#39;\r\n```\r\n```\r\n01\r\n23\r\n45\r\n67\r\n```\r\n\r\nThis gathers all keys using `keys_unsorted`, then `select`s those matching the regular expression in `test`. The wrapping `.[…]` descends into them, the following `[]` iterates over the children, and `.id` outputs the values as raw text using the `-r` flag.",
                "title": "jq - get dict element based on key regex"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1675754058,
        "creation_date": 1675422520,
        "last_edit_date": 1675754058,
        "question_id": 75334848,
        "body_markdown": "I&#39;m working with a JSON object having the following structure:\r\n\r\n```\r\n{\r\n  &quot;key-foo-1.0&quot;: [\r\n    {\r\n      &quot;key1&quot;: &quot;foo&quot;,\r\n      &quot;key2&quot;: &quot;bar&quot;,\r\n      &quot;id&quot;: &quot;01&quot;\r\n    },\r\n    {\r\n      &quot;key1&quot;: &quot;foo&quot;,\r\n      &quot;key2&quot;: &quot;bar&quot;,\r\n      &quot;id&quot;: &quot;23&quot;\r\n    }\r\n  ],\r\n  &quot;key-bar-1.0&quot;: [\r\n    {\r\n      &quot;key1&quot;: &quot;foo&quot;,\r\n      &quot;key2&quot;: &quot;bar&quot;,\r\n      &quot;id&quot;: &quot;45&quot;\r\n    },\r\n    {\r\n      &quot;key1&quot;: &quot;foo&quot;,\r\n      &quot;key2&quot;: &quot;bar&quot;,\r\n      &quot;id&quot;: &quot;67&quot;\r\n    }\r\n  ],\r\n  &quot;key-baz-1.0&quot;: [\r\n    {\r\n      &quot;key1&quot;: &quot;foo&quot;,\r\n      &quot;key2&quot;: &quot;bar&quot;,\r\n      &quot;id&quot;: &quot;89&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to get all the `id` values where the &quot;parent&quot; key name matches the pattern `.*foo.*` or `.*bar.*`.\r\n\r\nSo in my example something like this:\r\n\r\n```\r\ncat json | jq &lt;some filter&gt; \r\n01\r\n23\r\n45\r\n67\r\n```\r\n\r\nBased on https://unix.stackexchange.com/questions/443884/match-keys-with-regex-in-jq I tried: \r\n```\r\n$ cat json | jq &#39;with_entries(if (.key|test(&quot;.*foo.*$&quot;)) then ( {key: .key, value: .value } ) else empty end )&#39;\r\n{\r\n  &quot;key-foo-1.0&quot;: [\r\n    {\r\n      &quot;key1&quot;: &quot;foo&quot;,\r\n      &quot;key2&quot;: &quot;bar&quot;,\r\n      &quot;id&quot;: &quot;01&quot;\r\n    },\r\n    {\r\n      &quot;key1&quot;: &quot;foo&quot;,\r\n      &quot;key2&quot;: &quot;bar&quot;,\r\n      &quot;id&quot;: &quot;23&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nBut I don&#39;t really know how to continue.\r\n \r\nI also think there is a better/simpler solution.",
        "link": "https://stackoverflow.com/questions/75334848/jq-get-dict-element-based-on-key-regex",
        "title": "jq - get dict element based on key regex"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675441130,
                "post_id": 75337873,
                "comment_id": 132936361,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1675441402,
                "last_edit_date": 1675441402,
                "creation_date": 1675438789,
                "answer_id": 75337972,
                "question_id": 75337873,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to properly format the string you are using in `jq`.\r\n\r\nYou can create the variable in the same way:\r\n\r\n    VAL=&quot;value with spaces&quot; \r\n\r\nAnd using it like this:\r\n\r\n    jq -n --arg myvar &quot;${VAL}&quot; &#39;{key: $myvar}&#39;\r\n    {\r\n      &quot;key&quot;: &quot;value with spaces&quot;\r\n    }",
                "title": "adding a value with jq fails if the value has spaces"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1675441402,
        "creation_date": 1675438288,
        "last_edit_date": 1675438504,
        "question_id": 75337873,
        "body_markdown": "When I try to add a bash string, that contains spaces with jq an error message will be generated. The error doesn&#39;t occur, if there are no spaces.\r\n\r\n\r\n**the code that generates the error**\r\n\r\n```bash\r\nvalue=&quot;value with spaces&quot;\r\necho {} | jq &quot;. +={&quot;key&quot;:&quot;&#39;$value&#39;&quot;}&quot;\r\n```\r\n\r\n*error message*\r\n\r\n`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:\r\n. +={&quot;key&quot;:&quot;value            \r\njq: 1 compile error`\r\n\r\n*expected output*\r\n\r\n`{&quot;key&quot;:&quot;value with spaces&quot;}`\r\n\r\n*note*\r\nwithout spaces in the value bash variable, the command will run just fine",
        "link": "https://stackoverflow.com/questions/75337873/adding-a-value-with-jq-fails-if-the-value-has-spaces",
        "title": "adding a value with jq fails if the value has spaces"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1675448623,
                "creation_date": 1675448623,
                "answer_id": 75339676,
                "question_id": 75339646,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Apply  compact `-c` output:\r\n\r\n    $ jq -c &#39;.array[]&#39; test.json \r\n    [1,2,3]\r\n    [4,5]\r\n    [6,7,8,9]\r\n\r\n\r\n----------\r\nOr if you also need to join array values by space char:\r\n\r\n    $ jq -rc &#39;.array[] | join(&quot; &quot;)&#39; test.json \r\n    1 2 3\r\n    4 5\r\n    6 7 8 9\r\n\r\n\r\n\r\n",
                "title": "Use jq command to display a two dimensional JSON array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1675448623,
        "creation_date": 1675448420,
        "question_id": 75339646,
        "body_markdown": "Is there a simple way to display a 2D JSON array using `jq`, so that each subarray is on its own line?\r\n\r\nE.g. If I have this JSON:\r\n```\r\n{\r\n  &quot;array&quot;: [\r\n    [1, 2, 3],\r\n    [4, 5],\r\n    [6, 7, 8, 9]\r\n  ]\r\n}\r\n```\r\n\r\nI&#39;m trying to use `jq` to print out:\r\n```\r\n1 2 3\r\n4 5\r\n6 7 8 9\r\n```",
        "link": "https://stackoverflow.com/questions/75339646/use-jq-command-to-display-a-two-dimensional-json-array",
        "title": "Use jq command to display a two dimensional JSON array"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1675467407,
                "last_edit_date": 1675467407,
                "creation_date": 1675467025,
                "answer_id": 75341955,
                "question_id": 75341938,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could compile a list of IDs from the second file using `input`, check against it using `IN`, and either use `del` to delete the matching, or `map` to keep those that do `not` match:\r\n```sh\r\njq &#39;\r\n  (input | map(.data.id)) as $del | del(.[] | select(IN(.data.id; $del[])))\r\n&#39; file1.json file2.json\r\n```\r\nor\r\n```sh\r\njq &#39;\r\n  (input | map(.data.id)) as $del | map(select(IN(.data.id; $del[]) | not))\r\n&#39; file1.json file2.json\r\n```\r\n\r\n---\r\nIf you can assert that objects with identical IDs also are identical in their other parts, and you don&#39;t have many items (because it&#39;s costly), you can even just subtract the second file from the first:\r\n```sh\r\njq &#39;. - input&#39; file1.json file2.json\r\n```",
                "title": "delete from one object those entries matching another object based off string id"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1675467407,
        "creation_date": 1675466665,
        "question_id": 75341938,
        "body_markdown": "So, given two files with JSON data from the same source type. The JSON objects look something like:\r\n\r\nfile1:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;data&quot;: {\r\n      &quot;id&quot;: &quot;2&quot;,\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;stuff&quot;: &quot;foo&quot;\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;data&quot;: {\r\n      &quot;id&quot;: &quot;6&quot;,\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;stuff&quot;: &quot;bar&quot;\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;data&quot;: {\r\n      &quot;id&quot;: &quot;61&quot;,\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;stuff&quot;: &quot;baz&quot;\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;data&quot;: {\r\n      &quot;id&quot;: &quot;63&quot;,\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;stuff&quot;: &quot;qux&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nfile2:\r\n```json\r\n[\r\n  {\r\n    &quot;data&quot;: {\r\n      &quot;id&quot;: &quot;61&quot;,\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;stuff&quot;: &quot;baz&quot;\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;data&quot;: {\r\n      &quot;id&quot;: &quot;63&quot;,\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;stuff&quot;: &quot;qux&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nI&#39;m trying to remove objects in the array in the first file with the matching IDs in the second file so that the resultant output would be:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;data&quot;: {\r\n      &quot;id&quot;: &quot;2&quot;,\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;stuff&quot;: &quot;foo&quot;\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;data&quot;: {\r\n      &quot;id&quot;: &quot;6&quot;,\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;stuff&quot;: &quot;bar&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nI&#39;ve tried a bunch of ways to accomplish this, but I haven&#39;t found a proper solution yet.\r\n\r\nA couple of attempts have been various permutations of the following with accompanying errors:\r\n\r\n```bash\r\njq -n --argfile src /var/tmp/w-src.json --argfile dst /var/tmp/w-dst.json &#39;\r\n$dst\r\n| [.data[].id] as $ids\r\n| $src\r\n| .data | map(select(.id | in($ids[])))\r\n\r\njq: error: select/0 is not defined at &lt;top-level&gt;, line 5:\r\n| .data | map($ids | map(select .id == .))                         \r\njq: 1 compile error\r\n```\r\n\r\n```bash\r\njq -n --argfile src /var/tmp/w-src.json --argfile dst /var/tmp/w-dst.json &#39;\r\n$dst\r\n| [.data[].id] as $ids\r\n| $src\r\n| .data[] | select(.id | in($ids[]))\r\n&#39;\r\njq: error (at &lt;unknown&gt;): Cannot check whether string has a string key\r\n```\r\nIdeally it would be super cool to do some kind of operation like:\r\n\r\n```\r\n$src.data[] - $dst.data[]\r\n```\r\n\r\n(kinda Ruby-ish like would be cool) and I admit, I haven&#39;t tried this but I will for kicks and giggles.\r\n\r\nI&#39;m trying not to have to use a function and I want to accomplish this using `jq`. I&#39;m probably not too far off, but I&#39;m at a loss. Any thoughts?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75341938/delete-from-one-object-those-entries-matching-another-object-based-off-string-id",
        "title": "delete from one object those entries matching another object based off string id"
    },
    {
        "tags": [
            "arrays",
            "json",
            "header",
            "jq",
            "tabular"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1675482079,
                "last_edit_date": 1675482079,
                "creation_date": 1675480310,
                "answer_id": 75342700,
                "question_id": 75342618,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input, the following jq program produces the output shown below:\r\n```\r\njq -r &#39;\r\n  def lpad($len): tostring | ($len - length) as $l | (&quot; &quot; * $l)[:$l] + .;\r\n  ([&quot;Names&quot;,&quot;Points&quot;, &quot;House&quot;]\r\n   | ., map(length*&quot;_&quot;)),\r\n  (.[] | (.users[] | [.name, .points]) +  [.house]) \r\n  | map(lpad(8)) | join(&quot;|&quot;)&#39; \r\n```\r\n\r\n```\r\n   Names|  Points|   House\r\n   _____|  ______|   _____\r\n  alfred|      10|     red\r\n   alice|      11|     red\r\n    emma|      33|     red\r\n   Logan|      20|    blue\r\n   Keith|      19|    blue\r\n    Lisa|      18|    blue\r\n   Julia|      45|    blue\r\n```\r\n\r\nFor a tiny bit more generality at the expense of a tiny bit of complexity:\r\n```\r\n  def lpad($len): tostring | ($len - length) as $l | (&quot; &quot; * $l)[:$l] + .;\r\n  def max(s): reduce s as $x (-infinite; if $x &gt; . then $x else . end);\r\n    max(&quot;House&quot;,  .[].house|length) as $hl\r\n  | max(&quot;Points&quot;, .[].users[].points|tostring|length) as $pl\r\n  | max(&quot;Names&quot;,  .[].users[].name|length) as $nl\r\n  | [ (&quot;Names&quot; | lpad($nl)), (&quot;Points&quot; | lpad($pl)), (&quot;House&quot;| lpad($hl))],\r\n    [$nl * &quot;_&quot;, $pl * &quot;_&quot;, $hl * &quot;_&quot;],\r\n    (.[] | ((.users[] | [(.name | lpad($nl)), (.points|lpad($pl))]) +  [.house | lpad($hl)] ))\r\n  | join(&quot;|&quot;)\r\n```\r\nSeason to taste.",
                "title": "jq: How to create output in a tabular format from a JSON array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1675483441,
                "last_edit_date": 1675483441,
                "creation_date": 1675482788,
                "answer_id": 75342831,
                "question_id": 75342618,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If it&#39;s OK to forego some formatting and decorations, this produces a simple table.\r\n```lang-bash\r\n$ jq -r &#39;[&quot;Name&quot;, &quot;Points&quot;, &quot;House&quot;],(.[]|.house as $house|.users[]|[.name, .points, $house])|@tsv&#39; test.json\r\nName\tPoints\tHouse\r\nalfred\t10\tred\r\nalice\t11\tred\r\nemma\t33\tred\r\nLogan\t20\tblue\r\nKeith\t19\tblue\r\nLisa\t18\tblue\r\nJulia\t45\tblue\r\n```\r\nGetting rid of the variable assignment, this outputs the same simple table.\r\n```lang-bash\r\n$ jq -r &#39;[&quot;Name&quot;, &quot;Points&quot;, &quot;House&quot;],(.[]|(.users[]|[.name, .points]) + [.house])|@tsv&#39; test.json\r\n```",
                "title": "jq: How to create output in a tabular format from a JSON array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1675483441,
        "creation_date": 1675478623,
        "last_edit_date": 1675482262,
        "question_id": 75342618,
        "body_markdown": "I have JSON as given below.\r\n\r\n```lang-json\r\n[\r\n   {\r\n      &quot;users&quot;: [\r\n         {\r\n            &quot;name&quot;: &quot;alfred&quot;,\r\n            &quot;points&quot;: 10\r\n         },\r\n         {\r\n            &quot;name&quot;: &quot;alice&quot;,\r\n            &quot;points&quot;: 11\r\n         },\r\n         {\r\n            &quot;name&quot;: &quot;emma&quot;,\r\n            &quot;points&quot;: 33\r\n         }\r\n      ],\r\n      &quot;house&quot;: &quot;red&quot;\r\n   },\r\n   {\r\n      &quot;users&quot;: [\r\n         {\r\n            &quot;name&quot;: &quot;Logan&quot;,\r\n            &quot;points&quot;: 20\r\n         },\r\n         {\r\n            &quot;name&quot;: &quot;Keith&quot;,\r\n            &quot;points&quot;: 19\r\n         },\r\n         {\r\n            &quot;name&quot;: &quot;Lisa&quot;,\r\n            &quot;points&quot;: 18\r\n         },\r\n         {\r\n            &quot;name&quot;: &quot;Julia&quot;,\r\n            &quot;points&quot;: 45\r\n         }\r\n      ],\r\n      &quot;house&quot;: &quot;blue&quot;\r\n   }\r\n]\r\n```\r\n\r\nHow do I create a tabular output as follows? Basically, I need the value of house appear in the corresponding rows.\r\n\r\n\r\nThe desired output table\r\n\r\n    |Name  |  Points|House|\r\n    |alfred|\t10\t|red  |\r\n    |alice |\t11\t|red  |\r\n    |emma  |\t33\t|red  |\r\n    |Logan |\t20\t|blue |\r\n    |Keith |\t19\t|blue |\r\n    |Lisa  |\t18\t|blue |\r\n    |Julia |\t45\t|blue |\r\n\r\nThis is what I tried.\r\n\r\n```lang-bash\r\n% jq &#39;.[]|.users[]| .name&#39; test.json\r\n\r\n&quot;alfred&quot;\r\n&quot;alice&quot;\r\n&quot;emma&quot;\r\n&quot;Logan&quot;\r\n&quot;Keith&quot;\r\n&quot;Lisa&quot;\r\n&quot;Julia&quot;\r\n\r\n% jq &#39;.[]|.users[]| (.name, .points)&#39; test.json\r\n\r\n&quot;alfred&quot;\r\n10\r\n&quot;alice&quot;\r\n11\r\n&quot;emma&quot;\r\n33\r\n&quot;Logan&quot;\r\n20\r\n&quot;Keith&quot;\r\n19\r\n&quot;Lisa&quot;\r\n18\r\n&quot;Julia&quot;\r\n45\r\n```\r\n\r\nThanks in advance",
        "link": "https://stackoverflow.com/questions/75342618/jq-how-to-create-output-in-a-tabular-format-from-a-json-array",
        "title": "jq: How to create output in a tabular format from a JSON array"
    },
    {
        "tags": [
            "json",
            "linux",
            "amazon-web-services",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675575067,
                "post_id": 75350077,
                "comment_id": 132956956,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1675577930,
                "creation_date": 1675577930,
                "answer_id": 75350468,
                "question_id": 75350077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you wish to use jq, you will have to do it in two or three steps.  Each step, however, is very easy.\r\n\r\nThe first step uses jq with the -c option to create a JSONLines file with the JSON objects you want:\r\n```\r\n&lt; input.json jq -c &#39;\r\n  (.Changes | _nwise(830)) as $C   # 830 per problem statement\r\n  | .Changes = $C\r\n&#39; &gt; output.jsonl\r\n```\r\nNext, partition output.jsonl into the files you want.  This can be done in many ways, e.g. using awk, or even the shell&#39;s `read`.\r\n\r\nFinally, if you want the separate files to be &quot;pretty-printed&quot;, you could use jq to do that in the obvious way.\r\n\r\n",
                "title": "Convert a single JSON to multiple jsons by taking one of the key values?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1675588215,
                "last_edit_date": 1675588215,
                "creation_date": 1675587856,
                "answer_id": 75351133,
                "question_id": 75350077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "so even assuming some of the `JSON` &quot;rows&quot; are compacted into 1 line (e.g. equivalent of `jq -c`) while others are pretty-printed in a tree format, then all you need is the right `regex` in `awk` to identify its row delimiter/sep (`&quot;RS&quot;`) :\r\n\r\n    gcat &lt;( printf &#39;%s&#39; &quot;$json_in_1$json_in_1$ajson_in_1&quot; | jq -c      ) \r\n         &lt;( printf &#39;%s\\n%s\\n%s&#39; &quot;$json_in_1&quot; &quot;$json_in_1&quot; &quot;$json_in_1&quot; ) |\r\n\r\n&gt;      {m,g,n}awk &#39;\r\n&gt;      BEGIN { RS = (_ = &quot;[[:space:]]*&quot;) (__ = &quot;[}]&quot;) \\\r\n&gt;                   (_)__ (_)&quot;[]]&quot; (_)__ (FS =  &quot;\\n&quot;) &quot;?&quot;\r\n&gt;             ORS = (_ = &quot;}&quot;)_     (&quot;]&quot;)_ FS\r\n&gt;             OFS = &quot;\\f\\r\\t&quot;\r\n&gt;            _+=_^= __ = (_&lt;_)\r\n&gt;      } { \r\n&gt;          printf(&quot; NR # %d | NF = %d :: %s&gt;&gt;&gt;&gt;%s%s%.*s%s&gt;&gt;&gt;&gt;%s&quot;,\r\n&gt;                   NR, NF, FS, FS, $__, _&lt;NF, FS, ORS, FS, FS) }&#39; \r\n\r\n     NR # 1 | NF = 1 :: \r\n    &gt;&gt;&gt;&gt;\r\n    {&quot;Comment&quot;:&quot;json data&quot;,&quot;Changes&quot;:[{&quot;Action&quot;:&quot;DELETE&quot;,&quot;ResourceRecordSet&quot;:{&quot;Name&quot;:&quot;record4.&quot;,&quot;Type&quot;:&quot;CNAME&quot;,&quot;SetIdentifier&quot;:&quot;record4&quot;,&quot;GeoLocation&quot;:{&quot;CountryCode&quot;:&quot;*&quot;},&quot;TTL&quot;:60,&quot;ResourceRecords&quot;:[{&quot;Value&quot;:&quot;record4-ap-west&quot;}],&quot;HealthCheckId&quot;:&quot;ID&quot;}}]}\r\n    &gt;&gt;&gt;&gt;\r\n     NR # 2 | NF = 1 :: \r\n    &gt;&gt;&gt;&gt;\r\n    {&quot;Comment&quot;:&quot;json data&quot;,&quot;Changes&quot;:[{&quot;Action&quot;:&quot;DELETE&quot;,&quot;ResourceRecordSet&quot;:{&quot;Name&quot;:&quot;record4.&quot;,&quot;Type&quot;:&quot;CNAME&quot;,&quot;SetIdentifier&quot;:&quot;record4&quot;,&quot;GeoLocation&quot;:{&quot;CountryCode&quot;:&quot;*&quot;},&quot;TTL&quot;:60,&quot;ResourceRecords&quot;:[{&quot;Value&quot;:&quot;record4-ap-west&quot;}],&quot;HealthCheckId&quot;:&quot;ID&quot;}}]}\r\n    &gt;&gt;&gt;&gt;\r\n     NR # 3 | NF = 19 :: \r\n    &gt;&gt;&gt;&gt;\r\n    {\r\n        &quot;Comment&quot;:&quot;json data&quot;,\r\n        &quot;Changes&quot;:[\r\n            {\r\n                &quot;Action&quot;:&quot;DELETE&quot;,\r\n                &quot;ResourceRecordSet&quot;:{\r\n                    &quot;Name&quot;:&quot;record4.&quot;,\r\n                    &quot;Type&quot;:&quot;CNAME&quot;,\r\n                    &quot;SetIdentifier&quot;:&quot;record4&quot;,\r\n                    &quot;GeoLocation&quot;:{\r\n                        &quot;CountryCode&quot;:&quot;*&quot;\r\n                    },\r\n                    &quot;TTL&quot;:60,\r\n                    &quot;ResourceRecords&quot;:[\r\n                        {\r\n                            &quot;Value&quot;:&quot;record4-ap-west&quot;\r\n                        }\r\n                    ],\r\n                    &quot;HealthCheckId&quot;:&quot;ID&quot;\r\n    }}]}\r\n    &gt;&gt;&gt;&gt;\r\n     NR # 4 | NF = 19 :: \r\n    &gt;&gt;&gt;&gt;\r\n    {\r\n        &quot;Comment&quot;:&quot;json data&quot;,\r\n        &quot;Changes&quot;:[\r\n            {\r\n                &quot;Action&quot;:&quot;DELETE&quot;,\r\n                &quot;ResourceRecordSet&quot;:{\r\n                    &quot;Name&quot;:&quot;record4.&quot;,\r\n                    &quot;Type&quot;:&quot;CNAME&quot;,\r\n                    &quot;SetIdentifier&quot;:&quot;record4&quot;,\r\n                    &quot;GeoLocation&quot;:{\r\n                        &quot;CountryCode&quot;:&quot;*&quot;\r\n                    },\r\n                    &quot;TTL&quot;:60,\r\n                    &quot;ResourceRecords&quot;:[\r\n                        {\r\n                            &quot;Value&quot;:&quot;record4-ap-west&quot;\r\n                        }\r\n                    ],\r\n                    &quot;HealthCheckId&quot;:&quot;ID&quot;\r\n    }}]}\r\n    &gt;&gt;&gt;&gt;\r\n     NR # 5 | NF = 19 :: \r\n    &gt;&gt;&gt;&gt;\r\n    {\r\n        &quot;Comment&quot;:&quot;json data&quot;,\r\n        &quot;Changes&quot;:[\r\n            {\r\n                &quot;Action&quot;:&quot;DELETE&quot;,\r\n                &quot;ResourceRecordSet&quot;:{\r\n                    &quot;Name&quot;:&quot;record4.&quot;,\r\n                    &quot;Type&quot;:&quot;CNAME&quot;,\r\n                    &quot;SetIdentifier&quot;:&quot;record4&quot;,\r\n                    &quot;GeoLocation&quot;:{\r\n                        &quot;CountryCode&quot;:&quot;*&quot;\r\n                    },\r\n                    &quot;TTL&quot;:60,\r\n                    &quot;ResourceRecords&quot;:[\r\n                        {\r\n                            &quot;Value&quot;:&quot;record4-ap-west&quot;\r\n                        }\r\n                    ],\r\n                    &quot;HealthCheckId&quot;:&quot;ID&quot;\r\n    }}]}\r\n    &gt;&gt;&gt;&gt;\r\n\r\nthen once you&#39;ve been able to isolate individual `&quot;Change Key&quot;` records, then outputing every 830 rows should be relative straight-forward.\r\n\r\nyou can pipe the output of that further downstream to confirm the output is valid `JSON` via :\r\n\r\n&gt;     ... | awk &#39;/^[{]/,/[}][}][]][}]$/&#39; | jq\r\n\r\nas long as the input structure is very well defined, then `awk` can handle `JSON`s just fine instead of needing a dedicated parser.",
                "title": "Convert a single JSON to multiple jsons by taking one of the key values?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1675588215,
        "creation_date": 1675570408,
        "last_edit_date": 1675578111,
        "question_id": 75350077,
        "body_markdown": "**I currently have one json file as follows in terms of formatting:**\r\n\r\n\r\n```\r\n{\r\n    &quot;Comment&quot;:&quot;json data&quot;,\r\n    &quot;Changes&quot;:[\r\n        {\r\n            &quot;Action&quot;:&quot;DELETE&quot;,\r\n            &quot;ResourceRecordSet&quot;:{\r\n                &quot;Name&quot;:&quot;record1&quot;,\r\n                &quot;Type&quot;:&quot;CNAME&quot;,\r\n                &quot;SetIdentifier&quot;:&quot;record1-ap-northeast&quot;,\r\n                &quot;GeoLocation&quot;:{\r\n                    &quot;CountryCode&quot;:&quot;JP&quot;\r\n                },\r\n                &quot;TTL&quot;:60,\r\n                &quot;ResourceRecords&quot;:[\r\n                    {\r\n                        &quot;Value&quot;:&quot;record1&quot;\r\n                    }\r\n                ],\r\n                &quot;HealthCheckId&quot;:&quot;ID&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;Action&quot;:&quot;DELETE&quot;,\r\n            &quot;ResourceRecordSet&quot;:{\r\n                &quot;Name&quot;:&quot;record2&quot;,\r\n                &quot;Type&quot;:&quot;CNAME&quot;,\r\n                &quot;SetIdentifier&quot;:&quot;record2-ap-south&quot;,\r\n                &quot;GeoLocation&quot;:{\r\n                    &quot;CountryCode&quot;:&quot;SG&quot;\r\n                },\r\n                &quot;TTL&quot;:60,\r\n                &quot;ResourceRecords&quot;:[\r\n                    {\r\n                        &quot;Value&quot;:&quot;record2&quot;\r\n                    }\r\n                ],\r\n                &quot;HealthCheckId&quot;:&quot;ID&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;Action&quot;:&quot;DELETE&quot;,\r\n            &quot;ResourceRecordSet&quot;:{\r\n                &quot;Name&quot;:&quot;record3&quot;,\r\n                &quot;Type&quot;:&quot;CNAME&quot;,\r\n                &quot;SetIdentifier&quot;:&quot;record3-ap-west&quot;,\r\n                &quot;GeoLocation&quot;:{\r\n                    &quot;CountryCode&quot;:&quot;IN&quot;\r\n                },\r\n                &quot;TTL&quot;:60,\r\n                &quot;ResourceRecords&quot;:[\r\n                    {\r\n                        &quot;Value&quot;:&quot;record3&quot;\r\n                    }\r\n                ],\r\n                &quot;HealthCheckId&quot;:&quot;ID&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;Action&quot;:&quot;DELETE&quot;,\r\n            &quot;ResourceRecordSet&quot;:{\r\n                &quot;Name&quot;:&quot;record4.&quot;,\r\n                &quot;Type&quot;:&quot;CNAME&quot;,\r\n                &quot;SetIdentifier&quot;:&quot;record4&quot;,\r\n                &quot;GeoLocation&quot;:{\r\n                    &quot;CountryCode&quot;:&quot;*&quot;\r\n                },\r\n                &quot;TTL&quot;:60,\r\n                &quot;ResourceRecords&quot;:[\r\n                    {\r\n                        &quot;Value&quot;:&quot;record4-ap-west&quot;\r\n                    }\r\n                ],\r\n                &quot;HealthCheckId&quot;:&quot;ID&quot;\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\nThe original file has 20000 such values for the &quot;Changes key&quot;. I want to create a file with 830 values in each file and create as many files as it creates. In order to achieve this I need it in the below format.\r\n\r\n```\r\n{\r\n    &quot;Comment&quot;:&quot;json data&quot;,\r\n    &quot;Changes&quot;:[\r\n        {\r\n            &quot;Action&quot;:&quot;DELETE&quot;,\r\n            &quot;ResourceRecordSet&quot;:{\r\n                &quot;Name&quot;:&quot;record4.&quot;,\r\n                &quot;Type&quot;:&quot;CNAME&quot;,\r\n                &quot;SetIdentifier&quot;:&quot;record4&quot;, #830 such arrays in each file\r\n                &quot;GeoLocation&quot;:{\r\n                    &quot;CountryCode&quot;:&quot;*&quot;\r\n                },\r\n                &quot;TTL&quot;:60,\r\n                &quot;ResourceRecords&quot;:[\r\n                    {\r\n                        &quot;Value&quot;:&quot;record4-ap-west&quot;\r\n                    }\r\n                ],\r\n                &quot;HealthCheckId&quot;:&quot;ID&quot;\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\nI&#39;ve created the below shell script to do this\r\n\r\n```\r\n#!/bin/bash\r\n\r\n# Set the input file name\r\ninput_file=&quot;input.json&quot;\r\n\r\n# Set the output file prefix\r\noutput_file_prefix=&quot;output&quot;\r\n\r\n# Set the number of objects per output file\r\nobjects_per_file=830\r\n\r\n# Skip the first two lines of the input file\r\ntail -n +3 &quot;$input_file&quot; &gt; temp.json\r\n\r\n# Get the total number of lines in the input file\r\ntotal_lines=$(wc -l &lt; temp.json)\r\n\r\n# Calculate the number of output files needed\r\noutput_files=$(((total_lines + objects_per_file - 1) / objects_per_file))\r\n\r\n# Split the input file into multiple output files\r\nsplit -l $objects_per_file temp.json &quot;$output_file_prefix&quot;\r\n\r\n# Loop through each output file and add the opening and closing square brackets\r\nfor file in &quot;$output_file_prefix&quot;*; do\r\n  echo &quot;[&quot; &gt; &quot;$file&quot;.json\r\n  cat &quot;$file&quot; &gt;&gt; &quot;$file&quot;.json\r\n  echo &quot;]&quot; &gt;&gt; &quot;$file&quot;.json\r\n  rm &quot;$file&quot;\r\ndone\r\n\r\n# Remove the temporary file\r\nrm temp.json\r\n\r\n```\r\n\r\n**By using this I am getting the output as expected but it is broken as it is considering 830 lines but not 830 arrays. **\r\n**Format:**\r\n\r\n```\r\n#start of file\r\n[\r\n{\r\n&quot;Action&quot;: &quot;DELETE&quot;,\r\n&quot;ResourceRecordSet&quot;:\r\n{\r\n  &quot;Name&quot;: &quot;record1&quot;,\r\n  &quot;Type&quot;: &quot;CNAME&quot;,\r\n  &quot;SetIdentifier&quot;: &quot;record1-ap-northeast&quot;,\r\n  &quot;GeoLocation&quot;: {\r\n    &quot;CountryCode&quot;: &quot;JP&quot;\r\n  },\r\n  &quot;TTL&quot;: 60,\r\n  &quot;ResourceRecords&quot;: [\r\n    {\r\n      &quot;Value&quot;: &quot;record1&quot;\r\n    }\r\n  ],\r\n  &quot;HealthCheckId&quot;: &quot;ID&quot;\r\n}\r\n},\r\n\r\n#end of file\r\n{\r\n&quot;Action&quot;: &quot;DELETE&quot;,\r\n&quot;ResourceRecordSet&quot;:\r\n{\r\n&quot;Action&quot;: &quot;DELETE&quot;,\r\n&quot;ResourceRecordSet&quot;:\r\n{\r\n  &quot;Name&quot;: &quot;record4.&quot;,\r\n  &quot;Type&quot;: &quot;CNAME&quot;,\r\n  &quot;SetIdentifier&quot;: &quot;record4&quot;\r\n]\r\n\r\n```\r\nHow do I achieve the required result. Due to the character limitation I cannot use more than 830 such arrays in each file?\r\nI tried using jq tool to achieve this but I am completely new with it. Could you please help me with this?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75350077/convert-a-single-json-to-multiple-jsons-by-taking-one-of-the-key-values",
        "title": "Convert a single JSON to multiple jsons by taking one of the key values?"
    },
    {
        "tags": [
            "jq",
            "iso8601"
        ],
        "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": 1675599060,
                "post_id": 75351906,
                "comment_id": 132960038,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "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": 1675602457,
                "post_id": 75351906,
                "comment_id": 132960595,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "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": 1675603857,
                "post_id": 75351906,
                "comment_id": 132960858,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1675613504,
                "post_id": 75351906,
                "comment_id": 132962683,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1675704170,
                "last_edit_date": 1675704170,
                "creation_date": 1675624686,
                "answer_id": 75354875,
                "question_id": 75351906,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The &quot;master&quot; version of jq fixes the issue (*). It&#39;s nice when jq and gojq agree:\r\n\r\n```\r\n$ uname -a\r\nDarwin Mac-mini.local 21.6.0 Darwin Kernel Version 21.6.0 ...\r\n\r\n$ jqMaster -nM &#39;&quot;1971-08-01T01:00:00Z&quot;,&quot;1972-08-01T01:00:00Z&quot; | fromdateiso8601&#39;\r\n49856400\r\n81478800\r\n\r\n$ gojq -n &#39;&quot;1971-08-01T01:00:00Z&quot;,&quot;1972-08-01T01:00:00Z&quot; | fromdateiso8601&#39;\r\n49856400\r\n81478800\r\n```\r\n\r\n——\r\n\r\n(*)\r\nhttps://github.com/stedolan/jq/commit/3c5b1419a278dfb192666b33197dc182c670290d",
                "title": "jq/fromdateiso8601 discrepancy on MacOS/Ubuntu"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1675704170,
        "creation_date": 1675596798,
        "last_edit_date": 1675664025,
        "question_id": 75351906,
        "body_markdown": "I run following two commands on both MacOS and Ubuntu :\r\n\r\n```\r\njq -n &#39;&quot;1971-08-01T01:00:00Z&quot; | fromdateiso8601&#39;\r\njq -n &#39;&quot;1972-08-01T01:00:00Z&quot; | fromdateiso8601&#39;\r\n```\r\n\r\nOn MacOS,   they give 49856400 and 81482400.\r\n\r\nOn Ubuntu, they give 49856400 and 81478800.\r\n\r\nWhy there is a difference of one hour for 1972, but no difference for 1971 ?\r\n\r\nBoth systems have jq-1.6.\r\n\r\n*Update 1*\r\n\r\nWindows behaves the same way as MacOS.\r\n\r\n*Update 2*\r\n\r\nThe dates where difference happens are as follows :\r\n\r\n```\r\n1972-03-20 - 1972-10-29 (inclusive)\r\n...\r\n2022-03-28 - 2022-10-30\r\n```\r\n\r\nSo it seems MacOS/Windows implementations apply one hour on DST dates from 1972 onwards, but not for the years 1969,1970, 1971.\r\n\r\nWhereas Ubuntu implementation does not apply at all.",
        "link": "https://stackoverflow.com/questions/75351906/jq-fromdateiso8601-discrepancy-on-macos-ubuntu",
        "title": "jq/fromdateiso8601 discrepancy on MacOS/Ubuntu"
    },
    {
        "tags": [
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1675722989,
                "last_edit_date": 1675722989,
                "creation_date": 1675722490,
                "answer_id": 75367223,
                "question_id": 75367200,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your first filter was executed as if it had been parenthesized like this\r\n```sh\r\necho &#39;{&quot;foo&quot;: 1}&#39; | jq &#39;.foo + (2 as $bar | {$bar})&#39;\r\n```\r\nThus, jq tried to add a number (here `1`) to an object (here `{&quot;bar&quot;:2}`).\r\n\r\nThis is because the syntax for a variable binding, as noted in the manual&#39;s [corresponding section](https://stedolan.github.io/jq/manual/#Variable%2FSymbolicBindingOperator%3A...as%24identifier%7C...), takes on the form `... as $identifier | ...`.  It &quot;includes&quot; the pipe and the following expression. This is reflected by the fact that a binding without the following pipe and expression cannot stand alone.",
                "title": "Why is `jq` trying to `add` to an object in a variable assignment?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1675893637,
        "creation_date": 1675722225,
        "last_edit_date": 1675893637,
        "question_id": 75367200,
        "body_markdown": "Given the following [tag:jq] pipeline of expressions:\r\n\r\n    echo &#39;{&quot;foo&quot;: 1}&#39; | jq &#39;.foo + 2 as $bar | {$bar}&#39;\r\n\r\nI would expect the output:\r\n\r\n    {\r\n      &quot;bar&quot;: 3\r\n    }\r\n\r\nWhat I get is:\r\n\r\n    jq: error (at &lt;stdin&gt;:1): number (1) and object ({&quot;bar&quot;:2}) cannot be added\r\n\r\n\r\nWhat is this object and why is `jq` trying to `add` to it?\r\n\r\nI can resolve this issue with parentheses but I&#39;m still unclear as to what was happening in the original statement:\r\n\r\n    echo &#39;{&quot;foo&quot;: 1}&#39; | jq &#39;(.foo + 2) as $bar | {$bar}&#39; \r\n    {\r\n      &quot;bar&quot;: 3\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75367200/why-is-jq-trying-to-add-to-an-object-in-a-variable-assignment",
        "title": "Why is `jq` trying to `add` to an object in a variable assignment?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1675772679,
                "creation_date": 1675772679,
                "answer_id": 75373320,
                "question_id": 75373266,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way could be to create a stream of 4 arbitrary items, e.g. numbers using `range`, store them in a variable to not affect the context, and provide your output for each:\r\n```sh\r\nrange(4) as $_ | .address\r\n```\r\n\r\nYou can also use the [comma operator](https://stedolan.github.io/jq/manual/#Comma:,) `,` to manually compile your stream:\r\n```sh\r\n.address, .address, .address, .address\r\n```",
                "title": "How do I duplicate values in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1675772679,
        "creation_date": 1675772383,
        "question_id": 75373266,
        "body_markdown": "I am trying to duplicate the values that I&#39;ve received in jq.\r\nFor example: If I enter &quot;.address&quot;, I get a value &quot;Times Square, New York&quot;\r\n\r\nI want to duplicate it so that it gives me the values:\r\n\r\n&quot;Times Square, New York&quot;\r\n&quot;Times Square, New York&quot;\r\n&quot;Times Square, New York&quot;\r\n&quot;Times Square, New York&quot;",
        "link": "https://stackoverflow.com/questions/75373266/how-do-i-duplicate-values-in-jq",
        "title": "How do I duplicate values in jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1675777407,
                "post_id": 75374187,
                "comment_id": 132998361,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1675777410,
                "creation_date": 1675777410,
                "answer_id": 75374211,
                "question_id": 75374187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`--arg` creates a string variable, but your `prId` properties are numbers (`6644 != &quot;6644&quot;`).\r\n\r\nUse [`--argjson`](https://stedolan.github.io/jq/manual/#Invokingjq) instead:\r\n\r\n```\r\njq --argjson v &quot;$PRID&quot; &#39;.[] | select(.prId == $v).IS_CR&#39; services.json \r\n```",
                "title": "get a value with jq by matching one of parent value from a variable"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1675777568,
                "creation_date": 1675777568,
                "answer_id": 75374242,
                "question_id": 75374187,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use:\r\n`jq &#39;.[] | select(.prId == &#39;&quot;$PRID&quot;&#39;) | .IS_CR&#39; services.json`\r\n\r\nOutput:\r\n```\r\n# PRID=6644\r\n# cat services.json\r\n{\r\n&quot;checkout-serviceA&quot;:{&quot;prId&quot;:6644,&quot;Sourcebranch&quot;:&quot;&quot;,&quot;HFX&quot;:false,&quot;IS_CR&quot;:&quot;Yes&quot;},\r\n&quot;checkout-serviceB&quot;:{&quot;prId&quot;:15826,&quot;Sourcebranch&quot;:&quot;&quot;,&quot;HFX&quot;:false,&quot;IS_CR&quot;: &quot;no&quot;},\r\n&quot;checkout-toggle&quot;:{&quot;prId&quot;:8963,&quot;Sourcebranch&quot;:&quot;&quot;,&quot;HFX&quot;:true,&quot;IS_CR&quot;: &quot;Yes&quot;},\r\n&quot;checkout-res&quot;:{&quot;prId&quot;:1104,&quot;Sourcebranch&quot;:&quot;&quot;,&quot;HFX&quot;:false,&quot;IS_CR&quot;: &quot;Yes&quot;}\r\n}\r\n# jq &#39;.[] | select(.prId == &#39;&quot;$PRID&quot;&#39;) | .IS_CR&#39; services.json\r\n&quot;Yes&quot;\r\n```\r\n",
                "title": "get a value with jq by matching one of parent value from a variable"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1675777568,
        "creation_date": 1675777235,
        "question_id": 75374187,
        "body_markdown": "I have JSON data as below, in services.json\r\n```json\r\n{\r\n&quot;checkout-serviceA&quot;:{&quot;prId&quot;:6644,&quot;Sourcebranch&quot;:&quot;&quot;,&quot;HFX&quot;:false,&quot;IS_CR&quot;:&quot;Yes&quot;},\r\n&quot;checkout-serviceB&quot;:{&quot;prId&quot;:15826,&quot;Sourcebranch&quot;:&quot;&quot;,&quot;HFX&quot;:false,&quot;IS_CR&quot;: &quot;no&quot;},\r\n&quot;checkout-toggle&quot;:{&quot;prId&quot;:8963,&quot;Sourcebranch&quot;:&quot;&quot;,&quot;HFX&quot;:true,&quot;IS_CR&quot;: &quot;Yes&quot;},\r\n&quot;checkout-res&quot;:{&quot;prId&quot;:1104,&quot;Sourcebranch&quot;:&quot;&quot;,&quot;HFX&quot;:false,&quot;IS_CR&quot;: &quot;Yes&quot;}\r\n}\r\n```\r\n\r\nI have a variable eg `$PRID` that contains `prID` value  already.\r\n\r\nI want to pass this to jq and fetch or get an output of `IS_CR` value for the respective `prID`.\r\n\r\nI tried \r\n`jq --arg v &quot;$PRID&quot; &#39;.[] | select(.prId == $v).IS_CR&#39; services.json\r\n`\r\n\r\n\r\n&amp;\r\n\r\n`jq --arg v &quot;$PRID&quot; &#39;to_entries | map(select(.value.prId == $v))[0].value.IS_CR&#39; services.json`\r\n\r\nbut none worked as it gives null or nothing returns.\r\n\r\nkindly help on this \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75374187/get-a-value-with-jq-by-matching-one-of-parent-value-from-a-variable",
        "title": "get a value with jq by matching one of parent value from a variable"
    },
    {
        "tags": [
            "bash",
            "jq",
            "firebase-test-lab"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1675789422,
                "post_id": 75376637,
                "comment_id": 133002754,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675799324,
                "post_id": 75376637,
                "comment_id": 133005476,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2126910,
                    "reputation": 1871,
                    "user_id": 1888799,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1c65f23ad6f63b4e8b24fb3fc61f0a99?s=256&d=identicon&r=PG",
                    "display_name": "veysiertekin",
                    "link": "https://stackoverflow.com/users/1888799/veysiertekin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675799443,
                "post_id": 75376637,
                "comment_id": 133005503,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1675799416,
                "last_edit_date": 1675799416,
                "creation_date": 1675798686,
                "answer_id": 75378220,
                "question_id": 75376637,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.[]` iterates over the elements in an array and returns a stream of elements. So the input `[1,2,3]` will be returned as `1 2 3` when filtered through `.[]`.\r\n\r\nNow you could stream the array&#39;s elements, apply a transformation, and then collect them again: `[.[] | f]`, but hold on. There&#39;s a better way: `map(f)`.\r\n\r\nApplying this idea to your program gives:\r\n\r\n```\r\njq -c &#39;map({matrixId, state, details: .axes[].details, device: .axes[].device, webLink} | to_entries[])&#39;\r\n```\r\n\r\n(Not sure why you have `to_entries | map({key:.key, value:.value})`, because `to_entries` already returns objects of that form.)\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;matrixId&quot;,\r\n    &quot;value&quot;: &quot;matrix-2h44ka21lln62&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;state&quot;,\r\n    &quot;value&quot;: &quot;FINISHED&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;details&quot;,\r\n    &quot;value&quot;: &quot;0 test cases failed&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;device&quot;,\r\n    &quot;value&quot;: &quot;iphone8-15.7-en-portrait&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;webLink&quot;,\r\n    &quot;value&quot;: &quot;https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/4663013071689981858/details&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;matrixId&quot;,\r\n    &quot;value&quot;: &quot;matrix-8hj1qx8udleaa&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;state&quot;,\r\n    &quot;value&quot;: &quot;FINISHED&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;details&quot;,\r\n    &quot;value&quot;: &quot;0 test cases failed&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;device&quot;,\r\n    &quot;value&quot;: &quot;iphone8-15.7-en-portrait&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;webLink&quot;,\r\n    &quot;value&quot;: &quot;https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/5654175129805154564/details&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;matrixId&quot;,\r\n    &quot;value&quot;: &quot;matrix-2i6y9uq9i0ext&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;state&quot;,\r\n    &quot;value&quot;: &quot;FINISHED&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;details&quot;,\r\n    &quot;value&quot;: &quot;0 test cases failed&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;device&quot;,\r\n    &quot;value&quot;: &quot;iphone8-15.7-en-portrait&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;webLink&quot;,\r\n    &quot;value&quot;: &quot;https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/4958041021718608851/details&quot;\r\n  }\r\n]\r\n```\r\n\r\nIf you want an array of arrays, then don&#39;t iterate `to_entries` and simply map to the entries array:\r\n\r\n```\r\njq &#39;map({matrixId, state, details: .axes[].details, device: .axes[].device, webLink} | to_entries)&#39;\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n[\r\n  [\r\n    {\r\n      &quot;key&quot;: &quot;matrixId&quot;,\r\n      &quot;value&quot;: &quot;matrix-2h44ka21lln62&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;state&quot;,\r\n      &quot;value&quot;: &quot;FINISHED&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;details&quot;,\r\n      &quot;value&quot;: &quot;0 test cases failed&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;device&quot;,\r\n      &quot;value&quot;: &quot;iphone8-15.7-en-portrait&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;webLink&quot;,\r\n      &quot;value&quot;: &quot;https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/4663013071689981858/details&quot;\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;key&quot;: &quot;matrixId&quot;,\r\n      &quot;value&quot;: &quot;matrix-8hj1qx8udleaa&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;state&quot;,\r\n      &quot;value&quot;: &quot;FINISHED&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;details&quot;,\r\n      &quot;value&quot;: &quot;0 test cases failed&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;device&quot;,\r\n      &quot;value&quot;: &quot;iphone8-15.7-en-portrait&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;webLink&quot;,\r\n      &quot;value&quot;: &quot;https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/5654175129805154564/details&quot;\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;key&quot;: &quot;matrixId&quot;,\r\n      &quot;value&quot;: &quot;matrix-2i6y9uq9i0ext&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;state&quot;,\r\n      &quot;value&quot;: &quot;FINISHED&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;details&quot;,\r\n      &quot;value&quot;: &quot;0 test cases failed&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;device&quot;,\r\n      &quot;value&quot;: &quot;iphone8-15.7-en-portrait&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;webLink&quot;,\r\n      &quot;value&quot;: &quot;https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/4958041021718608851/details&quot;\r\n    }\r\n  ]\r\n]\r\n```",
                "title": "Get the output of a jq command and iterate over them in a bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1675799416,
        "creation_date": 1675789152,
        "last_edit_date": 1675789447,
        "question_id": 75376637,
        "body_markdown": "I have the following json that I need to parse values in a bash script.\r\n```\r\n{\r\n  &quot;matrix-2h44ka21lln62&quot;: {\r\n    &quot;projectId&quot;: &quot;app-54934&quot;,\r\n    &quot;matrixId&quot;: &quot;matrix-2h44ka21lln62&quot;,\r\n    &quot;state&quot;: &quot;FINISHED&quot;,\r\n    &quot;gcsPath&quot;: &quot;App-ios-runner/2023-02-07_13-55-43.444360_CdCC/shard_0&quot;,\r\n    &quot;webLink&quot;: &quot;https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/4663013071689981858/details&quot;,\r\n    &quot;downloaded&quot;: true,\r\n    &quot;billableMinutes&quot;: {\r\n      &quot;virtual&quot;: 0,\r\n      &quot;physical&quot;: 1\r\n    },\r\n    &quot;clientDetails&quot;: {\r\n      &quot;Flank Version&quot;: &quot;v23.01.0&quot;,\r\n      &quot;Flank Revision&quot;: &quot;7ad3d5ba4097f189965110ca52b93fd0645715e0&quot;\r\n    },\r\n    &quot;gcsPathWithoutRootBucket&quot;: &quot;2023-02-07_13-55-43.444360_CdCC/shard_0&quot;,\r\n    &quot;gcsRootBucket&quot;: &quot;App-ios-runner&quot;,\r\n    &quot;axes&quot;: [\r\n      {\r\n        &quot;device&quot;: &quot;iphone8-15.7-en-portrait&quot;,\r\n        &quot;outcome&quot;: &quot;failure&quot;,\r\n        &quot;details&quot;: &quot;0 test cases failed&quot;,\r\n        &quot;suiteOverview&quot;: {\r\n          &quot;total&quot;: 0,\r\n          &quot;errors&quot;: 0,\r\n          &quot;failures&quot;: 0,\r\n          &quot;flakes&quot;: 0,\r\n          &quot;skipped&quot;: 0,\r\n          &quot;elapsedTime&quot;: 0,\r\n          &quot;overheadTime&quot;: 0\r\n        }\r\n      }\r\n    ],\r\n    &quot;appFileName&quot;: &quot;App-UISmokeTests.zip&quot;,\r\n    &quot;testFileName&quot;: &quot;App-UISmokeTests_iphoneos16.2-arm64_shard_0.xctestrun&quot;,\r\n    &quot;isCompleted&quot;: false,\r\n    &quot;testExecutions&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;matrix-2h44ka21lln62_execution-clgfpxn2zgrta&quot;,\r\n        &quot;modelId&quot;: &quot;iphone8&quot;,\r\n        &quot;deviceVersion&quot;: &quot;15.7&quot;,\r\n        &quot;state&quot;: &quot;FINISHED&quot;,\r\n        &quot;errorMessage&quot;: &quot;&quot;,\r\n        &quot;progress&quot;: [\r\n          &quot;Starting attempt 1.&quot;,\r\n          &quot;Checking Internet connection...&quot;,\r\n          &quot;Internet connection stable!&quot;,\r\n          &quot;Starting iOS test.&quot;,\r\n          &quot;Completed iOS test.&quot;,\r\n          &quot;Done. Test time = 14 (secs)&quot;,\r\n          &quot;Starting results processing. Attempt: 1&quot;,\r\n          &quot;Completed results processing. Time taken = 3 (secs)&quot;\r\n        ],\r\n        &quot;toolResultsStep&quot;: {\r\n          &quot;executionId&quot;: &quot;4663013071689981858&quot;,\r\n          &quot;historyId&quot;: &quot;bh.388190097b1eab25&quot;,\r\n          &quot;projectId&quot;: &quot;app-54934&quot;,\r\n          &quot;stepId&quot;: &quot;bs.2b9b72bccab868fa&quot;\r\n        }\r\n      }\r\n    ],\r\n    &quot;testTimeout&quot;: 2700,\r\n    &quot;isRoboTest&quot;: false,\r\n    &quot;historyId&quot;: &quot;&quot;,\r\n    &quot;executionId&quot;: &quot;&quot;,\r\n    &quot;invalidMatrixDetails&quot;: &quot;UNKNOWN&quot;,\r\n    &quot;outcome&quot;: &quot;failure&quot;\r\n  },\r\n  &quot;matrix-8hj1qx8udleaa&quot;: {\r\n    &quot;projectId&quot;: &quot;app-54934&quot;,\r\n    &quot;matrixId&quot;: &quot;matrix-8hj1qx8udleaa&quot;,\r\n    &quot;state&quot;: &quot;FINISHED&quot;,\r\n    &quot;gcsPath&quot;: &quot;App-ios-runner/2023-02-07_13-55-43.444360_CdCC/shard_1&quot;,\r\n    &quot;webLink&quot;: &quot;https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/5654175129805154564/details&quot;,\r\n    &quot;downloaded&quot;: true,\r\n    &quot;billableMinutes&quot;: {\r\n      &quot;virtual&quot;: 0,\r\n      &quot;physical&quot;: 1\r\n    },\r\n    &quot;clientDetails&quot;: {\r\n      &quot;Flank Version&quot;: &quot;v23.01.0&quot;,\r\n      &quot;Flank Revision&quot;: &quot;7ad3d5ba4097f189965110ca52b93fd0645715e0&quot;\r\n    },\r\n    &quot;gcsPathWithoutRootBucket&quot;: &quot;2023-02-07_13-55-43.444360_CdCC/shard_1&quot;,\r\n    &quot;gcsRootBucket&quot;: &quot;App-ios-runner&quot;,\r\n    &quot;axes&quot;: [\r\n      {\r\n        &quot;device&quot;: &quot;iphone8-15.7-en-portrait&quot;,\r\n        &quot;outcome&quot;: &quot;failure&quot;,\r\n        &quot;details&quot;: &quot;0 test cases failed&quot;,\r\n        &quot;suiteOverview&quot;: {\r\n          &quot;total&quot;: 0,\r\n          &quot;errors&quot;: 0,\r\n          &quot;failures&quot;: 0,\r\n          &quot;flakes&quot;: 0,\r\n          &quot;skipped&quot;: 0,\r\n          &quot;elapsedTime&quot;: 0,\r\n          &quot;overheadTime&quot;: 0\r\n        }\r\n      }\r\n    ],\r\n    &quot;appFileName&quot;: &quot;App-UISmokeTests.zip&quot;,\r\n    &quot;testFileName&quot;: &quot;App-UISmokeTests_iphoneos16.2-arm64_shard_1.xctestrun&quot;,\r\n    &quot;isCompleted&quot;: false,\r\n    &quot;testExecutions&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;matrix-8hj1qx8udleaa_execution-10jy4hq8i62g4&quot;,\r\n        &quot;modelId&quot;: &quot;iphone8&quot;,\r\n        &quot;deviceVersion&quot;: &quot;15.7&quot;,\r\n        &quot;state&quot;: &quot;FINISHED&quot;,\r\n        &quot;errorMessage&quot;: &quot;&quot;,\r\n        &quot;progress&quot;: [\r\n          &quot;Starting attempt 1.&quot;,\r\n          &quot;Checking Internet connection...&quot;,\r\n          &quot;Internet connection stable!&quot;,\r\n          &quot;Starting iOS test.&quot;,\r\n          &quot;Completed iOS test.&quot;,\r\n          &quot;Done. Test time = 15 (secs)&quot;,\r\n          &quot;Starting results processing. Attempt: 1&quot;,\r\n          &quot;Completed results processing. Time taken = 4 (secs)&quot;\r\n        ],\r\n        &quot;toolResultsStep&quot;: {\r\n          &quot;executionId&quot;: &quot;5654175129805154564&quot;,\r\n          &quot;historyId&quot;: &quot;bh.388190097b1eab25&quot;,\r\n          &quot;projectId&quot;: &quot;app-54934&quot;,\r\n          &quot;stepId&quot;: &quot;bs.b7d2f90beed6230a&quot;\r\n        }\r\n      }\r\n    ],\r\n    &quot;testTimeout&quot;: 2700,\r\n    &quot;isRoboTest&quot;: false,\r\n    &quot;historyId&quot;: &quot;&quot;,\r\n    &quot;executionId&quot;: &quot;&quot;,\r\n    &quot;invalidMatrixDetails&quot;: &quot;UNKNOWN&quot;,\r\n    &quot;outcome&quot;: &quot;failure&quot;\r\n  },\r\n  &quot;matrix-2i6y9uq9i0ext&quot;: {\r\n    &quot;projectId&quot;: &quot;app-54934&quot;,\r\n    &quot;matrixId&quot;: &quot;matrix-2i6y9uq9i0ext&quot;,\r\n    &quot;state&quot;: &quot;FINISHED&quot;,\r\n    &quot;gcsPath&quot;: &quot;App-ios-runner/2023-02-07_13-55-43.444360_CdCC/shard_2&quot;,\r\n    &quot;webLink&quot;: &quot;https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/4958041021718608851/details&quot;,\r\n    &quot;downloaded&quot;: true,\r\n    &quot;billableMinutes&quot;: {\r\n      &quot;virtual&quot;: 0,\r\n      &quot;physical&quot;: 1\r\n    },\r\n    &quot;clientDetails&quot;: {\r\n      &quot;Flank Version&quot;: &quot;v23.01.0&quot;,\r\n      &quot;Flank Revision&quot;: &quot;7ad3d5ba4097f189965110ca52b93fd0645715e0&quot;\r\n    },\r\n    &quot;gcsPathWithoutRootBucket&quot;: &quot;2023-02-07_13-55-43.444360_CdCC/shard_2&quot;,\r\n    &quot;gcsRootBucket&quot;: &quot;App-ios-runner&quot;,\r\n    &quot;axes&quot;: [\r\n      {\r\n        &quot;device&quot;: &quot;iphone8-15.7-en-portrait&quot;,\r\n        &quot;outcome&quot;: &quot;failure&quot;,\r\n        &quot;details&quot;: &quot;0 test cases failed&quot;,\r\n        &quot;suiteOverview&quot;: {\r\n          &quot;total&quot;: 0,\r\n          &quot;errors&quot;: 0,\r\n          &quot;failures&quot;: 0,\r\n          &quot;flakes&quot;: 0,\r\n          &quot;skipped&quot;: 0,\r\n          &quot;elapsedTime&quot;: 0,\r\n          &quot;overheadTime&quot;: 0\r\n        }\r\n      }\r\n    ],\r\n    &quot;appFileName&quot;: &quot;App-UISmokeTests.zip&quot;,\r\n    &quot;testFileName&quot;: &quot;App-UISmokeTests_iphoneos16.2-arm64_shard_2.xctestrun&quot;,\r\n    &quot;isCompleted&quot;: false,\r\n    &quot;testExecutions&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;matrix-2i6y9uq9i0ext_execution-1zvntyq5awzyv&quot;,\r\n        &quot;modelId&quot;: &quot;iphone8&quot;,\r\n        &quot;deviceVersion&quot;: &quot;15.7&quot;,\r\n        &quot;state&quot;: &quot;FINISHED&quot;,\r\n        &quot;errorMessage&quot;: &quot;&quot;,\r\n        &quot;progress&quot;: [\r\n          &quot;Starting attempt 1.&quot;,\r\n          &quot;Checking Internet connection...&quot;,\r\n          &quot;Internet connection stable!&quot;,\r\n          &quot;Starting iOS test.&quot;,\r\n          &quot;Completed iOS test.&quot;,\r\n          &quot;Done. Test time = 13 (secs)&quot;,\r\n          &quot;Starting results processing. Attempt: 1&quot;,\r\n          &quot;Completed results processing. Time taken = 5 (secs)&quot;\r\n        ],\r\n        &quot;toolResultsStep&quot;: {\r\n          &quot;executionId&quot;: &quot;4958041021718608851&quot;,\r\n          &quot;historyId&quot;: &quot;bh.388190097b1eab25&quot;,\r\n          &quot;projectId&quot;: &quot;app-54934&quot;,\r\n          &quot;stepId&quot;: &quot;bs.283070cfe31b0c&quot;\r\n        }\r\n      }\r\n    ],\r\n    &quot;testTimeout&quot;: 2700,\r\n    &quot;isRoboTest&quot;: false,\r\n    &quot;historyId&quot;: &quot;&quot;,\r\n    &quot;executionId&quot;: &quot;&quot;,\r\n    &quot;invalidMatrixDetails&quot;: &quot;UNKNOWN&quot;,\r\n    &quot;outcome&quot;: &quot;failure&quot;\r\n  }\r\n}\r\n```\r\n\r\nI went with jq to parse these results but I&#39;m stuck on how to iterate values over the output of my jq command \r\n\r\n    jq -c --raw-output &#39;.[] | {matrixId: .matrixId, state: .state, details: .axes[].details, device: .axes[].device, webLink: .webLink} | to_entries | map({key:.key, value:.value})&#39;\r\n\r\nI want to get the following result\r\n\r\n```\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;matrixId&quot;,\r\n    &quot;value&quot;: &quot;matrix-2h44ka21lln62&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;state&quot;,\r\n    &quot;value&quot;: &quot;FINISHED&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;details&quot;,\r\n    &quot;value&quot;: &quot;0 test cases failed&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;device&quot;,\r\n    &quot;value&quot;: &quot;iphone8-15.7-en-portrait&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;webLink&quot;,\r\n    &quot;value&quot;: &quot;https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/4663013071689981858/details&quot;\r\n  }\r\n],\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;matrixId&quot;,\r\n    &quot;value&quot;: &quot;matrix-8hj1qx8udleaa&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;state&quot;,\r\n    &quot;value&quot;: &quot;FINISHED&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;details&quot;,\r\n    &quot;value&quot;: &quot;0 test cases failed&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;device&quot;,\r\n    &quot;value&quot;: &quot;iphone8-15.7-en-portrait&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;webLink&quot;,\r\n    &quot;value&quot;: &quot;https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/5654175129805154564/details&quot;\r\n  }\r\n],\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;matrixId&quot;,\r\n    &quot;value&quot;: &quot;matrix-2i6y9uq9i0ext&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;state&quot;,\r\n    &quot;value&quot;: &quot;FINISHED&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;details&quot;,\r\n    &quot;value&quot;: &quot;0 test cases failed&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;device&quot;,\r\n    &quot;value&quot;: &quot;iphone8-15.7-en-portrait&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;webLink&quot;,\r\n    &quot;value&quot;: &quot;https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/4958041021718608851/details&quot;\r\n  }\r\n]\r\n```\r\n\r\n\r\nIt returns the output as three array objects with no comma separated value which is blocking me on iterating over them\r\n\r\n\r\nI tried to search on how can I join them through piping but it&#39;s not working as expected",
        "link": "https://stackoverflow.com/questions/75376637/get-the-output-of-a-jq-command-and-iterate-over-them-in-a-bash-script",
        "title": "Get the output of a jq command and iterate over them in a bash script"
    },
    {
        "tags": [
            "jq",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1675797541,
                "creation_date": 1675797541,
                "answer_id": 75378024,
                "question_id": 75377835,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could just `map` the `.items` array to contain only those items that match.\r\n\r\nUsing [mikefarah/yq](https://github.com/mikefarah/yq):\r\n```sh\r\nyq &#39;\r\n  (load(&quot;images.yaml&quot;).searchItems | unique) as $q | .items\r\n  | map(select(.spec.template.spec.containers[0].image == $q[]))\r\n&#39; deployments.yaml\r\n```\r\n\r\nUsing [kislyuk/yq](https://github.com/kislyuk/yq):\r\n```sh\r\nyq -y &#39;\r\n  (input.searchItems | unique) as $q | .items\r\n  | map(select(.spec.template.spec.containers[0].image == $q[]))\r\n&#39; deployments.yaml images.yaml\r\n```\r\n\r\nUsing [itchyny/gojq](https://github.com/itchyny/gojq):\r\n```sh\r\ngojq --yaml-input --yaml-output &#39;\r\n  (input.searchItems | unique) as $q | .items\r\n  | map(select(.spec.template.spec.containers[0].image == $q[]))\r\n&#39; deployments.yaml images.yaml\r\n```",
                "title": "How do I get an intersection of two lists with yq/jq, returning the parent object for matches?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1675797541,
        "creation_date": 1675796396,
        "last_edit_date": 1675797083,
        "question_id": 75377835,
        "body_markdown": "Simplified from my use case a bit, I&#39;m trying to find all Kubernetes deployments whose image (you can assume the container at index 0) is contained in a list of images.\r\n\r\nI understand I can subtract two arrays to get the the intersection of these, but what I&#39;m left with is just the list of images; I&#39;d like to keep the full Deployment spec for matches.\r\n\r\nExample:\r\n\r\ndeployments.yaml:\r\n```yaml\r\napiVersion: v1\r\nkind: List\r\nmetadata:\r\n  resourceVersion: &quot;&quot;\r\nitems:\r\n- apiVersion: apps/v1\r\n  kind: Deployment\r\n  metadata:\r\n    name: nginx-deployment\r\n    labels:\r\n      app: nginx\r\n  spec:\r\n    replicas: 3\r\n    selector:\r\n      matchLabels:\r\n        app: nginx\r\n    template:\r\n      metadata:\r\n        labels:\r\n          app: nginx\r\n      spec:\r\n        containers:\r\n        - name: nginx\r\n          image: nginx:1.14.2\r\n          ports:\r\n          - containerPort: 80\r\n- apiVersion: apps/v1\r\n  kind: Deployment\r\n  metadata:\r\n    name: myapp-deployment\r\n    labels:\r\n      app: myapp\r\n  spec:\r\n    replicas: 1\r\n    selector:\r\n      matchLabels:\r\n        app: myapp\r\n    template:\r\n      metadata:\r\n        labels:\r\n          app: myapp\r\n      spec:\r\n        containers:\r\n        - name: myapp\r\n          image: myapp:0.1.2\r\n          ports:\r\n          - containerPort: 8080\r\n```\r\n\r\nimages.yaml\r\n```yaml\r\nsearchItems:\r\n- nginx:1.13.1\r\n- nginx:1.14.2\r\n```\r\n\r\nUsing this, I can get the list of images for Deployments using one of the images in my list:\r\n```\r\nyq ea &#39;[.items[].spec.template.spec.containers[0].image] - ([.items[].spec.template.spec.containers[0].image] - .searchItems) | unique&#39; deployments.yaml images.yaml\r\n```\r\nOutput:\r\n```\r\n- nginx:1.14.2\r\n```\r\nI&#39;d like to get the entire Deployment object though, not just the image, for any matches.\r\n\r\nI am using yq here, but any solution using jq would work fine for me too. I can also solve this by other means, like scripting it one by one, but I am curious about the solution with yq/jq.",
        "link": "https://stackoverflow.com/questions/75377835/how-do-i-get-an-intersection-of-two-lists-with-yq-jq-returning-the-parent-objec",
        "title": "How do I get an intersection of two lists with yq/jq, returning the parent object for matches?"
    },
    {
        "tags": [
            "json",
            "structure",
            "jq",
            "transform"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1675810112,
                "creation_date": 1675810112,
                "answer_id": 75379764,
                "question_id": 75379682,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t understand why one of the items is missing in your desired output, but apart from that it&#39;s flattening the object with mapping the key to another field:\r\n```sh\r\njq &#39;._internal_messages |= (to_entries | map({type: .key} + .value[]))&#39;\r\n```\r\n```json\r\n{\r\n  &quot;_internal_messages&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;error&quot;,\r\n      &quot;date&quot;: &quot;16:12:30 - 07/02/2023&quot;,\r\n      &quot;id&quot;: 1,\r\n      &quot;origin&quot;: &quot;A&quot;,\r\n      &quot;text&quot;: &quot;This is an error message&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;error&quot;,\r\n      &quot;date&quot;: &quot;16:12:31 - 07/02/2023&quot;,\r\n      &quot;id&quot;: 5,\r\n      &quot;origin&quot;: &quot;A&quot;,\r\n      &quot;text&quot;: &quot;This is a second error message&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;info&quot;,\r\n      &quot;date&quot;: &quot;16:12:29 - 07/02/2023&quot;,\r\n      &quot;id&quot;: 0,\r\n      &quot;origin&quot;: &quot;A&quot;,\r\n      &quot;text&quot;: &quot;This is an info message&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;info&quot;,\r\n      &quot;date&quot;: &quot;16:12:30 - 07/02/2023&quot;,\r\n      &quot;id&quot;: 4,\r\n      &quot;origin&quot;: &quot;C&quot;,\r\n      &quot;text&quot;: &quot;This is a second info message&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;success&quot;,\r\n      &quot;date&quot;: &quot;16:12:30 - 07/02/2023&quot;,\r\n      &quot;id&quot;: 2,\r\n      &quot;origin&quot;: &quot;B&quot;,\r\n      &quot;text&quot;: &quot;This is a success message&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;success&quot;,\r\n      &quot;date&quot;: &quot;16:12:30 - 07/02/2023&quot;,\r\n      &quot;id&quot;: 3,\r\n      &quot;origin&quot;: &quot;B&quot;,\r\n      &quot;text&quot;: &quot;This is a second success message&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;success&quot;,\r\n      &quot;date&quot;: &quot;16:12:31 - 07/02/2023&quot;,\r\n      &quot;id&quot;: 6,\r\n      &quot;origin&quot;: &quot;C&quot;,\r\n      &quot;text&quot;: &quot;This is a third success message&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n---\r\nIf you want the items to be sorted by `.id`, append a `sort_by`:\r\n```sh\r\njq &#39;._internal_messages |= (to_entries | map({type: .key} + .value[]) | sort_by(.id))&#39;\r\n```\r\n```json\r\n{\r\n  &quot;_internal_messages&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;info&quot;,\r\n      &quot;date&quot;: &quot;16:12:29 - 07/02/2023&quot;,\r\n      &quot;id&quot;: 0,\r\n      &quot;origin&quot;: &quot;A&quot;,\r\n      &quot;text&quot;: &quot;This is an info message&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;error&quot;,\r\n      &quot;date&quot;: &quot;16:12:30 - 07/02/2023&quot;,\r\n      &quot;id&quot;: 1,\r\n      &quot;origin&quot;: &quot;A&quot;,\r\n      &quot;text&quot;: &quot;This is an error message&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;success&quot;,\r\n      &quot;date&quot;: &quot;16:12:30 - 07/02/2023&quot;,\r\n      &quot;id&quot;: 2,\r\n      &quot;origin&quot;: &quot;B&quot;,\r\n      &quot;text&quot;: &quot;This is a success message&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;success&quot;,\r\n      &quot;date&quot;: &quot;16:12:30 - 07/02/2023&quot;,\r\n      &quot;id&quot;: 3,\r\n      &quot;origin&quot;: &quot;B&quot;,\r\n      &quot;text&quot;: &quot;This is a second success message&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;info&quot;,\r\n      &quot;date&quot;: &quot;16:12:30 - 07/02/2023&quot;,\r\n      &quot;id&quot;: 4,\r\n      &quot;origin&quot;: &quot;C&quot;,\r\n      &quot;text&quot;: &quot;This is a second info message&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;error&quot;,\r\n      &quot;date&quot;: &quot;16:12:31 - 07/02/2023&quot;,\r\n      &quot;id&quot;: 5,\r\n      &quot;origin&quot;: &quot;A&quot;,\r\n      &quot;text&quot;: &quot;This is a second error message&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;success&quot;,\r\n      &quot;date&quot;: &quot;16:12:31 - 07/02/2023&quot;,\r\n      &quot;id&quot;: 6,\r\n      &quot;origin&quot;: &quot;C&quot;,\r\n      &quot;text&quot;: &quot;This is a third success message&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "How to transform a json structure with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1675810569,
        "creation_date": 1675809420,
        "last_edit_date": 1675810569,
        "question_id": 75379682,
        "body_markdown": "How can I transform (using `jq`) the following _json_ structure from this:\r\n\r\n```\r\n{\r\n  &quot;_internal_messages&quot;: {\r\n    &quot;error&quot;: [\r\n      {\r\n        &quot;date&quot;: &quot;16:12:30 - 07/02/2023&quot;,\r\n        &quot;id&quot;: 1,\r\n        &quot;origin&quot;: &quot;A&quot;,\r\n        &quot;text&quot;: &quot;This is an error message&quot;\r\n      },\r\n      {\r\n        &quot;date&quot;: &quot;16:12:31 - 07/02/2023&quot;,\r\n        &quot;id&quot;: 5,\r\n        &quot;origin&quot;: &quot;A&quot;,\r\n        &quot;text&quot;: &quot;This is a second error message&quot;\r\n      }\r\n    ],\r\n    &quot;info&quot;: [\r\n      {\r\n        &quot;date&quot;: &quot;16:12:29 - 07/02/2023&quot;,\r\n        &quot;id&quot;: 0,\r\n        &quot;origin&quot;: &quot;A&quot;,\r\n        &quot;text&quot;: &quot;This is an info message&quot;\r\n      },\r\n      {\r\n        &quot;date&quot;: &quot;16:12:30 - 07/02/2023&quot;,\r\n        &quot;id&quot;: 4,\r\n        &quot;origin&quot;: &quot;C&quot;,\r\n        &quot;text&quot;: &quot;This is a second info message&quot;\r\n      }\r\n    ],\r\n    &quot;success&quot;: [\r\n      {\r\n        &quot;date&quot;: &quot;16:12:30 - 07/02/2023&quot;,\r\n        &quot;id&quot;: 2,\r\n        &quot;origin&quot;: &quot;B&quot;,\r\n        &quot;text&quot;: &quot;This is a success message&quot;\r\n      },\r\n      {\r\n        &quot;date&quot;: &quot;16:12:30 - 07/02/2023&quot;,\r\n        &quot;id&quot;: 3,\r\n        &quot;origin&quot;: &quot;B&quot;,\r\n        &quot;text&quot;: &quot;This is a second success message&quot;\r\n      },\r\n      {\r\n        &quot;date&quot;: &quot;16:12:31 - 07/02/2023&quot;,\r\n        &quot;id&quot;: 6,\r\n        &quot;origin&quot;: &quot;C&quot;,\r\n        &quot;text&quot;: &quot;This is a third success message&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nTo this:\r\n\r\n```\r\n{&quot;_internal_messages&quot;:[\r\n  {\r\n    &quot;type&quot;:&quot;info&quot;,\r\n    &quot;date&quot;: &quot;16:12:29 - 07/02/2023&quot;,\r\n    &quot;id&quot;: 0,\r\n    &quot;origin&quot;: &quot;A&quot;,\r\n    &quot;text&quot;: &quot;This is an info message&quot;\r\n  },{\r\n    &quot;type&quot;:&quot;error&quot;,\r\n    &quot;date&quot;: &quot;16:12:30 - 07/02/2023&quot;,\r\n    &quot;id&quot;: 1,\r\n    &quot;origin&quot;: &quot;A&quot;,\r\n    &quot;text&quot;: &quot;This is an error message&quot;\r\n  },{\r\n    &quot;type&quot;:&quot;success&quot;,\r\n    &quot;date&quot;: &quot;16:12:30 - 07/02/2023&quot;,\r\n    &quot;id&quot;: 2,\r\n    &quot;origin&quot;: &quot;B&quot;,\r\n    &quot;text&quot;: &quot;This is a success message&quot;\r\n  },{\r\n    &quot;type&quot;:&quot;success&quot;,\r\n    &quot;date&quot;: &quot;16:12:30 - 07/02/2023&quot;,\r\n    &quot;id&quot;: 3,\r\n    &quot;origin&quot;: &quot;B&quot;,\r\n    &quot;text&quot;: &quot;This is a second success message&quot;\r\n  },{\r\n    &quot;type&quot;:&quot;info&quot;,\r\n    &quot;date&quot;: &quot;16:12:30 - 07/02/2023&quot;,\r\n    &quot;id&quot;: 4,\r\n    &quot;origin&quot;: &quot;C&quot;,\r\n    &quot;text&quot;: &quot;This is a second info message&quot;\r\n  },{\r\n    &quot;type&quot;:&quot;error&quot;,\r\n    &quot;date&quot;: &quot;16:12:31 - 07/02/2023&quot;,\r\n    &quot;id&quot;: 5,\r\n    &quot;origin&quot;: &quot;A&quot;,\r\n    &quot;text&quot;: &quot;This is a second error message&quot;\r\n  },{\r\n    &quot;type&quot;:&quot;success&quot;,\r\n    &quot;date&quot;: &quot;16:12:31 - 07/02/2023&quot;,\r\n    &quot;id&quot;: 6,\r\n    &quot;origin&quot;: &quot;C&quot;,\r\n    &quot;text&quot;: &quot;This is a third success message&quot;\r\n  }\r\n]}\r\n```\r\n\r\nI checked the _jq Manual_ and some other previous answered questions at SO, but I was not able to crack this one out... I&#180;m thinking in combining `jq` with `bash` to do it, but I&#180;m sure there must be a better way using just `jq` but my skills are not there yet. Can someone help me out, please? Thanks!\r\n\r\nIn the original structure the messages are stored in 3 arrays: `error`, `info` and `success`. Each time a message is added to those arrays, it receives a consecutive/incremental `id`. What I want is to take all those messages out from the three arrays, put them in one array while adding an extra attribute to know where each message came from (`error`, `info` or `success`) and finally order them in asc order by their id. The tricky part is knowing which one is an `error`, `info` or a `success` once you put them all together.",
        "link": "https://stackoverflow.com/questions/75379682/how-to-transform-a-json-structure-with-jq",
        "title": "How to transform a json structure with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675845356,
                "post_id": 75382353,
                "comment_id": 133013395,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23745027,
                    "reputation": 773,
                    "user_id": 17762566,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/535989cd46e90e339be99aa1f0fbcc04?s=256&d=identicon&r=PG",
                    "display_name": "Preeti ",
                    "link": "https://stackoverflow.com/users/17762566/preeti"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675845706,
                "post_id": 75382353,
                "comment_id": 133013508,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675845740,
                "post_id": 75382353,
                "comment_id": 133013519,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1675849097,
                "last_edit_date": 1675849097,
                "creation_date": 1675840611,
                "answer_id": 75382455,
                "question_id": 75382353,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your problem is not (only) with jq, but with shell syntax.\r\n\r\nBut if all you are trying to do is to update the value of key D whether it exists or not, then you don&#39;t need any checks and can simply assign the new value:\r\n\r\n```\r\n$ jq &#39;.D = [&quot;new value&quot;]&#39; test.json \r\n{\r\n  &quot;A&quot;: &quot;123&quot;,\r\n  &quot;B&quot;: &quot;456&quot;,\r\n  &quot;C&quot;: &quot;789&quot;,\r\n  &quot;D&quot;: [\r\n    &quot;new value&quot;\r\n  ]\r\n}\r\n```\r\n\r\nIf you want to modify the current value, the operator `|=` might be helpful.\r\n\r\nAn alternative, equivalent program would be `&#39;. + { D: [&quot;new value&quot;] }&#39;`\r\n\r\n****\r\n\r\nIf you really want to fix your script, here&#39;s a working version of it:\r\n\r\n```\r\nif jq -e &#39;has(&quot;D&quot;)&#39; test.json &gt;/dev/null; then\r\n  # key exists\r\n  jq --argjson addobj &#39;{&quot;D&quot;: &quot;[]&quot;}&#39; &#39;your program here&#39; test.json\r\nelse\r\n  # key doesn&#39;t exist\r\n  jq &#39;your other program here&#39;\r\nfi\r\n```\r\n\r\nBut this is arguably easier in jq directly:\r\n\r\n```\r\njq --argjson addobj &#39;{&quot;D&quot;: &quot;[]&quot;}&#39; &#39;\r\nif has(&quot;D&quot;) then\r\n  # D exists\r\n  . # &lt;- your jq program\r\nelse\r\n  # D doesn&#39;t exist\r\n  . # &lt;- your other jq program\r\nend\r\n&#39; test.json\r\n```\r\n\r\nIf your goal is to simply insert the key with a default value if it doesn&#39;t exist, but keep any existing value, the following simple jq program (and nothing else) should take care of that:\r\n\r\n```\r\njq &#39;{D: []} + .&#39; test.json\r\n```\r\n\r\n(keys in the RHS overwrite keys from the LHS – `{a:1}+{a:2}` becomes `{a:2}`)\r\n\r\nObjects in JavaScript (and by extension JSON), are a bag of unordered key-value pairs and `{a:1,b:2}` is the same object as `{b:2,a:1}`.\r\n\r\nHowever, jq mostly keeps order of keys (although I don&#39;t think this is specified/guaranteed). So, a slightly more complicated version which puts `D` at the end of the object, but keeps existing values would be:\r\n\r\n```\r\njq &#39;.D |= (. // [])&#39; test.json\r\n```",
                "title": "How to create keys in json file using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1675849097,
        "creation_date": 1675839814,
        "last_edit_date": 1675843977,
        "question_id": 75382353,
        "body_markdown": "I am trying to update a `json` file using `jq`. My json file looks like\r\n``` \r\n{\r\n\t&quot;A&quot;: &quot;123&quot;,\r\n\t&quot;B&quot;: &quot;456&quot;,\r\n\t&quot;C&quot;: &quot;789&quot;,\r\n\t&quot;D&quot;: []\r\n}\r\n``` \r\nHere the value for key `D` is empty so I am adding some values to it. And this is working\r\n\r\nNow, if for some reason the key doesn&#39;t exist then I need to first create the key `D`. And I am not able to achieve this\r\n\r\n``` \r\n{\r\n\t&quot;A&quot;: &quot;123&quot;,\r\n\t&quot;B&quot;: &quot;456&quot;,\r\n\t&quot;C&quot;: &quot;789&quot;,\r\n}\r\n```\r\n\r\n    cat test.json | jq &#39;has(&quot;D&quot;)&#39; = false &amp;&amp; cat test.json jq --argjson addobj &#39;{&quot;D&quot;: &quot;[]&quot;}&#39;\r\n\r\nI am getting the error \r\n```\r\njq: error: Could not open file =: No such file or directory\r\njq: error: Could not open file false: No such file or directory\r\n```\r\n\r\nexpected output\r\n\r\n``` \r\n{\r\n\t&quot;A&quot;: &quot;123&quot;,\r\n\t&quot;B&quot;: &quot;456&quot;,\r\n\t&quot;C&quot;: &quot;789&quot;,\r\n\t&quot;D&quot;: []\r\n}\r\n```\r\n\r\nCan anyone please let me know what is the issue here and how to resolve it?\r\n\r\nThanks in advance.\r\n\r\nP.S: Please let me know if any info is missing here\r\n ",
        "link": "https://stackoverflow.com/questions/75382353/how-to-create-keys-in-json-file-using-jq",
        "title": "How to create keys in json file using jq?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675864669,
                "post_id": 75384637,
                "comment_id": 133019355,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1675854008,
                "creation_date": 1675854008,
                "answer_id": 75384805,
                "question_id": 75384637,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have a loop (or any sequence of commands) which generates a stream of JSON objects, you can _slurp_ them with jq and get your array for free.\r\n\r\nLoop:\r\n\r\n```\r\nfor i in $(seq 100); do\r\n  echo &#39;{&quot;key&quot;: &quot;value&quot;}&#39;;\r\ndone | jq -s &#39;.&#39; &gt; output.json\r\n```\r\n\r\nSequence:\r\n\r\n```\r\n{\r\n  echo &#39;{&quot;key&quot;: &quot;value&quot;}&#39;;\r\n  echo &#39;{&quot;other_key&quot;: &quot;second value&quot;}&#39;;\r\n  echo &#39;{&quot;last&quot;: 42}&#39;;\r\n} | jq -s &#39;.&#39; &gt; output.json\r\n```",
                "title": "What is the proper way of growing a json array using jq inside a bash script?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1675877997,
        "creation_date": 1675853116,
        "last_edit_date": 1675877997,
        "question_id": 75384637,
        "body_markdown": "I am trying to construct a json array using jq element by element. The elements are being generated by a certain process. In this example I am keeping all the elements as the same, let&#39;s say ```{&quot;key_1&quot;:1}``` for simplicity.\r\n```\r\ndeclare JSON_ARRAY=[]\r\ntotal_count=10000\r\nOBJECT=&quot;{\\&quot;key_1\\&quot;:1}&quot;\r\nfor i in $(seq 0 $total_count); do\r\n  JSON_ARRAY=$(echo &quot;$JSON_ARRAY&quot; | jq .[$i]+=&quot;$OBJECT&quot;)\r\ndone\r\necho &quot;$JSON_ARRAY&quot; | jq -c\r\n```\r\nI want the output from the code above to be a json array, such as for 3 elements:\r\n```\r\n[{&quot;key_1&quot;:1}, {&quot;key_1&quot;:1}, {&quot;key_1&quot;:1}]\r\n```\r\nFor smaller values of ```counter``` this would work but for large values like 10000 this leads to ```parse error``` or ```Aborted (core dumped)```. It seems that the script runs out of memory trying to build large arrays. What could be the reasonable approach to doing this using ```jq```? In this case all the elements are identical, but in my situation the elements (each a json object) are being generated in runtime within the loop such as the following:\r\n```\r\nfor i in $(seq 0 $total_count); do\r\n  OBJECT=$(build_object)\r\n  JSON_ARRAY=$(echo &quot;$JSON_ARRAY&quot; | jq .[$i]+=&quot;$OBJECT&quot;)\r\ndone\r\n```\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/75384637/what-is-the-proper-way-of-growing-a-json-array-using-jq-inside-a-bash-script",
        "title": "What is the proper way of growing a json array using jq inside a bash script?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675868336,
                "post_id": 75387570,
                "comment_id": 133020748,
                "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": 1675868483,
                "post_id": 75387570,
                "comment_id": 133020806,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1675876512,
                "last_edit_date": 1675876512,
                "creation_date": 1675868720,
                "answer_id": 75387707,
                "question_id": 75387570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple [`JOIN` operation](https://stedolan.github.io/jq/manual/#SQL-StyleOperators) could do:\r\n```sh\r\njq -n --argjson data1 &quot;$data1&quot; --argjson data2 &quot;$data2&quot; &#39;\r\n  [JOIN(INDEX($data1[]; .timestamp); $data2[]; .timestamp | @text; add)]\r\n&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;errors&quot;: 51,\r\n    &quot;timestamp&quot;: 1675854900,\r\n    &quot;bookings&quot;: 2984\r\n  },\r\n  {\r\n    &quot;errors&quot;: 90,\r\n    &quot;timestamp&quot;: 1675855200,\r\n    &quot;bookings&quot;: 2967\r\n  }\r\n]\r\n```\r\n\r\n---\r\n&gt; I&#39;m getting this error: `jq: error: JOIN/4 is not defined at &lt;top-level&gt;, line 2:   [JOIN(INDEX($data1[]; .timestamp); $data2[]; .timestamp | @text; add)] jq: 1 compile error`\r\n\r\nYou are probably using an older version of jq. `JOIN` and `INDEX` were introduced in jq 1.6. Either define them yourself by taking their definitions from [source](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L282), or take those definitions and modify them to fit your very use case (both work well with jq 1.5).\r\n\r\nDefinitions from source:\r\n```sh\r\njq -n --argjson data1 &quot;$data1&quot; --argjson data2 &quot;$data2&quot; &#39;\r\n  def INDEX(stream; idx_expr):\r\n    reduce stream as $row ({}; .[$row | idx_expr | tostring] = $row);\r\n  def JOIN($idx; stream; idx_expr; join_expr):\r\n    stream | [., $idx[idx_expr]] | join_expr;\r\n\r\n  [JOIN(INDEX($data1[]; .timestamp); $data2[]; .timestamp | @text; add)]\r\n&#39;\r\n```\r\n\r\nAdapted to your use case:\r\n```sh\r\njq -n --argjson data1 &quot;$data1&quot; --argjson data2 &quot;$data2&quot; &#39;\r\n  ($data1 | with_entries(.key = (.value.timestamp | @text))) as $ix\r\n  | $data2 | map(. + $ix[.timestamp | @text])\r\n&#39;\r\n```\r\n",
                "title": "Merge two array of objects with common key using jq command"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1675868861,
                "creation_date": 1675868861,
                "answer_id": 75387734,
                "question_id": 75387570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another way to do this is to build a map from timestamps to error counts, and perform a lookup in it.\r\n\r\n```\r\njq -n &#39;\r\n  input as $data1\r\n| input as $data2\r\n| ($data2\r\n   | map({ &quot;key&quot;: (.timestamp | tostring), &quot;value&quot;: .errors }) \r\n   | from_entries\r\n  ) as $errors_by_timestamp\r\n| $data1 | map(.errors = $errors_by_timestamp[(.timestamp | tostring)])\r\n&#39; &lt;&lt;&lt;&quot;$data1 $data2&quot;\r\n```",
                "title": "Merge two array of objects with common key using jq command"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1675870781,
                "creation_date": 1675870781,
                "answer_id": 75388175,
                "question_id": 75387570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By the way, I have trying to this answer from AI since morning and finally it also gave me correct solution this time\r\n\r\n```\r\n#!/bin/bash\r\n\r\ndata1=&#39;[\r\n    { &quot;bookings&quot;: 2984, &quot;timestamp&quot;: 1675854900 },\r\n    { &quot;bookings&quot;: 2967, &quot;timestamp&quot;: 1675855200 }\r\n]&#39;\r\n\r\ndata2=&#39;[\r\n    { &quot;errors&quot;: 51, &quot;timestamp&quot;: 1675854900 },\r\n    { &quot;errors&quot;: 90, &quot;timestamp&quot;: 1675855200 }\r\n]&#39;\r\n\r\ncombined=$(jq -n --argjson d1 &quot;$data1&quot; --argjson d2 &quot;$data2&quot; &#39;\r\n  [ $d1, $d2 ] | transpose[] | group_by(.timestamp) | map(\r\n    reduce .[] as $i ({}; . * $i)\r\n  )\r\n&#39;)\r\n\r\necho &quot;$combined&quot;\r\n```\r\n\r\nJust pasting it here for you guys in case you didn&#39;t think of this method",
                "title": "Merge two array of objects with common key using jq command"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1675887149,
                "creation_date": 1675887149,
                "answer_id": 75391254,
                "question_id": 75387570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In general, if you find `JOIN` a bit tricky to understand or use, then consider using `INDEX` for this type of problem.  In the present case, you could get away with a trivially simple approach, e.g.:\r\n```\r\njq -n --argjson data1 &quot;$data1&quot;  --argjson data2 &quot;$data2&quot; &#39;\r\n  INDEX($data1[]; .timestamp) as $dict\r\n  | $data2 | map( . + $dict[.timestamp|tostring])\r\n```\r\n ",
                "title": "Merge two array of objects with common key using jq command"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1675952227,
                "creation_date": 1675952227,
                "answer_id": 75399919,
                "question_id": 75387570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This last paragraph just caught my attention:\r\n\r\n&gt; Assume that timestamp will always be present and will always have a common value across two datasets. Even the order is same.\r\n\r\nIf this is truly the case then it is reasonable to assume that both arrays have the same length and their items are aligned respectively. Thus, there&#39;s no need to build up a hash-based `INDEX` as accessing the items by their numeric `keys` (positions within the arrays) can already be achieved in constant time.\r\n\r\n```sh\r\njq -n --argjson data1 &quot;$data1&quot; --argjson data2 &quot;$data2&quot; &#39;\r\n  $data1 | [keys[] | $data2[.] + $data1[.]]\r\n&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;errors&quot;: 51,\r\n    &quot;timestamp&quot;: 1675854900,\r\n    &quot;bookings&quot;: 2984\r\n  },\r\n  {\r\n    &quot;errors&quot;: 90,\r\n    &quot;timestamp&quot;: 1675855200,\r\n    &quot;bookings&quot;: 2967\r\n  }\r\n]\r\n```\r\n",
                "title": "Merge two array of objects with common key using jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 0,
        "last_activity_date": 1675952227,
        "creation_date": 1675868176,
        "question_id": 75387570,
        "body_markdown": "I have two datasets:\r\n\r\n```\r\ndata1=&#39;[\r\n    { &quot;bookings&quot;: 2984, &quot;timestamp&quot;: 1675854900 },\r\n    { &quot;bookings&quot;: 2967, &quot;timestamp&quot;: 1675855200 }\r\n]&#39;\r\n\r\ndata2=&#39;[\r\n    { &quot;errors&quot;: 51, &quot;timestamp&quot;: 1675854900 },\r\n    { &quot;errors&quot;: 90, &quot;timestamp&quot;: 1675855200 }\r\n]&#39;\r\n```\r\n\r\nI want the output to be:\r\n```\r\ncombined=&#39;[\r\n    { &quot;errors&quot;: 51, bookings: 2984, &quot;timestamp&quot;: 1675854900 },\r\n    { &quot;errors&quot;: 90, bookings: 2967, &quot;timestamp&quot;: 1675855200 }\r\n]&#39;\r\n```\r\n\r\nCan this be achieved by shell scripting and jq command?\r\n\r\nAssume that timestamp will always be present and will always have a common value across two datasets. Even the order is same.",
        "link": "https://stackoverflow.com/questions/75387570/merge-two-array-of-objects-with-common-key-using-jq-command",
        "title": "Merge two array of objects with common key using jq command"
    },
    {
        "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": 1,
                "creation_date": 1675871122,
                "post_id": 75388052,
                "comment_id": 133021810,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675871500,
                "post_id": 75388052,
                "comment_id": 133021975,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "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": 1,
                "creation_date": 1675871563,
                "post_id": 75388052,
                "comment_id": 133022000,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1675871771,
                "post_id": 75388052,
                "comment_id": 133022085,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1675892039,
                "post_id": 75388052,
                "comment_id": 133028244,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1675871046,
                "creation_date": 1675871046,
                "answer_id": 75388238,
                "question_id": 75388052,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you want the `--argjson` option instead of `--arg`. Compare\r\n\r\n    $ jq --arg k &#39;{&quot;foo&quot;: &quot;bar&quot;}&#39; -n &#39;{x: $k}&#39;\r\n    {\r\n      &quot;x&quot;: &quot;{\\&quot;foo\\&quot;: \\&quot;bar\\&quot;}&quot;\r\n    }\r\n\r\nwith\r\n    \r\n    $ jq --argjson k &#39;{&quot;foo&quot;: &quot;bar&quot;}&#39; -n &#39;{x: $k}&#39;\r\n    {\r\n      &quot;x&quot;: {\r\n        &quot;foo&quot;: &quot;bar&quot;\r\n      }\r\n    }",
                "title": "bash &amp; jq: add attribute with object value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1675926254,
                "last_edit_date": 1675926254,
                "creation_date": 1675871081,
                "answer_id": 75388246,
                "question_id": 75388052,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`--arg` will create a _string_ variable. Use `--argjson` to parse the value as JSON (can be object, array or number).\r\n\r\nFrom the [docs](https://stedolan.github.io/jq/manual/#Invokingjq):\r\n\r\n&gt; ##### `--arg name value`:\r\n&gt; \r\n&gt; This option passes a value to the jq program as a predefined variable.\r\n&gt; If you run jq with `--arg foo bar`, then `$foo` is available in the\r\n&gt; program and has the value `&quot;bar&quot;`. Note that `value` will be treated as a\r\n&gt; string, so `--arg foo 123` will bind `$foo` to `&quot;123&quot;`.\r\n&gt; \r\n&gt; Named arguments are also available to the jq program as `$ARGS.named`.\r\n&gt; \r\n&gt; ##### `--argjson name JSON-text`:\r\n&gt; \r\n&gt; This option passes a JSON-encoded value to the jq program as a\r\n&gt; predefined variable. If you run jq with `--argjson foo 123`, then $foo\r\n&gt; is available in the program and has the value `123`.\r\n\r\nNote that you don&#39;t need multiple invocations of jq, xargs, command substitution or variables (don&#39;t forget to quote all your variables when expanding).\r\n\r\nTo &quot;merge&quot; the contents of two files, read both files with jq and let jq do the work. This avoids all the complications that arise from jumping between jq and shell context. A single line is all that&#39;s needed:\r\n\r\n```\r\njq --slurpfile deps &quot;$dep_file&quot; &#39;. + { devDependencies: $deps[0].devDependencies }&#39; &quot;$source_file&quot; &gt; &quot;$dest_file&quot;\r\n```\r\n\r\nor\r\n\r\n```\r\njq --slurpfile deps &quot;$dep_file&quot; &#39;. + ($deps[0]|{devDependencies})&#39; &quot;$source_file&quot; &gt; &quot;$dest_file&quot;\r\n```\r\n\r\nalternatively (still a one-liner):\r\n\r\n```\r\njq --slurpfile deps &quot;$dev_file&quot; &#39;.devDependencies = $deps[0].devDependencies&#39; &quot;$source_file&quot; &gt; &quot;$dest_file&quot;\r\n```\r\n\r\n[peak&#39;s answer here](https://stackoverflow.com/a/75392237/112968) reminded me of the very useful [`input`](https://stedolan.github.io/jq/manual/v1.6/#input) filter, which can make the program even shorter as it avoids the variable:\r\n\r\n```\r\njq &#39;. + (input|{devDependencies})&#39; &quot;$source_file&quot; &quot;$dep_file&quot; &gt; &quot;$dest_file&quot;\r\n```",
                "title": "bash &amp; jq: add attribute with object value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1675926254,
        "creation_date": 1675870160,
        "question_id": 75388052,
        "body_markdown": "I&#39;m looking for a solution to add a new attribute with a JSON object value into an existing JSON file.\r\n\r\nMy current script: \r\n```shell\r\nif [ ! -f &quot;$src_file&quot; ]; then\r\n  echo &quot;Source file $src_file does not exists&quot;\r\n  exit 1\r\nfi\r\nif [ ! -f &quot;$dst_file&quot; ]; then\r\n  echo &quot;Destination file $dst_file does not exists&quot;\r\n  exit 1\r\nfi\r\n\r\nif ! jq &#39;.devDependencies&#39; &quot;$src_file&quot; &gt;/dev/null 2&gt;&amp;1; then\r\n  echo &quot;The key &quot;devDependencies&quot; does not exists into source file $src_file&quot;\r\n  exit 1\r\nfi\r\n\r\ndev_dependencies=$(jq &#39;.devDependencies&#39; &quot;$src_file&quot; | xargs )\r\n\r\n# Extract data from source file\r\ndata=$(cat $src_file)\r\n\r\n# Add new key-value\r\ndata=$(echo $data | jq --arg key &quot;devDependencies&quot; --arg value &quot;$dev_dependencies&quot; &#39;. + {($key): ($value)}&#39;)\r\n\r\n# Write data into destination file\r\necho $data &gt; $dst_file\r\n```\r\n\r\nIt&#39;s working but the `devDependencies` value from `$dev_dependencies` is wrote as string:\r\n\r\n`&quot;devDependencies&quot;: &quot;{ @nrwl/esbuild: 15.6.3, @nrwl/eslint-pl[...]&quot;`.\r\n\r\nHow can I write it as raw JSON ?",
        "link": "https://stackoverflow.com/questions/75388052/bash-jq-add-attribute-with-object-value",
        "title": "bash &amp; jq: add attribute with object value"
    },
    {
        "tags": [
            "arrays",
            "json",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1677013809,
                "last_edit_date": 1677013809,
                "creation_date": 1675889381,
                "answer_id": 75391591,
                "question_id": 75391528,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Close enough. Use [`length`](https://stedolan.github.io/jq/manual/v1.6/#length) to get the length of an array.\r\n\r\n```\r\n$ jq -r &#39;\r\n[&quot;Value1&quot;, &quot;Value2&quot;, &quot;count&quot;],\r\n(.[] | [.value1, .value2, (.nArray|length)])\r\n| @csv&#39; input.json\r\n&quot;Value1&quot;,&quot;Value2&quot;,&quot;count&quot;\r\n&quot;Data1-0&quot;,&quot;Data2-0&quot;,3\r\n&quot;Data1-1&quot;,&quot;Data2-1&quot;,2\r\n$ jq -r &#39;\r\n[&quot;Value1&quot;, &quot;Value2&quot;, &quot;count&quot;],\r\n(.[] | [.value1, .value2] + [.nArray|length])\r\n| @csv&#39; input.json\r\n&quot;Value1&quot;,&quot;Value2&quot;,&quot;count&quot;\r\n&quot;Data1-0&quot;,&quot;Data2-0&quot;,3\r\n&quot;Data1-1&quot;,&quot;Data2-1&quot;,2\r\n```",
                "title": "JQ adding count of nested array objects to CSV"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1675894223,
                "creation_date": 1675894223,
                "answer_id": 75392242,
                "question_id": 75391528,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the data is like the one in your post (no double quotes or comma in Values), then :\r\n\r\n```\r\n#!/usr/bin/env bash\r\n    \r\njq -r &#39;[&quot;Value1&quot;, &quot;Value2&quot;, &quot;Value3&quot;, &quot;nArrayCount&quot;],\r\n       (.[] | [.value1, .value2, .value3, (.nArray|length)])\r\n       | join(&quot;,&quot;)&#39; input.json\r\n```",
                "title": "JQ adding count of nested array objects to CSV"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1677013809,
        "creation_date": 1675888995,
        "last_edit_date": 1675889366,
        "question_id": 75391528,
        "body_markdown": "Working with a nested arrays like this:\r\n\r\n    [\r\n    \t{\r\n    \t\t&quot;value1&quot;: &quot;Data1-0&quot;,\r\n    \t\t&quot;value2&quot;: &quot;Data2-0&quot;,\r\n    \t\t&quot;nArray&quot;: [\r\n    \t\t\t{&quot;nValue1&quot;: &quot;nData1-0a&quot;,&quot;nValue2&quot;: &quot;nData2-0a&quot;},\r\n    \t\t\t{&quot;nValue1&quot;: &quot;nData1-0b&quot;,&quot;nValue2&quot;: &quot;nData2-0a&quot;},\r\n    \t\t\t{&quot;nValue1&quot;: &quot;nData1-0c&quot;,&quot;nValue2&quot;: &quot;nData2-0a&quot;}\r\n    \t\t],\r\n    \t\t&quot;value3&quot;: &quot;Data3-0&quot;\r\n    \t},\r\n    \t{\r\n    \t\t&quot;value1&quot;: &quot;Data1-1&quot;,\r\n    \t\t&quot;value2&quot;: &quot;Data2-1&quot;,\r\n    \t\t&quot;nArray&quot;: [\r\n    \t\t\t{&quot;nValue1&quot;: &quot;nData1-1a&quot;,&quot;nValue2&quot;: &quot;nData2-1a&quot;},\r\n    \t\t\t{&quot;nValue1&quot;: &quot;nData1-1b&quot;,&quot;nValue2&quot;: &quot;nData2-1a&quot;}\r\n    \t\t],\r\n    \t\t&quot;value3&quot;: &quot;Data3-1&quot;\r\n    \t}\r\n    ]\r\n\r\nDesired output is CSV format like this:\r\n\r\n```\r\nValue1,Value2,nArrayCount\r\nData1-0,Data2-0,Data3-0,3\r\nData1-1,Data2-1,Data3-1,2\r\n```\r\nI was able to get the nested values but that produces multiple rows for each nArray value with this:\r\n\r\n    [.[] | [.value1,.value2,.value3] + (.nArray[]? | [.nValue1]) ] | .[] | @csv\r\n\r\nAll I need is a count. ",
        "link": "https://stackoverflow.com/questions/75391528/jq-adding-count-of-nested-array-objects-to-csv",
        "title": "JQ adding count of nested array objects to CSV"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1675891987,
                "creation_date": 1675891987,
                "answer_id": 75391974,
                "question_id": 75391973,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`+` or `*` can be used here, correct. Let&#39;s first see how `+` works:\r\n\r\n```\r\n$ jq -n &#39;{a:1,b:2} + {b:3,c:4}&#39;\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 3,\r\n  &quot;c&quot;: 4\r\n}\r\n```\r\n\r\n* Properties only present in the left object are kept\r\n* Properties of the right object overwrite properties of the left object\r\n* Properties only present in the right object are added\r\n\r\nPerfect, now how to get the objects from two unrelated files? [`--slurpfile`](https://stedolan.github.io/jq/manual/v1.6/#Invokingjq) can be used, which reads all JSON entities in the file into an array and puts it into a variable.\r\n\r\n```\r\n$ jq --slurpfile b b.json &#39;. + $b[0]&#39; a.json\r\n{\r\n  &quot;id&quot;: &quot;ZGVhZGJlZWY=&quot;,\r\n  &quot;name&quot;: &quot;fake name&quot;,\r\n  &quot;version&quot;: 2,\r\n  &quot;description&quot;: &quot;just a simple json file&quot;,\r\n  &quot;dependencies&quot;: [\r\n    4,\r\n    2\r\n  ],\r\n  &quot;comment&quot;: &quot;I&#39;m just sitting here, ignore me&quot;\r\n}\r\n```\r\n\r\nWe are getting closer, but are not quite there yet. `name` is overwritten and `comment` is added; both of which we do not want. To solve this, we can transform the slurped object into a new object which only contains the properties we care about\r\n\r\n```\r\n$ jq --slurpfile b b.json &#39;. + ($b[0] | {version,dependencies})&#39; a.json\r\n{\r\n  &quot;id&quot;: &quot;ZGVhZGJlZWY=&quot;,\r\n  &quot;name&quot;: &quot;first file&quot;,\r\n  &quot;version&quot;: 2,\r\n  &quot;description&quot;: &quot;just a simple json file&quot;,\r\n  &quot;dependencies&quot;: [\r\n    4,\r\n    2\r\n  ]\r\n}\r\n```\r\n\r\n*****\r\n\r\nNow let&#39;s address part two of the question: &quot;can some properties of the first file be dropped?&quot;\r\n\r\nThere are basically two options:\r\n\r\n1. Creating a new object containing only the required properties and then adding the second object (any property part of the second file can be ignored, since it will be added anyway): `{id,name} + ($b[0] | {version,dependencies})`\r\n2. Deleting the unneeded properties: `del(.description) + ($b[0] | {version,dependencies})` or `. + ($b[0] | {version,dependencies}) | del(.description)`\r\n\r\nDepending on the number of properties you want to keep/drop, one or the other solution might be simpler to use. Creating a new object has the advantage of being able to rename properties in one go.\r\n\r\nExecuting solution 2:\r\n\r\n```\r\n$ jq --slurpfile b b.json &#39;del(.description) + ($b[0] | {version,dependencies})&#39; a.json\r\n{\r\n  &quot;id&quot;: &quot;ZGVhZGJlZWY=&quot;,\r\n  &quot;name&quot;: &quot;first file&quot;,\r\n  &quot;version&quot;: 2,\r\n  &quot;dependencies&quot;: [\r\n    4,\r\n    2\r\n  ]\r\n}\r\n```",
                "title": "Transfer or merge only some properties from one JSON file to another with jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1675894573,
                "last_edit_date": 1675894573,
                "creation_date": 1675894184,
                "answer_id": 75392237,
                "question_id": 75391973,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want simplicity, brevity, and efficiency, consider:\r\n```\r\njq &#39;. + (input|{version, dependencies})&#39; a.json b.json\r\n```\r\n\r\nIf the first file might have .dependencies, and if in that case you want to add in the second file&#39;s:\r\n```\r\njq &#39;. as $a | input as $b | $a + ($b|{version}) | .dependencies += $b.dependencies&#39;\r\n```\r\n\r\nTo drop .description, you could append `| del(.description)` to either of these filters.",
                "title": "Transfer or merge only some properties from one JSON file to another with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1675926027,
        "creation_date": 1675891987,
        "last_edit_date": 1675926027,
        "question_id": 75391973,
        "body_markdown": "I have two JSON files:\r\n\r\n```\r\n$ jq . a.json b.json \r\n{\r\n  &quot;id&quot;: &quot;ZGVhZGJlZWY=&quot;,\r\n  &quot;name&quot;: &quot;first file&quot;,\r\n  &quot;version&quot;: 1,\r\n  &quot;description&quot;: &quot;just a simple json file&quot;\r\n}\r\n{\r\n  &quot;version&quot;: 2,\r\n  &quot;name&quot;: &quot;fake name&quot;,\r\n  &quot;dependencies&quot;: [\r\n    4,\r\n    2\r\n  ],\r\n  &quot;comment&quot;: &quot;I&#39;m just sitting here, ignore me&quot;\r\n}\r\n```\r\n\r\nand want to merge them into a single file (think of file 1 as &quot;template&quot; and file 2 as &quot;actual values&quot;). I don&#39;t want to merge all properties, I only want to transfer some properties of the second file (specifically only `version` and `dependencies`). `version` should overwrite the value in the original file and `dependencies` should be added to the new file. `name` must not be overwritten and the original name must be kept.\r\n\r\nThis is the expected result:\r\n\r\n```\r\n{\r\n  &quot;id&quot;: &quot;ZGVhZGJlZWY=&quot;,\r\n  &quot;name&quot;: &quot;first file&quot;,\r\n  &quot;version&quot;: 2,\r\n  &quot;description&quot;: &quot;just a simple json file&quot;,\r\n  &quot;dependencies&quot;: [\r\n    4,\r\n    2\r\n  ]\r\n}\r\n```\r\n\r\nI know that jq supports the `+` and `*` operators to merge or merge recursively, but how can I apply those to only some properties and not all? How can I access both files in my jq program; do I have to preprocess the file and then use `--arg` in a second jq call?\r\n\r\nObviously, `jq &#39;. + {version, dependencies}&#39; a.json b.json` does not work. What is the correct program here?\r\n\r\nWhat would the solution look like if `description` should also be dropped from the output?",
        "link": "https://stackoverflow.com/questions/75391973/transfer-or-merge-only-some-properties-from-one-json-file-to-another-with-jq",
        "title": "Transfer or merge only some properties from one JSON file to another with jq"
    },
    {
        "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": 1675978285,
                "post_id": 75403756,
                "comment_id": 133049850,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1675972979,
                "creation_date": 1675972979,
                "answer_id": 75403864,
                "question_id": 75403756,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the [update operator](https://stedolan.github.io/jq/manual/#Update-assignment%3A%7C%3D) `|=` to update the field in question. For the conditional just compare to `null`.\r\n```sh\r\njq &#39;.timeout |= if . == null then 200 else . end&#39;\r\n```\r\n\r\nIf your input file is\r\n```json\r\n{  \r\n  &quot;timeout&quot;: 100\r\n}\r\n```\r\nit will stay the same, as `.timeout` is not `null`. But if it is\r\n```json\r\n{  \r\n  &quot;timeout&quot;: null\r\n}\r\n```\r\nthen it will be changed to the default value given, here:\r\n```json\r\n{  \r\n  &quot;timeout&quot;: 200\r\n}\r\n```\r\nNote that this only triggers for the content of `null`. There are other means to test for `false`, the number zero `0`, the empty string `&quot;&quot;`, etc., even the complete absence of that field.",
                "title": "How to validate fields with if conditional in jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1675985982,
                "creation_date": 1675985982,
                "answer_id": 75405577,
                "question_id": 75403756,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try alternative operator `//`\r\n\r\n```\r\njq &#39;.timeout //= 200&#39; file.json\r\n```",
                "title": "How to validate fields with if conditional in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1675985982,
        "creation_date": 1675972358,
        "question_id": 75403756,
        "body_markdown": "I am validating a json file, I need to validate in a field that if it is null, assign a default value, I can&#39;t find how to perform a validation with if conditional\r\n\r\n```\r\nfile.json\r\n```\r\n\r\n```\r\n{  \r\n    &quot;timeout&quot;: 100\r\n}\r\n```\r\n\r\n```\r\njq -r .timeout fiile.json\r\n```\r\n\r\nhere it prints the value correctly, I need to validate if this field is null to assign it a default value with jq\r\n\r\nThanks in advance",
        "link": "https://stackoverflow.com/questions/75403756/how-to-validate-fields-with-if-conditional-in-jq",
        "title": "How to validate fields with if conditional in jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1675999348,
                "creation_date": 1675999348,
                "answer_id": 75406624,
                "question_id": 75406356,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for this:\r\n``` sh\r\njq -r &#39;.Metrics[] | [.Namespace, .MetricName] + (.Dimensions | map(&quot;\\(.Name):\\(.Value)&quot;)) | join(&quot;|&quot;)&#39; input.json\r\n```",
                "title": "Flattening a nested json while printing outer json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1675999348,
        "creation_date": 1675995707,
        "last_edit_date": 1675996037,
        "question_id": 75406356,
        "body_markdown": "I have a file like below (excerpt)\r\n```\r\ncat input.json\r\n{\r\n    &quot;Metrics&quot;: [\r\n        {\r\n            &quot;Namespace&quot;: &quot;CWAgent&quot;,\r\n            &quot;MetricName&quot;: &quot;disk_used_percent&quot;,\r\n            &quot;Dimensions&quot;: [\r\n                {\r\n                    &quot;Name&quot;: &quot;path&quot;,\r\n                    &quot;Value&quot;: &quot;/aem&quot;\r\n                },\r\n                {\r\n                    &quot;Name&quot;: &quot;host&quot;,\r\n                    &quot;Value&quot;: &quot;uat2-author01.uat.cloud.abc.com.au&quot;\r\n                },\r\n                {\r\n                    &quot;Name&quot;: &quot;device&quot;,\r\n                    &quot;Value&quot;: &quot;mapper/aem-aem&quot;\r\n                },\r\n                {\r\n                    &quot;Name&quot;: &quot;fstype&quot;,\r\n                    &quot;Value&quot;: &quot;ext4&quot;\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;Namespace&quot;: &quot;CWAgent&quot;,\r\n            &quot;MetricName&quot;: &quot;mem_used_percent&quot;,\r\n            &quot;Dimensions&quot;: [\r\n                {\r\n                    &quot;Name&quot;: &quot;host&quot;,\r\n                    &quot;Value&quot;: &quot;uat2-dispatch02.uat.cloud.abc.com.au&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\nAs you can see the &quot;Dimensions&quot; is a list of json objects of varying length. I am required to print each objects under &quot;Metrics&quot; in a single line like below -\r\n```\r\nCWAgent|disk_used_percent|path:/aem|host:uat2-author01.uat.cloud.abc.com.au|device:mapper/aem-aem|fstype:ext4\r\nCWAgent|mem_used_percent|host:uat2-dispatch02.uat.cloud.abc.com.au\r\n```\r\n\r\nI used this -\r\n```\r\ncat input.json | jq -r &quot;.Metrics[] | .Namespace + \\&quot;|\\&quot; + .MetricName + \\&quot;|\\&quot; + (.Dimensions[] | .Name + \\&quot;:\\&quot; + .Value + \\&quot;|\\&quot;)&quot;\r\n```\r\n\r\nAnd the output is like below:\r\n```\r\nCWAgent|disk_used_percent|path:/aem|\r\nCWAgent|disk_used_percent|host:uat2-author01.uat.cloud.abc.com.au|\r\nCWAgent|disk_used_percent|device:mapper/aem-aem|\r\nCWAgent|disk_used_percent|fstype:ext4|\r\nCWAgent|mem_used_percent|host:uat2-dispatch02.uat.cloud.abc.com.au|\r\n```\r\n\r\nAs you can see, we are getting 4 lines for first object each having different object under Dimensions. Can anyone please suggest what will be the jq command to get desired output. I am novice in jq and wasted too much time on this experimenting.\r\n\r\nThanks,\r\nBijitesh\r\n",
        "link": "https://stackoverflow.com/questions/75406356/flattening-a-nested-json-while-printing-outer-json-using-jq",
        "title": "Flattening a nested json while printing outer json using jq"
    },
    {
        "tags": [
            "unix",
            "curl",
            "cmd",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1676024156,
                "creation_date": 1676024156,
                "answer_id": 75409685,
                "question_id": 75409608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `index` for testing if a string contains another.\r\n``` sh\r\njq -r &#39;.log[].message.message | select(index(&quot;DHCPREQUEST&quot;))&#39;\r\n```",
                "title": "Parse JSON in cURL query"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1676024156,
        "creation_date": 1676023770,
        "question_id": 75409608,
        "body_markdown": "I&#39;ve got JSON from cURL:\r\n\r\n    {\r\n      &quot;log&quot;: {\r\n        &quot;52911&quot;: {\r\n          &quot;message&quot;: {\r\n            &quot;level&quot;: &quot;Info&quot;,\r\n            &quot;label&quot;: &quot;I&quot;,\r\n            &quot;message&quot;: &quot;DHCPREQUEST received (STATE_RENEWING) for 192.168.0.12 from b1:00:00:02:e1:2f. &quot;\r\n          },\r\n          &quot;timestamp&quot;: &quot;Feb 10 13:06:14&quot;,\r\n          &quot;ident&quot;: &quot;ndhcps&quot;,\r\n          &quot;id&quot;: 52911\r\n        },\r\n        &quot;52912&quot;: {\r\n          &quot;message&quot;: {\r\n            &quot;level&quot;: &quot;Info&quot;,\r\n            &quot;label&quot;: &quot;I&quot;,\r\n            &quot;message&quot;: &quot;sending ACK of 192.168.0.12 to b1:00:00:02:e1:2f. &quot;\r\n          },\r\n          &quot;timestamp&quot;: &quot;Feb 10 13:06:14&quot;,\r\n          &quot;ident&quot;: &quot;ndhcps&quot;,\r\n          &quot;id&quot;: 52912\r\n        }\r\n      }\r\n    }\r\n\r\n \r\n\r\nHow to filter all messages with pattern &quot;DHCPREQUEST&quot; in comand line?\r\n\r\nI&#39;d tryed `| jq -r &#39;.logs | .[].message.message | select(.!=&quot;DHCPREQUEST&quot;)&#39;`, it didn&#39;t work.\r\n\r\nThe result I need to get is: `DHCPREQUEST received (STATE_RENEWING) for 192.168.0.12 from b1:00:00:02:e1:2f.`\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75409608/parse-json-in-curl-query",
        "title": "Parse JSON in cURL query"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1676045253,
                "post_id": 75412631,
                "comment_id": 133064617,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1676045420,
                "last_edit_date": 1676045420,
                "creation_date": 1676045026,
                "answer_id": 75413447,
                "question_id": 75412631,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `.C` array and the `$update` array both have arrays as items. You need to consider their first item to be a unique key, so that clashes can lead to overwrites. One way could be turning them into an `INDEX` object first, then `add` up those, and retrieve their items back into an array:\r\n```sh\r\njq --argjson val &quot;$update&quot; &#39;.C |= [[., $val | INDEX(.[0])] | add[]]&#39; test_data.json\r\n```\r\n```json\r\n{\r\n  &quot;A&quot;: &quot;12&quot;,\r\n  &quot;B&quot;: &quot;34&quot;,\r\n  &quot;C&quot;: [\r\n    [\r\n      &quot;X&quot;,\r\n      &quot;test1&quot;\r\n    ],\r\n    [\r\n      &quot;Y&quot;,\r\n      &quot;test2&quot;\r\n    ],\r\n    [\r\n      &quot;Z&quot;,\r\n      &quot;test4&quot;\r\n    ],\r\n    [\r\n      &quot;D&quot;,\r\n      &quot;test5&quot;\r\n    ],\r\n    [\r\n      &quot;E&quot;,\r\n      &quot;test6&quot;\r\n    ]\r\n  ]\r\n}\r\n```",
                "title": "How to update the value of the item in an array if it exists in json using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1676049236,
        "creation_date": 1676040455,
        "last_edit_date": 1676049236,
        "question_id": 75412631,
        "body_markdown": "I have a Json file which I want to update using `jq`. I am working on Ubuntu with `jq-1.6`\r\n\r\n    test_data.json\r\n\r\n```\r\n{\r\n\t&quot;A&quot;: &quot;12&quot;,\r\n\t&quot;B&quot;: &quot;34&quot;,\r\n\t&quot;C&quot;: [\r\n\t\t[&quot;X&quot;, &quot;test1&quot;],\r\n\t\t[&quot;Y&quot;, &quot;test2&quot;],\r\n\t\t[&quot;Z&quot;, &quot;test3&quot;]\r\n\t]\r\n}\r\n```\r\n\r\nNow I want to update array `C` with new key:value pair. But, if the any of the key already exists then it&#39;s value should be updated.\r\n```\r\nupdate=&#39;[\r\n\t[&quot;Z&quot;, &quot;test4&quot;],\r\n\t[&quot;D&quot;, &quot;test5&quot;],\r\n\t[&quot;E&quot;, &quot;test6&quot;]\r\n\t]&#39;\r\n```\r\nIn this case the item `Z` already exists in `test_data.json` but `update` has new value for the item.\r\n\r\nExpected output:\r\n```\r\n{\r\n\t&quot;A&quot;: &quot;12&quot;,\r\n\t&quot;B&quot;: &quot;34&quot;,\r\n\t&quot;C&quot;: [\r\n\t\t[&quot;X&quot;, &quot;test1&quot;],\r\n\t\t[&quot;Y&quot;, &quot;test2&quot;],\r\n\t\t[&quot;Z&quot;, &quot;test4&quot;],\r\n\t\t[&quot;D&quot;, &quot;test5&quot;],\r\n\t\t[&quot;E&quot;, &quot;test6&quot;]\r\n\t]\r\n}\r\n```\r\n\r\nSo far, I could do \r\n\r\n    cat test_data.json | jq --argjson val &quot;${update}&quot; &#39;.C += $val&#39;)\r\n\r\nBut this is not updating value for item `Z`, instead adding new entry.\r\n\r\nCan anyone please let me know how to resolve this?\r\n\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/75412631/how-to-update-the-value-of-the-item-in-an-array-if-it-exists-in-json-using-jq",
        "title": "How to update the value of the item in an array if it exists in json using jq?"
    },
    {
        "tags": [
            "javascript",
            "node.js",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1676044572,
                "creation_date": 1676044572,
                "answer_id": 75413385,
                "question_id": 75413221,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could traverse the document tree using `..`, filter for `objects`, and `select` by all your filters. Wrap that in array brackets to get an array.\r\n```sh\r\n[.. | objects | select(\r\n  (has(&quot;contentType&quot;) | not) and has(&quot;id&quot;) and (.id | startswith(&quot;BT&quot;))\r\n).id]\r\n```\r\n```json\r\n[\r\n  &quot;BT-03&quot;,\r\n  &quot;BT-Care&quot;,\r\n  &quot;BT-10&quot;\r\n]\r\n```\r\nUse the `-c` flag to have the array printed in one single line: `[&quot;BT-03&quot;,&quot;BT-Care&quot;,&quot;BT-10&quot;]`",
                "title": "jq : how to extract attribute value from JSON conditionally"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1676044572,
        "creation_date": 1676043696,
        "last_edit_date": 1676043843,
        "question_id": 75413221,
        "body_markdown": "I&#39;m trying to extract all the IDs (`id`) of objects without the `contentType` attribute from the following `JSON`:\r\n\r\n```\r\n    {\r\n       &quot;version&quot;:&quot;1.5.0&quot;,\r\n       &quot;metadata&quot;:{\r\n          &quot;version&quot;:&quot;1.5.0&quot;,\r\n          &quot;createdOn&quot;:&quot;2023-01-01&quot;\r\n       },\r\n       &quot;fileId&quot;:&quot;1&quot;,\r\n       &quot;CanBeAnyName&quot;:[\r\n          {\r\n             &quot;id&quot;:&quot;BT-02&quot;,\r\n             &quot;contentType&quot;:&quot;file&quot;,\r\n             &quot;readOnly&quot;:true\r\n          },\r\n          {\r\n             &quot;id&quot;:&quot;BT-03&quot;,\r\n             &quot;readOnly&quot;:true\r\n          }\r\n       ],\r\n       &quot;AlsoCanBeAnyName&quot;:[\r\n          {\r\n             &quot;id&quot;:&quot;BT&quot;,\r\n             &quot;contentType&quot;:&quot;empty&quot;\r\n          },\r\n          {\r\n             &quot;contentType&quot;:&quot;group&quot;,\r\n             &quot;content&quot;:[\r\n                {\r\n                   &quot;id&quot;:&quot;BT-Care&quot;,\r\n                   &quot;_repeatable&quot;:true,\r\n                   &quot;content&quot;:[\r\n                      {\r\n                         &quot;id&quot;:&quot;BT-90-care&quot;,\r\n                         &quot;contentType&quot;:&quot;group&quot;,\r\n                         &quot;content&quot;:[\r\n                            {\r\n                               &quot;id&quot;:&quot;GR-300-analyze&quot;,\r\n                               &quot;contentType&quot;:&quot;field&quot;\r\n                            },\r\n                            {\r\n                               &quot;id&quot;:&quot;BT-10&quot;\r\n                            }\r\n                         ]\r\n                      }\r\n                   ]\r\n                }\r\n             ]\r\n          }\r\n       ]\r\n    }\r\n```\r\nThe jq command I&#39;m using at the moment is:\r\n```\r\nwalk(if (type == &quot;object&quot; and .id) then if ((.id | startswith(&quot;BT&quot;)) and has(&quot;contentType&quot;) | not) then .id else empty end else . end)\r\n```\r\n\r\nResult: \r\n```\r\n    {\r\n      &quot;version&quot;: &quot;1.5.0&quot;,\r\n      &quot;metadata&quot;: {\r\n        &quot;version&quot;: &quot;1.5.0&quot;,\r\n        &quot;createdOn&quot;: &quot;2023-01-01&quot;\r\n      },\r\n      &quot;fileId&quot;: &quot;1&quot;,\r\n      &quot;CanBeAnyName&quot;: [\r\n        &quot;BT-03&quot;\r\n      ],\r\n      &quot;AlsoCanBeAnyName&quot;: [\r\n        {\r\n          &quot;contentType&quot;: &quot;group&quot;,\r\n          &quot;content&quot;: [\r\n            &quot;BT-Care&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n```\r\nExpected result:\r\n\r\n`[&quot;BT-03&quot;, &quot;BT-Care&quot;]` or even better to iterate down in the nested object `[&quot;BT-03&quot;, &quot;BT-Care&quot;, &quot;BT-10&quot;]`\r\n\r\nHow can I achieve this, please?\r\nThanks! ",
        "link": "https://stackoverflow.com/questions/75413221/jq-how-to-extract-attribute-value-from-json-conditionally",
        "title": "jq : how to extract attribute value from JSON conditionally"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5425221,
                    "reputation": 37827,
                    "user_id": 7366100,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/139c7d4589b263c62cb63692b913fde0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "markp-fuso",
                    "link": "https://stackoverflow.com/users/7366100/markp-fuso"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1676055737,
                "post_id": 75415079,
                "comment_id": 133067574,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "reply_to_user": {
                    "account_id": 5425221,
                    "reputation": 37827,
                    "user_id": 7366100,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/139c7d4589b263c62cb63692b913fde0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "markp-fuso",
                    "link": "https://stackoverflow.com/users/7366100/markp-fuso"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1676059662,
                "post_id": 75415079,
                "comment_id": 133068465,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1676058573,
                "last_edit_date": 1676058573,
                "creation_date": 1676056228,
                "answer_id": 75415210,
                "question_id": 75415079,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As already [commented by markp-fuso](https://stackoverflow.com/questions/75415079/when-creating-a-variable-from-command-output-bash-removes-a-backslash-from-the#comment133067574_75415079):\r\n\r\nIt looks like your `echo` command is interpreting the backslashes. You can confirm this by running `echo &#39;a\\\\b&#39;` and looking at the output.\r\n\r\nThe portable way to deal with such problems is to use `printf` instead of `echo`:\r\n\r\n    printf %s\\\\n &quot;$iteration&quot;\r\n",
                "title": "When creating a variable from command output, Bash removes a backslash from the JSON. How do I make it keep both backslashes to maintain valid JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1676058573,
        "creation_date": 1676055252,
        "question_id": 75415079,
        "body_markdown": "I&#39;m doing the following to capture some ADO JSON data:\r\n\r\n    iteration=&quot;$(az boards iteration team list --team Test --project Test --timeframe current)&quot;\r\n\r\nNormally, the output of that command contains a JSON key/value pair like the following:\r\n\r\n    &quot;path&quot;: &quot;Test\\\\Sprint1&quot;\r\n\r\nBut after capturing the STDOUT into that iteration variable, if I do\r\n\r\n    echo &quot;$iteration&quot;\r\nThat key/value pair becomes\r\n\r\n    &quot;path&quot;: &quot;Test\\Sprint1&quot;\r\nAnd if I attempt to use jq on that output, it breaks because it&#39;s not recognized as valid JSON any longer. I&#39;m very unfamiliar with Bash. How can I get that JSON to remain valid all the way through?",
        "link": "https://stackoverflow.com/questions/75415079/when-creating-a-variable-from-command-output-bash-removes-a-backslash-from-the",
        "title": "When creating a variable from command output, Bash removes a backslash from the JSON. How do I make it keep both backslashes to maintain valid JSON?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4882324,
                    "reputation": 435,
                    "user_id": 3935715,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/28770ddebe540f0131c9dbac829ce2dc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Korba",
                    "link": "https://stackoverflow.com/users/3935715/korba"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676085958,
                "post_id": 75417863,
                "comment_id": 133072311,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1676104418,
                "post_id": 75417863,
                "comment_id": 133073785,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676104459,
                "post_id": 75417863,
                "comment_id": 133073795,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1676104087,
                "creation_date": 1676104087,
                "answer_id": 75418949,
                "question_id": 75417863,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re off to a good start - but you&#39;d want to use assignment rather than the sort of `{ ... }` syntax like so:\r\n\r\n```sh\r\nnode_info_file=&quot;node_info.json&quot;\r\n\r\nset_status() {\r\n\tlocal value=&quot;$1&quot;\r\n\r\n\tmv -f &quot;$node_info_file&quot; &quot;$node_info_file.tmp&quot;\r\n\r\n    # Set property key with: &#39;.node_bootstrap_status = ...&#39;\r\n\tjq --argjson node_bootstrap_status &quot;$value&quot; &#39;.node_bootstrap_status = $node_bootstrap_status&#39; &quot;$node_info_file.tmp&quot; &gt; &quot;$node_info_file&quot;\r\n\r\n\trm -f &quot;$node_info_file.tmp&quot;\r\n}\r\n\r\n# if node_info.json does NOT exists; create it\r\nif [ ! -f $node_info_file ]; then\r\n\tprintf &#39;%s\\n&#39; &#39;{}&#39; &gt; &quot;$node_info_file&quot;\r\nfi\r\n\r\nset_status true\r\nset_status false\r\n```\r\n\r\n\r\nI tested this with empty JSON, and with other contents, and it worked as expected.\r\n\r\nAlso, make sure you quote `&quot;$node_info_file&quot;` - it&#39;s good practice. If you use ShellCheck then it&#39;ll catch those types of errors for you.",
                "title": "How to update json field using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1676116332,
                "last_edit_date": 1676116332,
                "creation_date": 1676115960,
                "answer_id": 75419970,
                "question_id": 75417863,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try to adapt this version to your needs :\r\n\r\n```\r\n#!/usr/bin/env bash\r\n\r\nexit_code=1\r\nnode_info_file=&quot;/etc/node_info.json&quot;\r\n\r\ntest -f &quot;$node_info_file&quot; || echo {} &gt; &quot;$node_info_file&quot;\r\n[ $exit_code = 0 ] &amp;&amp; status=true || status=false\r\ntmp=$(mktemp)\r\njq --argjson node_bootstrap_status $status &#39;{$node_bootstrap_status}&#39; &quot;$node_info_file&quot; &gt; $tmp\r\nmv $tmp &quot;$node_info_file&quot;\r\n```\r\n\r\nJust a side note, it may not be a good idea to save node_info.json in /etc.",
                "title": "How to update json field using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1676116332,
        "creation_date": 1676084612,
        "last_edit_date": 1676086044,
        "question_id": 75417863,
        "body_markdown": "I have a bootstrap script. After every time it runs, I want to keep track of its exit status in a JSON file. JSON file can have other fields too.\r\n\r\n  **Case 1**: The very first time it runs, JSON file will be created &amp; a field `node_bootstrap_status` with boolean value will be added to it.\r\n\r\n  **Case 2**: In subsequent runs, JSON file will pre-exist. But in this case, I want to update same JSON field `node_bootstrap_status` with the outcome(again boolean).\r\n\r\nI wrote the following bash script. It works for 1st case. In second case however, it ends up deleting everything in pre-existing JSON file.\r\n\r\n```bash\r\nexit_code=1\r\n\r\nnode_info_file=&quot;/etc/node_info.json&quot;\r\n\r\n\r\nif [[ -f $node_info_file ]]; then\r\n  # /etc/node_info.json exists\r\n  echo &quot;${node_info_file} exists&quot;\r\n  if [ $exit_code = 0 ]; then\r\n    cat $node_info_file | jq --argjson node_bootstrap_status true &#39;{&quot;node_bootstrap_status&quot;: $node_bootstrap_status}&#39; &gt; $node_info_file\r\n  else\r\n    cat $node_info_file | jq --argjson node_bootstrap_status false &#39;{&quot;node_bootstrap_status&quot;: $node_bootstrap_status}&#39; &gt; $node_info_file\r\n  fi  \r\nelse\r\n  # /etc/node_info.json does NOT exists\r\n  echo &quot;${node_info_file} does not exist&quot;\r\n  touch ${node_info_file}\r\n  if [ $exit_code = 0 ]; then\r\n    echo &#39;{}&#39; | jq --argjson node_bootstrap_status true &#39;{&quot;node_bootstrap_status&quot;: $node_bootstrap_status}&#39; &gt; $node_info_file\r\n  else\r\n    echo &#39;{}&#39; | jq --argjson node_bootstrap_status false &#39;{&quot;node_bootstrap_status&quot;: $node_bootstrap_status}&#39; &gt; $node_info_file\r\n  fi  \r\nfi\r\n```\r\n\r\nexpected outcome:\r\n```json\r\ncat /etc/node_info.json \r\n{\r\n  &quot;node_bootstrap_status&quot;: true/false,\r\n  &quot;foo&quot;: &quot;bar&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/75417863/how-to-update-json-field-using-jq",
        "title": "How to update json field using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1676112617,
                "post_id": 75419250,
                "comment_id": 133074871,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1676137586,
                "creation_date": 1676137586,
                "answer_id": 75422111,
                "question_id": 75419250,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s assume `myscript` contains following line :\r\n\r\n```\r\necho &quot;I am a computed value out of &lt;$1&gt;&quot;\r\n```\r\n\r\nAs `jq` does not allow to evaluate shell commands, you need something like :\r\n\r\n```\r\n#!/usr/bin/env bash\r\ninput=mappings.json\r\n\r\nalternative-models(){\r\n    local result=&#39;{}&#39; sres\r\n    for id in $(jq -r &#39;.model[].id&#39; $input); do\r\n        model=&quot;$(jq -r --arg id &quot;$id&quot; &#39;.model[]|select(.id==$id).model&#39; $input)&quot;\r\n        amodel=&quot;$(./myscript $model)&quot;\r\n        result=&quot;$(jq --arg id $id --arg amodel &quot;$amodel&quot; &#39;. + { $id: $amodel }&#39; &lt;&lt;&lt; &quot;$result&quot;)&quot;\r\n    done\r\n    echo &quot;$result&quot;\r\n}\r\n\r\njq --argjson amodels &quot;$(alternative-models)&quot; &#39;.model|map({\r\n        id, path, model, &quot;alternative_model&quot;: $amodels[.id] }\r\n)&#39; $input\r\n```\r\n\r\nYour mappings.json is not valid json because of a comma on the `model` line.",
                "title": "Evaluating command inside JQ pipeline"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1676232487,
        "creation_date": 1676108023,
        "last_edit_date": 1676232487,
        "question_id": 75419250,
        "body_markdown": "I&#39;m struggling evaluating a command inside a jq pipeline. Example will make it easier. Let&#39;s imagine I&#39;ve got this simple json\r\n\r\n```\r\n{\r\n\t&quot;model&quot;: [{\r\n\t\t\t&quot;id&quot;: &quot;an-id&quot;,\r\n\t\t\t&quot;path&quot;: [\r\n\t\t\t\t&quot;mypath1.txt&quot;\r\n\t\t\t],\r\n\t\t\t&quot;model&quot;: &quot;foo&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;id&quot;: &quot;an-id2&quot;,\r\n\t\t\t&quot;path&quot;: [\r\n\t\t\t\t&quot;mypath1.txt&quot;\r\n\t\t\t],\r\n\t\t\t&quot;model&quot;: &quot;foo2&quot;\r\n\t\t}\r\n\t]\r\n}\r\n```\r\n\r\nAnd I want to convert into this\r\n\r\n```\r\n {\r\n\t&quot;model&quot;: [{\r\n\t\t\t&quot;id&quot;: &quot;an-id&quot;,\r\n\t\t\t&quot;path&quot;: [\r\n\t\t\t\t&quot;mypath1.txt&quot;\r\n\t\t\t],\r\n\t\t\t&quot;model&quot;: &quot;foo&quot;,\r\n\t\t\t&quot;alternative_model&quot;: &quot;I am a computed value out of &lt;foo&gt;&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;id&quot;: &quot;an-id2&quot;,\r\n\t\t\t&quot;path&quot;: [\r\n\t\t\t\t&quot;mypath1.txt&quot;\r\n\t\t\t],\r\n\t\t\t&quot;model&quot;: &quot;foo2&quot;,\r\n\t\t\t&quot;alternative_model&quot;: &quot;I am a computed value out of &lt;foo2&gt;&quot;\r\n\t\t}\r\n\t]\r\n}\r\n```\r\nI want to do something like this that allows me to delegate computing alternative model to a different bash script.\r\n```\r\n  myNewJson=$(cat mappings.json | jq &#39;[.model[]| {\r\n        id: .id,\r\n        path: .path\r\n        model: .model\r\n        alternative_model: //TODO}&#39; ---&gt; here I&#39;d like to do something like &quot;eval ./myscript $model&quot; \r\n])\r\n```\r\nThanks!",
        "link": "https://stackoverflow.com/questions/75419250/evaluating-command-inside-jq-pipeline",
        "title": "Evaluating command inside JQ pipeline"
    },
    {
        "tags": [
            "json",
            "bash",
            "multidimensional-array",
            "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": 1676110086,
                "post_id": 75419387,
                "comment_id": 133074499,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676110813,
                "post_id": 75419387,
                "comment_id": 133074608,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1676109906,
        "creation_date": 1676109664,
        "last_edit_date": 1676109906,
        "question_id": 75419387,
        "body_markdown": "How to make a bash array from this JSON using jq\r\n```json\r\n[\r\n  {\r\n    &quot;username&quot;: &quot;abc@com&quot;,\r\n    &quot;name&quot;: &quot;ABC&quot;,\r\n    &quot;given_name&quot;: &quot;DotCom&quot;,\r\n    &quot;password&quot;: &quot;iDWtCEKiA#!@345&quot;,\r\n    &quot;email&quot;: &quot;abc@com&quot;\r\n  },\r\n  {\r\n    &quot;username&quot;: &quot;def@com&quot;,\r\n    &quot;name&quot;: &quot;DEF&quot;,\r\n    &quot;given_name&quot;: &quot;DotCom&quot;,\r\n    &quot;password&quot;: &quot;iDWtCEKiA#!@345&quot;,\r\n    &quot;email&quot;: &quot;def@com&quot;\r\n  }\r\n]\r\n```\r\n\r\nI need to get all object values with a loop (3000 objects) so I will be like this : \r\n\r\nindex(0) username: abc.com , name: ABC\r\nindex(1) username: def.com , name: DEF",
        "link": "https://stackoverflow.com/questions/75419387/bash-array-from-json-array",
        "title": "Bash Array from JSON Array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": -1,
                    "reputation": 1,
                    "user_id": -1,
                    "user_type": "moderator",
                    "profile_image": "https://www.gravatar.com/avatar/a007be5a61f6aa8f3e85ae2fc18dd66e?s=256&d=identicon&r=PG",
                    "display_name": "Community",
                    "link": "https://stackoverflow.com/users/-1/community"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676283629,
                "post_id": 75425014,
                "comment_id": 133099314,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1676179635,
                "creation_date": 1676179635,
                "answer_id": 75425075,
                "question_id": 75425014,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The desired output is not JSON, and it would be difficult to produce those non-numeric paths (e.g. 1.2.3). You could obviously add quotation marks to make them strings, but it would be much better to choose a more standard or convenient path representation. \r\n\r\nOther than that, you can rest assured that jq is up to the task, though it would require some expertise in programming generally, or at least fluency with jq.\r\n\r\n",
                "title": "is this even possible with `jq`?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1676179635,
        "creation_date": 1676178763,
        "question_id": 75425014,
        "body_markdown": "I have some JSON data that looks like this\r\n\r\n```\r\n[ \r\n   {Key: &quot;fruits/red/apple&quot;, Value: &quot;Red apples&quot;}, \r\n   {Key:&quot;fruits/green/lime&quot;, Value: &quot;Green Limes&quot;}, \r\n   {Key: &quot;fruits/blue/berries/blueberry&quot;, Value: &quot;Blue Berries&quot;}, \r\n   {Key: &quot;vegetables/red/tomato&quot;, Value: &quot;Red Tomatoes&quot;}, \r\n   {Key: &quot;vegetables/green/cucumber&quot;, Value: &quot;Green Cucumbers&quot;} \r\n]\r\n```\r\n\r\n\r\n\r\nAnd I am trying to extract the data to a nested JSON-tree structure like\r\n\r\n```\r\n{\r\n  &quot;fruits&quot;: {\r\n    &quot;id&quot;: 1,\r\n    &quot;name&quot;: &quot;fruits&quot;,\r\n    &quot;children&quot;: [\r\n       { \r\n          &quot;id&quot;: 2, \r\n          &quot;name&quot;: &quot;red&quot;, \r\n          &quot;path&quot;: 1.2, \r\n          &quot;children&quot;: [ { &quot;id&quot;: 3, &quot;name&quot;: &quot;apple&quot;, &quot;path&quot;: 1.2.3 } ]\r\n       },\r\n       { \r\n          &quot;id: 4, \r\n          &quot;name&quot;: &quot;green&quot;,\r\n          &quot;path&quot;: 1.4, \r\n          &quot;children&quot;: [ {&quot;id&quot;: 5, &quot;name&quot;: &quot;lime&quot;, &quot;path&quot;: 1.4.5} ]\r\n       },\r\n       { \r\n          &quot;id: 6, \r\n          &quot;name&quot;: &quot;blue&quot;, \r\n          &quot;path&quot;: 1.6, \r\n          &quot;children&quot;: [ {&quot;id&quot;: 7, &quot;name&quot;: &quot;berries&quot;, &quot;path&quot;: 1.6.7, &quot;children&quot;: [{...}] } ] \r\n       } \r\n    ]\r\n  },\r\n  &quot;vegetables&quot;: {...}\r\n}\r\n```\r\n\r\n\r\nI am new to jq and have something like this that gives me one level of data, but am lost on how to do running counters and recursion\r\n\r\n```\r\n[ .[] |  { name: .Key, description: .Value, children: ( [.Key | split(&quot;/&quot;)] | .[0] | to_entries ) } ]\r\n```\r\n\r\nappreciate any pointers on this.",
        "link": "https://stackoverflow.com/questions/75425014/is-this-even-possible-with-jq",
        "title": "is this even possible with `jq`?"
    },
    {
        "tags": [
            "format",
            "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": 1,
                "creation_date": 1676218309,
                "post_id": 75428312,
                "comment_id": 133088945,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676218580,
                "post_id": 75428312,
                "comment_id": 133088994,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676221629,
                "post_id": 75428312,
                "comment_id": 133089602,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1103145,
                    "reputation": 15,
                    "user_id": 1095091,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/585b43629b8125fb816248d4e48c4c60?s=256&d=identicon&r=PG",
                    "display_name": "Prateek",
                    "link": "https://stackoverflow.com/users/1095091/prateek"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676255232,
                "post_id": 75428312,
                "comment_id": 133094519,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1676235005,
                "last_edit_date": 1676235005,
                "creation_date": 1676221795,
                "answer_id": 75428726,
                "question_id": 75428312,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use a two-pass approach.  In the first, stringify the field using special markers so that in the second pass, they can be removed. \r\n\r\nDepending on your level of paranoia, this second pass could be very simple or quite complex. On the simple end of the spectrum, choose markers that simply will not occur elsewhere, perhaps `&quot;&lt;q&gt;…&lt;/q&gt;&quot;`, or using some combination of non-ASCII characters.  On the complex end of the spectrum, only remove the markers if they occur in the fields in which they are known to be markers.\r\n\r\nBoth passes could be accomplished with jq, along the lines of:\r\n```\r\njq &#39;.[].datapoints |= &quot;&lt;q&gt;\\(tojson)&lt;/q&gt;&quot;&#39; |\r\njq -Rr &#39;sub(&quot;&lt;q&gt;(?&lt;s&gt;.*)&lt;/q&gt;&quot;; .s)&#39;\r\n```",
                "title": "Custom JSON output formatting with JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1676229838,
                "creation_date": 1676229838,
                "answer_id": 75429595,
                "question_id": 75428312,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq and perl :\r\n\r\n```\r\njq &#39;map(.datapoints |= &quot;\\u001b\\(tojson)\\u001b&quot;)\r\n&#39; test.json |  perl -pe &#39;s/&quot;\\\\u001b(.*?)\\\\u001b&quot;/$1/g&#39;\r\n```",
                "title": "Custom JSON output formatting with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1676235005,
        "creation_date": 1676217948,
        "question_id": 75428312,
        "body_markdown": "I&#39;d like to use `jq` to format the output of some known keys in my objects more succinctly. \r\n\r\nSample object:\r\n```\r\n// test.json\r\n[\r\n  {\r\n    &quot;target&quot;: &quot;some-string&quot;,\r\n    &quot;datapoints&quot;: [\r\n      [\r\n        123,\r\n        456\r\n      ],\r\n      [\r\n        789,\r\n        101112\r\n      ]\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI&#39;d like to use JQ (with some incantation) to change this to put all the `datapoints` objects on a single line. E.g.\r\n\r\n\r\n```\r\n[\r\n  {\r\n    &quot;target&quot;: &quot;some-string&quot;,\r\n    &quot;datapoints&quot;: [[ 123, 456 ], [ 789, 101112 ]]\r\n  }\r\n]\r\n```\r\n\r\nI don&#39;t really know if JQ allows this. I searched around - and found custom formatters like https://www.npmjs.com/package/perfect-json which seem to do what I want. I&#39;d prefer to have a portable incantation for this using `jq` alone (and/or with standard *nix tools).",
        "link": "https://stackoverflow.com/questions/75428312/custom-json-output-formatting-with-jq",
        "title": "Custom JSON output formatting with JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5964120,
                    "reputation": 4797,
                    "user_id": 4688321,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/aa3c9a8b29d3a64f5841a6d511777979?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kiner_shah",
                    "link": "https://stackoverflow.com/users/4688321/kiner-shah"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1676282120,
                "post_id": 75434304,
                "comment_id": 133098881,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1676282840,
                "post_id": 75434304,
                "comment_id": 133099101,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27724181,
                    "reputation": 13,
                    "user_id": 21164092,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0000e4631ce41798500a606a756ca03b?s=256&d=identicon&r=PG",
                    "display_name": "Nepromukk",
                    "link": "https://stackoverflow.com/users/21164092/nepromukk"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1676283307,
                "post_id": 75434304,
                "comment_id": 133099235,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1676283453,
                "post_id": 75434304,
                "comment_id": 133099265,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1676283615,
                "post_id": 75434304,
                "comment_id": 133099306,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676284052,
                "post_id": 75434304,
                "comment_id": 133099403,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676284488,
                "post_id": 75434304,
                "comment_id": 133099529,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676299099,
                "post_id": 75434304,
                "comment_id": 133103847,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1677270019,
                "last_edit_date": 1677270019,
                "creation_date": 1676400052,
                "answer_id": 75452008,
                "question_id": 75434304,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The sample file you have given above is not a valid JSON. Contains non-quoted strings, missing open braces and several missing closing braces. A right one is here (lets suppose is is a file named `duda_jq_stackoverflow.json`.\r\n\r\nIf you execute\r\n\r\n```\r\noscar@toreyes-i7:/tmp$ cat duda_jq_stackoverflow.json\r\n```\r\n\r\nthe shown content is:\r\n\r\n```\r\n{\r\n    &quot;data&quot;: {\r\n         &quot;master.services&quot;: {\r\n             &quot;host1&quot;: [\r\n               {\r\n                 &quot;cert_cn&quot;: &quot;CN=host1-signer1:&quot;,\r\n                 &quot;days_remaining&quot;: 412,\r\n                 &quot;expiry&quot;: &quot;2024-03-18 17:21:41&quot;,\r\n                 &quot;health&quot;: &quot;ok&quot;,\r\n                 &quot;issuer&quot;: &quot;CN=host1-signer1&quot;,\r\n                 &quot;path&quot;: &quot;/etc/host1/ca.crt&quot;,\r\n                 &quot;serial&quot;: &quot;xxxxxxxxxxx&quot;,\r\n                 &quot;serial_hex&quot;: &quot;xxxxxxxx&quot;\r\n               },\r\n               {\r\n                 &quot;cert_cn&quot;: &quot;CN=host1-signer2&quot;,\r\n                 &quot;days_remaining&quot;: 544,\r\n                 &quot;expiry&quot;: &quot;2024-07-28 12:47:50&quot;,\r\n                 &quot;health&quot;: &quot;ok&quot;,\r\n                 &quot;issuer&quot;: &quot;CN=host1-signer2&quot;,\r\n                 &quot;path&quot;: &quot;/etc/host1/server.crt&quot;,\r\n                 &quot;serial&quot;: 12,\r\n                 &quot;serial_hex&quot;: &quot;0xc&quot;\r\n               },\r\n               {\r\n                 &quot;cert_cn&quot;: &quot;CN=host3-signer1&quot;,\r\n                 &quot;days_remaining&quot;: 544,\r\n                 &quot;expiry&quot;: &quot;2024-07-28 12:47:52&quot;,\r\n                 &quot;health&quot;: &quot;ok&quot;,\r\n                 &quot;issuer&quot;: &quot;CN=host3-signer1&quot;,\r\n                 &quot;path&quot;: &quot;/etc/host3/peer.crt&quot;,\r\n                 &quot;serial&quot;: 14,\r\n                 &quot;serial_hex&quot;: &quot;0xe&quot;\r\n               }\r\n             ],\r\n             &quot;host4&quot;: [\r\n               {\r\n                 &quot;cert_cn&quot;: &quot;CN=host4-signer1&quot;,\r\n                 &quot;days_remaining&quot;: 729,\r\n                 &quot;expiry&quot;: &quot;2025-01-29 17:10:11&quot;,\r\n                 &quot;health&quot;: &quot;ok&quot;,\r\n                 &quot;issuer&quot;: &quot;xxxxxxxxxxxxxxxxxxxxxxxxx&quot;,\r\n                 &quot;path&quot;: &quot;/etc/origin/master/admin.host4&quot;,\r\n                 &quot;serial&quot;: 6,\r\n                 &quot;serial_hex&quot;: &quot;0x6&quot;\r\n               }\r\n             ]\r\n         }\r\n    }\r\n}\r\n```\r\n\r\nIf you execute\r\n\r\n```\r\noscar@toreyes-i7:/tmp$ jq &#39;.data[&quot;master.services&quot;]&#39;  duda_jq_stackoverflow.json\r\n```\r\n\r\nyou get the next fragment of the original JSON:\r\n\r\n```json\r\n{\r\n  &quot;host1&quot;: [\r\n    {\r\n      &quot;cert_cn&quot;: &quot;CN=host1-signer1:&quot;,\r\n      &quot;days_remaining&quot;: 412,\r\n      &quot;expiry&quot;: &quot;2024-03-18 17:21:41&quot;,\r\n      &quot;health&quot;: &quot;ok&quot;,\r\n      &quot;issuer&quot;: &quot;CN=host1-signer1&quot;,\r\n      &quot;path&quot;: &quot;/etc/host1/ca.crt&quot;,\r\n      &quot;serial&quot;: &quot;xxxxxxxxxxx&quot;,\r\n      &quot;serial_hex&quot;: &quot;xxxxxxxx&quot;\r\n    },\r\n    {\r\n      &quot;cert_cn&quot;: &quot;CN=host1-signer2&quot;,\r\n      &quot;days_remaining&quot;: 544,\r\n      &quot;expiry&quot;: &quot;2024-07-28 12:47:50&quot;,\r\n      &quot;health&quot;: &quot;ok&quot;,\r\n      &quot;issuer&quot;: &quot;CN=host1-signer2&quot;,\r\n      &quot;path&quot;: &quot;/etc/host1/server.crt&quot;,\r\n      &quot;serial&quot;: 12,\r\n      &quot;serial_hex&quot;: &quot;0xc&quot;\r\n    },\r\n    {\r\n      &quot;cert_cn&quot;: &quot;CN=host3-signer1&quot;,\r\n      &quot;days_remaining&quot;: 544,\r\n      &quot;expiry&quot;: &quot;2024-07-28 12:47:52&quot;,\r\n      &quot;health&quot;: &quot;ok&quot;,\r\n      &quot;issuer&quot;: &quot;CN=host3-signer1&quot;,\r\n      &quot;path&quot;: &quot;/etc/host3/peer.crt&quot;,\r\n      &quot;serial&quot;: 14,\r\n      &quot;serial_hex&quot;: &quot;0xe&quot;\r\n    }\r\n  ],\r\n  &quot;host4&quot;: [\r\n    {\r\n      &quot;cert_cn&quot;: &quot;CN=host4-signer1&quot;,\r\n      &quot;days_remaining&quot;: 729,\r\n      &quot;expiry&quot;: &quot;2025-01-29 17:10:11&quot;,\r\n      &quot;health&quot;: &quot;ok&quot;,\r\n      &quot;issuer&quot;: &quot;xxxxxxxxxxxxxxxxxxxxxxxxx&quot;,\r\n      &quot;path&quot;: &quot;/etc/origin/master/admin.host4&quot;,\r\n      &quot;serial&quot;: 6,\r\n      &quot;serial_hex&quot;: &quot;0x6&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI recommend you to use the `gron` program to get the path you have to use with jq (in the output, remove the initial &quot;json&quot; part of each line).\r\n\r\nYou can get `gron` in https://github.com/tomnomnom/gron\r\n\r\nIf your execute the command\r\n\r\n```\r\noscar@toreyes-i7:/tmp$ gron duda_jq_stackoverflow.json\r\n```\r\n\r\nyou get\r\n\r\n```\r\njson = {};\r\njson.data = {};\r\njson.data[&quot;master.services&quot;] = {};\r\njson.data[&quot;master.services&quot;].host1 = [];\r\njson.data[&quot;master.services&quot;].host1[0] = {};\r\njson.data[&quot;master.services&quot;].host1[0].cert_cn = &quot;CN=host1-signer1:&quot;;\r\njson.data[&quot;master.services&quot;].host1[0].days_remaining = 412;\r\njson.data[&quot;master.services&quot;].host1[0].expiry = &quot;2024-03-18 17:21:41&quot;;\r\njson.data[&quot;master.services&quot;].host1[0].health = &quot;ok&quot;;\r\njson.data[&quot;master.services&quot;].host1[0].issuer = &quot;CN=host1-signer1&quot;;\r\njson.data[&quot;master.services&quot;].host1[0].path = &quot;/etc/host1/ca.crt&quot;;\r\njson.data[&quot;master.services&quot;].host1[0].serial = &quot;xxxxxxxxxxx&quot;;\r\njson.data[&quot;master.services&quot;].host1[0].serial_hex = &quot;xxxxxxxx&quot;;\r\njson.data[&quot;master.services&quot;].host1[1] = {};\r\njson.data[&quot;master.services&quot;].host1[1].cert_cn = &quot;CN=host1-signer2&quot;;\r\njson.data[&quot;master.services&quot;].host1[1].days_remaining = 544;\r\njson.data[&quot;master.services&quot;].host1[1].expiry = &quot;2024-07-28 12:47:50&quot;;\r\njson.data[&quot;master.services&quot;].host1[1].health = &quot;ok&quot;;\r\njson.data[&quot;master.services&quot;].host1[1].issuer = &quot;CN=host1-signer2&quot;;\r\njson.data[&quot;master.services&quot;].host1[1].path = &quot;/etc/host1/server.crt&quot;;\r\njson.data[&quot;master.services&quot;].host1[1].serial = 12;\r\njson.data[&quot;master.services&quot;].host1[1].serial_hex = &quot;0xc&quot;;\r\njson.data[&quot;master.services&quot;].host1[2] = {};\r\njson.data[&quot;master.services&quot;].host1[2].cert_cn = &quot;CN=host3-signer1&quot;;\r\njson.data[&quot;master.services&quot;].host1[2].days_remaining = 544;\r\njson.data[&quot;master.services&quot;].host1[2].expiry = &quot;2024-07-28 12:47:52&quot;;\r\njson.data[&quot;master.services&quot;].host1[2].health = &quot;ok&quot;;\r\njson.data[&quot;master.services&quot;].host1[2].issuer = &quot;CN=host3-signer1&quot;;\r\njson.data[&quot;master.services&quot;].host1[2].path = &quot;/etc/host3/peer.crt&quot;;\r\njson.data[&quot;master.services&quot;].host1[2].serial = 14;\r\njson.data[&quot;master.services&quot;].host1[2].serial_hex = &quot;0xe&quot;;\r\njson.data[&quot;master.services&quot;].host4 = [];\r\njson.data[&quot;master.services&quot;].host4[0] = {};\r\njson.data[&quot;master.services&quot;].host4[0].cert_cn = &quot;CN=host4-signer1&quot;;\r\njson.data[&quot;master.services&quot;].host4[0].days_remaining = 729;\r\njson.data[&quot;master.services&quot;].host4[0].expiry = &quot;2025-01-29 17:10:11&quot;;\r\njson.data[&quot;master.services&quot;].host4[0].health = &quot;ok&quot;;\r\njson.data[&quot;master.services&quot;].host4[0].issuer = &quot;xxxxxxxxxxxxxxxxxxxxxxxxx&quot;;\r\njson.data[&quot;master.services&quot;].host4[0].path = &quot;/etc/origin/master/admin.host4&quot;;\r\njson.data[&quot;master.services&quot;].host4[0].serial = 6;\r\njson.data[&quot;master.services&quot;].host4[0].serial_hex = &quot;0x6&quot;;\r\n```\r\n\r\nIn that output, we can see the format of the paths to be used with `jq`. For example, if I take the line\r\n\r\n```\r\njson.data[&quot;master.services&quot;] = {};\r\n```\r\nand remove the `json` at the beginning and discard everything from `=` onwards, what is left is:\r\n\r\n```\r\n.data[&quot;master.services&quot;]\r\n```\r\n\r\nAnd that is the path to tell `jq` to extract the field value.\r\n\r\nNote that as the field name has a `.` in it, you have to surround the field name with double quotes, and all this, in turn, with square brackets `[` and `]`.\r\n\r\nYou can get the values `host1` and `host4` ejecuting:\r\n\r\n```\r\noscar@toreyes-i7:/tmp$ jq -r &#39;.data[&quot;master.services&quot;] | keys_unsorted | .[]&#39;  duda_jq_stackoverflow.json\r\nhost1\r\nhost4\r\n```\r\n\r\nWith that values, you can compose the paths and make another query using `jq`.\r\n\r\n\r\nOr maybe this can be a starting point to get to what you want to achieve:\r\n\r\n```\r\noscar@toreyes-i7:/tmp$ jq -r &#39;.data[&quot;master.services&quot;][&quot;host1&quot;][] as $nodo | &quot;\\(&quot;cert_cn = &quot; + $nodo.cert_cn + &quot;\\n&quot; + &quot;days_remaining = &quot; +  ($nodo.days_remaining | tostring) + &quot;\\n&quot; + &quot;expiry &quot; + $nodo.expiry + &quot;\\n&quot;)&quot;&#39;  duda_jq_stackoverflow.json\r\ncert_cn = CN=host1-signer1:\r\ndays_remaining = 412\r\nexpiry 2024-03-18 17:21:41\r\n\r\ncert_cn = CN=host1-signer2\r\ndays_remaining = 544\r\nexpiry 2024-07-28 12:47:50\r\n\r\ncert_cn = CN=host3-signer1\r\ndays_remaining = 544\r\nexpiry 2024-07-28 12:47:52\r\n```\r\n\r\nTo execute the next script you have a create a file called `duda_jq_stackoverflow_2.json`, with the contents of your sample JSON:\r\n\r\n```\r\nFICHERO_JSON=duda_jq_stackoverflow_2.json\r\n\r\nfor CLAVE in $(jq -r &#39;. as $datos | .data | keys_unsorted[] | select ( endswith(&quot;.services&quot;) )&#39; $FICHERO_JSON)\r\ndo\r\n    echo ==== $CLAVE =====\r\n    # You have to include here all keys that may contain certificate\r\n    # expiry data, or calculate them in another jq execution\r\n    for CLAVE2 in etcd ocp_certs\r\n    do\r\n         echo &quot;  === BEGIN $CLAVE - $CLAVE2 ====&quot;\r\n         jq -r &quot;.data[\\&quot;$CLAVE\\&quot;].$CLAVE2[] | \\&quot;  cert = \\(.cert_cn)\\&quot;,\\&quot;  days_remaining = \\(.days_remaining)\\&quot;,\\&quot;  expiry = \\(.expiry)\\&quot;,\\&quot;  -----\\&quot; &quot;  $FICHERO_JSON\r\n         echo &quot;  === END   $CLAVE - $CLAVE2 ====&quot;\r\n         echo\r\n    done\r\n    echo ====\r\n    echo\r\ndone\r\n```\r\n\r\nDoes this answer your question?",
                "title": "I need to create a Shell, that utilizes jq to extract some data from a rather large json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1677270019,
        "creation_date": 1676281969,
        "last_edit_date": 1677147434,
        "question_id": 75434304,
        "body_markdown": "So I&#39;m struggling to solve this problem.\r\n\r\nThis is part of the data from the JSON file. The rest of the data is using the same structure.\r\n  ```\r\n    {\r\n    &quot;data&quot;: {\r\n    &quot;infra01.xx.mdk.services&quot;: {\r\n      &quot;etcd&quot;: [],\r\n      &quot;kubeconfigs&quot;: [],\r\n      &quot;meta&quot;: {\r\n        &quot;checked_at_time&quot;: &quot;2023-01-30 18:14:56.013633&quot;,\r\n        &quot;show_all&quot;: &quot;True&quot;,\r\n        &quot;warn_before_date&quot;: &quot;2024-01-30 18:14:56.013633&quot;,\r\n        &quot;warning_days&quot;: 365\r\n      },\r\n      &quot;ocp_certs&quot;: [\r\n        {\r\n          &quot;cert_cn&quot;: &quot;xxxxxxxxx:&quot;,\r\n          &quot;days_remaining&quot;: 1126,\r\n          &quot;expiry&quot;: &quot;2026-03-02 09:49:43&quot;,\r\n          &quot;health&quot;: &quot;ok&quot;,\r\n          &quot;issuer&quot;: &quot;xxxxxxxxx&quot;,\r\n          &quot;path&quot;: &quot;/etc/origin/node/client-ca.crt&quot;,\r\n          &quot;serial&quot;: 1,\r\n          &quot;serial_hex&quot;: &quot;0x1&quot;\r\n        },\r\n        {\r\n          &quot;cert_cn&quot;: &quot;xxxxxxxxx:&quot;,\r\n          &quot;days_remaining&quot;: 1126,\r\n          &quot;expiry&quot;: &quot;2026-03-02 09:49:43&quot;,\r\n          &quot;health&quot;: &quot;ok&quot;,\r\n          &quot;issuer&quot;: &quot;xxxxxxxxx&quot;,\r\n          &quot;path&quot;: &quot;/etc/origin/node/client-ca.crt&quot;,\r\n          &quot;serial&quot;: 1,\r\n          &quot;serial_hex&quot;: &quot;0x1&quot;\r\n        }\r\n      ],\r\n      &quot;registry&quot;: [],\r\n      &quot;router&quot;: []\r\n    },\r\n    &quot;infra02.xx.mdk.services&quot;: {\r\n      &quot;etcd&quot;: [\r\n        {\r\n          &quot;cert_cn&quot;: &quot;xxxxxxxxx:&quot;,\r\n          &quot;days_remaining&quot;: 1126,\r\n          &quot;expiry&quot;: &quot;2026-03-02 09:49:43&quot;,\r\n          &quot;health&quot;: &quot;ok&quot;,\r\n          &quot;issuer&quot;: &quot;xxxxxxxxx&quot;,\r\n          &quot;path&quot;: &quot;/etc/origin/node/client-ca.crt&quot;,\r\n          &quot;serial&quot;: 1,\r\n          &quot;serial_hex&quot;: &quot;0x1&quot;\r\n        }\r\n      ],\r\n      &quot;kubeconfigs&quot;: [],\r\n      &quot;meta&quot;: {\r\n        &quot;checked_at_time&quot;: &quot;2023-01-30 18:14:56.253790&quot;,\r\n        &quot;show_all&quot;: &quot;True&quot;,\r\n        &quot;warn_before_date&quot;: &quot;2024-01-30 18:14:56.253790&quot;,\r\n        &quot;warning_days&quot;: 365\r\n      },\r\n      &quot;ocp_certs&quot;: [\r\n        {\r\n          &quot;cert_cn&quot;: &quot;xxxxxxxxx:&quot;,\r\n          &quot;days_remaining&quot;: 1126,\r\n          &quot;expiry&quot;: &quot;2026-03-02 09:49:43&quot;,\r\n          &quot;health&quot;: &quot;ok&quot;,\r\n          &quot;issuer&quot;: &quot;xxxxxxxxx&quot;,\r\n          &quot;path&quot;: &quot;/etc/origin/node/client-ca.crt&quot;,\r\n          &quot;serial&quot;: 1,\r\n          &quot;serial_hex&quot;: &quot;0x1&quot;\r\n        }\r\n      ],\r\n      &quot;registry&quot;: [],\r\n      &quot;router&quot;: []\r\n    },\r\n    &quot;infra03.xx.mdk.services&quot;: {\r\n      &quot;etcd&quot;: [],\r\n      &quot;kubeconfigs&quot;: [],\r\n      &quot;meta&quot;: {\r\n        &quot;checked_at_time&quot;: &quot;2023-01-30 18:14:56.557721&quot;,\r\n        &quot;show_all&quot;: &quot;True&quot;,\r\n        &quot;warn_before_date&quot;: &quot;2024-01-30 18:14:56.557721&quot;,\r\n        &quot;warning_days&quot;: 365\r\n      },\r\n      &quot;ocp_certs&quot;: [\r\n        {\r\n          &quot;cert_cn&quot;: &quot;xxxxxxxxx:&quot;,\r\n          &quot;days_remaining&quot;: 1126,\r\n          &quot;expiry&quot;: &quot;2026-03-02 09:49:43&quot;,\r\n          &quot;health&quot;: &quot;ok&quot;,\r\n          &quot;issuer&quot;: &quot;xxxxxxxxx&quot;,\r\n          &quot;path&quot;: &quot;/etc/origin/node/client-ca.crt&quot;,\r\n          &quot;serial&quot;: 1,\r\n          &quot;serial_hex&quot;: &quot;0x1&quot;\r\n        },\r\n        {\r\n          &quot;cert_cn&quot;: &quot;xxxxxxxxx:&quot;,\r\n          &quot;days_remaining&quot;: 1126,\r\n          &quot;expiry&quot;: &quot;2026-03-02 09:49:43&quot;,\r\n          &quot;health&quot;: &quot;ok&quot;,\r\n          &quot;issuer&quot;: &quot;xxxxxxxxx&quot;,\r\n          &quot;path&quot;: &quot;/etc/origin/node/client-ca.crt&quot;,\r\n          &quot;serial&quot;: 1,\r\n          &quot;serial_hex&quot;: &quot;0x1&quot;\r\n        }\r\n      ],\r\n      &quot;registry&quot;: [],\r\n      &quot;router&quot;: []\r\n    }\r\n    }\r\n    }\r\n```\r\n  \r\n\r\nI tried to write a shell that uses jq to extract the following data:\r\n```\r\n&quot;master-services(name of master Service)&quot;:\r\n      host1:....\r\n        cert_cn:....\r\n        days_remaining:....\r\n        expiry:.......\r\n      host2:.....\r\n        cert_cn:....\r\n        days_remaining:....\r\n        expiry:.......\r\n```\r\nAnd so on... I&#39;ve gotten as far as extracting the data of host1, cert_cn etc… but I just can&#39;t get the master service name in front of the belonging data. I think it is because the master Service name is in {} brackets and therefore defined as an object, rather than an array...\r\nFurthermore, I&#39;ve tried \r\nif anybody has any tips, I would be really grateful… \r\n\r\n\r\nAlso, first time posting, so if anything else is needed, or I need to remove something, please tell me!\r\n\r\nEdit: \r\nSo to clarify, there are multiple &quot;master.services&quot;, with multiple &quot;host&quot;s. I need a jq command, that will be executable in a shell, that outputs:\r\nthe &quot;master.service&quot; (so that the certificate that will be running out is identifyable), followed by the hosts, followed by only &quot;cert_cn&quot;, &quot;days_remaining&quot; and &quot;expiry&quot;, as shown above.\r\nThe output needs to be in xml format, but that problem will be approached, after i solved this. The problems i had so far, are the dots in &quot;master.service&quot; which made it impossible to to directly adress them. After that i tried to navigate through the json by doin something like:\r\n`\r\n    jq -r &#39;.data | .[1] | {cert_cn, days_remaining, expiry}&#39;\r\n`\r\nBut because the &quot;master.service&quot; is in &quot;{}&quot; brackets instead of in [] brackets, i cant index them with numbers, because they are objects rather than arrays.\r\n\r\nSo to clarify i edited the example code to be a valid json file. Also now it should be clearer to understand my problem. I am really learning and exercising right now. So thats the reason im going step by step to get a better understanding. My Problem right now is, that I have created a loop, that reads the the master service name, and right now im working on only printing out the nth(master.service), that will be printed out and passed on so jq can then print out the belonging &quot;cert_cn, days_remaining&quot; and the &quot;expiry&quot; date. After that it should go &quot;back&quot; to the next master.serice and start printing out the next &quot;cert_cn, days_remaining, expiry&quot;. Im progressing slowly. So if anyone has a idea, i would be grateful.\r\nAlready thanks for the comments and sorry for the unclearly formulated question, still working on my english..",
        "link": "https://stackoverflow.com/questions/75434304/i-need-to-create-a-shell-that-utilizes-jq-to-extract-some-data-from-a-rather-la",
        "title": "I need to create a Shell, that utilizes jq to extract some data from a rather large json file"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1676289011,
                "last_edit_date": 1676289011,
                "creation_date": 1676288679,
                "answer_id": 75435438,
                "question_id": 75435133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With [tag:nodejs]:\r\n\r\n    &gt; var json =   [\r\n    ...     {\r\n    ...       &quot;loc&quot;: &quot;51.12345, 12.12345&quot;,\r\n    ...       &quot;city&quot;: &quot;CityName1&quot;\r\n    ...     },\r\n    ...     {\r\n    ...       &quot;loc&quot;: &quot;65.12345, 15.12345&quot;,\r\n    ...       &quot;city&quot;: &quot;CityName2&quot;\r\n    ...     }\r\n    ...   ]\r\n    &gt; var c = 0\r\n    &gt; [&quot;abc&quot;, &quot;def&quot;].forEach(n =&gt; json[c++].city = n)\r\n    &gt; console.log(JSON.stringify(json, null, 4))\r\n    [\r\n        {\r\n            &quot;loc&quot;: &quot;51.12345, 12.12345&quot;,\r\n            &quot;city&quot;: &quot;abc&quot;\r\n        },\r\n        {\r\n            &quot;loc&quot;: &quot;65.12345, 15.12345&quot;,\r\n            &quot;city&quot;: &quot;def&quot;\r\n        }\r\n    ]\r\n\r\nFrom a script : \r\n\r\n    #!/bin/bash\r\n\r\n    node&lt;&lt;EOF | sponge file.json\r\n    var json = $(&lt; file.json)\r\n    var c = 0;\r\n    [&quot;abc&quot;, &quot;def&quot;].forEach(n =&gt; json[c++].city = n)\r\n    console.log(JSON.stringify(json, null, 4))\r\n    EOF\r\n\r\noutput file:\r\n\r\n    [\r\n        {\r\n            &quot;loc&quot;: &quot;51.12345, 12.12345&quot;,\r\n            &quot;city&quot;: &quot;abc&quot;\r\n        },\r\n        {\r\n            &quot;loc&quot;: &quot;65.12345, 15.12345&quot;,\r\n            &quot;city&quot;: &quot;def&quot;\r\n        }\r\n    ]",
                "title": "Update fields from string in JQ"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1676289103,
                "creation_date": 1676289103,
                "answer_id": 75435508,
                "question_id": 75435133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n```\r\n$ string=abc,def\r\n$ jq --arg cities &quot;$string&quot; &#39;[., ($cities / &quot;,&quot;)] | transpose | map(.[0] + {city: .[1]})&#39; file.json\r\n[\r\n  {\r\n    &quot;loc&quot;: &quot;51.12345, 12.12345&quot;,\r\n    &quot;city&quot;: &quot;abc&quot;\r\n  },\r\n  {\r\n    &quot;loc&quot;: &quot;65.12345, 15.12345&quot;,\r\n    &quot;city&quot;: &quot;def&quot;\r\n  }\r\n]\r\n$\r\n```",
                "title": "Update fields from string in JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1676290470,
                "last_edit_date": 1676290470,
                "creation_date": 1676289946,
                "answer_id": 75435651,
                "question_id": 75435133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `reduce` would be another way. Same lengths provided, it allows iterating over the entries along with their indices, which can then be used to access the input array.\r\n```sh\r\nstring=&quot;abc,def&quot;\r\njq --arg var &quot;$string&quot; &#39;\r\n  reduce ($var / &quot;,&quot; | to_entries)[] as {$key, $value} (.;\r\n    .[$key].city = $value\r\n  )\r\n&#39;\r\n```\r\n\r\n&gt; I&#39;m getting an error with jq version 1.4\r\n\r\nTo make this approach compatible with jq 1.4, replace the variable destructuring with a plain variable, and access its parts later, e.g.\r\n```sh\r\nstring=&quot;abc,def&quot;\r\njq --arg var &quot;$string&quot; &#39;\r\n  reduce ($var / &quot;,&quot; | to_entries)[] as $item (.;\r\n    .[$item.key].city = $item.value\r\n  )\r\n&#39;\r\n```\r\n\r\nOutput:\r\n```json\r\n[\r\n  {\r\n    &quot;loc&quot;: &quot;51.12345, 12.12345&quot;,\r\n    &quot;city&quot;: &quot;abc&quot;\r\n  },\r\n  {\r\n    &quot;loc&quot;: &quot;65.12345, 15.12345&quot;,\r\n    &quot;city&quot;: &quot;def&quot;\r\n  }\r\n]\r\n```",
                "title": "Update fields from string in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1676290470,
        "creation_date": 1676286991,
        "last_edit_date": 1676289866,
        "question_id": 75435133,
        "body_markdown": "I have a bash `$string` containing the values: `abc,def` and a *file.json* looking like this:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;loc&quot;: &quot;51.12345, 12.12345&quot;,\r\n    &quot;city&quot;: &quot;CityName1&quot;\r\n  },\r\n  {\r\n    &quot;loc&quot;: &quot;65.12345, 15.12345&quot;,\r\n    &quot;city&quot;: &quot;CityName2&quot;\r\n  }\r\n]\r\n```\r\n\r\nI&#39;m trying to update the city field with the values from the string to get this result:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;loc&quot;: &quot;51.12345, 12.12345&quot;,\r\n    &quot;city&quot;: &quot;abc&quot;\r\n  },\r\n  {\r\n    &quot;loc&quot;: &quot;65.12345, 15.12345&quot;,\r\n    &quot;city&quot;: &quot;def&quot;\r\n  }\r\n]\r\n```\r\nI&#39;m trying this code but it doesn&#39;t work, any suggestions?\r\n\r\n      string=&quot;abc,def&quot;; jq --arg variable &quot;$string&quot; &#39;.city = $string&#39; file.json\r\n",
        "link": "https://stackoverflow.com/questions/75435133/update-fields-from-string-in-jq",
        "title": "Update fields from string in JQ"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1676381708,
                "last_edit_date": 1676381708,
                "creation_date": 1676380156,
                "answer_id": 75448317,
                "question_id": 75445788,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [slice filter](https://stedolan.github.io/jq/manual/#Array/StringSlice:.[10:15]) to extract the head and the tail of the array, then use `+` to concatenate head + the new object + the tail. Finally, use [update-assignment `|=`](https://stedolan.github.io/jq/manual/#Update-assignment:|=) to modify the array:\r\n\r\n```\r\n.components[].content |= .[0:1] + [{ link: &quot;test&quot; }] + .[1:]\r\n```\r\n\r\nIf you are planning on using this more often, consider defining a reusable function:\r\n\r\n```\r\ndef splice($at; $obj): .[0:$at] + [$obj] + .[$at:]; \r\n\r\n.components[].content |= splice(1; {link: &quot;test&quot;})\r\n```",
                "title": "Append JSON file after specific array index by using shell script"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1676392367,
                "last_edit_date": 1676392367,
                "creation_date": 1676391182,
                "answer_id": 75450493,
                "question_id": 75445788,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Grab the empty sub-array at position `1` (slicing either by start and end position `.[1:1]`, or by start position and length `.[1:][:0]`), and assign to it your insert value formatted as (single-element) array `[{&quot;link&quot;: &quot;test&quot;}]` (as you are assigning to an array after all - add more items to it if you want to add all of them at once). This looks almost like your original attempt:\r\n```sh\r\njq &#39;.components[].content[1:1] = [{&quot;link&quot;: &quot;test&quot;}]&#39; test.json\r\n```\r\n---\r\nFor convenience, you can also turn this into an `insertAt` function:\r\n```sh\r\ndef insertAt($pos; $val): .[$pos:$pos] = [$val];\r\n\r\n.components[].content |= insertAt(1; {&quot;link&quot;: &quot;test&quot;})\r\n```",
                "title": "Append JSON file after specific array index by using shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1676392367,
        "creation_date": 1676366841,
        "last_edit_date": 1676377740,
        "question_id": 75445788,
        "body_markdown": "I want to append some content by using shell script.\r\nI have a JSON file *test.json* as below.\r\n\r\n```json\r\n{\r\n  &quot;reference&quot;: &quot;Json Test&quot;,\r\n  &quot;title&quot;: {\r\n    &quot;a&quot;: &quot;Json Test&quot;\r\n  },\r\n  &quot;components&quot;: [\r\n    {\r\n      &quot;reference&quot;: &quot;Json Test&quot;,\r\n      &quot;type&quot;: &quot;panel&quot;,\r\n      &quot;content&quot;: [\r\n        {\r\n          &quot;link&quot;: &quot;abc/123&quot;,\r\n          &quot;label&quot;: {\r\n            &quot;a&quot;: &quot;for test 123 - a&quot;,\r\n            &quot;b&quot;: &quot;for test 123 - b&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;link&quot;: &quot;abc/456&quot;,\r\n          &quot;label&quot;: {\r\n            &quot;a&quot;: &quot;for test 456 - a&quot;,\r\n            &quot;b&quot;: &quot;for test 456 - b&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;link&quot;: &quot;abc/789&quot;,\r\n          &quot;label&quot;: {\r\n            &quot;a&quot;: &quot;for test 789 - a&quot;,\r\n            &quot;b&quot;: &quot;for test 789 - b&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nI want to append the content and output as following by using shell script (*.sh) How can I achieve this ?\r\n\r\n\r\n```json\r\n{\r\n  &quot;reference&quot;: &quot;Json Test&quot;,\r\n  &quot;title&quot;: {\r\n    &quot;a&quot;: &quot;Json Test&quot;\r\n  },\r\n  &quot;components&quot;: [\r\n    {\r\n      &quot;reference&quot;: &quot;Json Test&quot;,\r\n      &quot;type&quot;: &quot;panel&quot;,\r\n      &quot;content&quot;: [\r\n        {\r\n          &quot;link&quot;: &quot;abc/123&quot;,\r\n          &quot;label&quot;: {\r\n            &quot;a&quot;: &quot;for test 123 - a&quot;,\r\n            &quot;b&quot;: &quot;for test 123 - b&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;link&quot;: &quot;abc/101112&quot;,\r\n          &quot;label&quot;: {\r\n            &quot;a&quot;: &quot;for test 101112 - a&quot;,\r\n            &quot;b&quot;: &quot;for test 101112 - b&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;link&quot;: &quot;abc/456&quot;,\r\n          &quot;label&quot;: {\r\n            &quot;a&quot;: &quot;for test 456 - a&quot;,\r\n            &quot;b&quot;: &quot;for test 456 - b&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;link&quot;: &quot;abc/789&quot;,\r\n          &quot;label&quot;: {\r\n            &quot;a&quot;: &quot;for test 789 - a&quot;,\r\n            &quot;b&quot;: &quot;for test 789 - b&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\n\r\nI tried to access the index and add some test string, the below command will replace the original data.\r\n\r\n\r\n```\r\njq &#39;.components[].content[1] + { &quot;link&quot; : &quot;test&quot; } &#39; test.json\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/75445788/append-json-file-after-specific-array-index-by-using-shell-script",
        "title": "Append JSON file after specific array index by using shell script"
    },
    {
        "tags": [
            "c++",
            "node.js",
            "jq",
            "symbols",
            "gyp"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1676377861,
                "creation_date": 1676377861,
                "answer_id": 75447866,
                "question_id": 75447527,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Solved, missing the extern keyword as I was running cpp code against c module hope it will help someone in the futrue\r\n```\r\nextern &quot;C&quot; {\r\n    #include &quot;jq.h&quot;\r\n    #include &quot;jv.h&quot;\r\n}\r\n```",
                "title": "Bindings of jq to nodejs undefined symbol"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1676377861,
        "creation_date": 1676375973,
        "last_edit_date": 1676376360,
        "question_id": 75447527,
        "body_markdown": "I have a problem regarding binding jq library using node-gyp.\r\n\r\nI have 2 node-gyp files \r\n 1. for building the nan code\r\n 2. for building the JQ code\r\n\r\nYou can see the full repo in here https://github.com/danielsinai/jq-node-bindings.git\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\nI&#39;m getting the error while trying to run the following program (`index.js`): \r\n\r\n```\r\nconst jq = require(&#39;bindings&#39;)(&#39;jq-node-bindings&#39;);\r\n\r\nconsole.log(jq)\r\n\r\nconst x =  jq.exec(JSON.stringify({ foo: &#39;bar&#39; }), &#39;.foo&#39;);\r\n\r\nconsole.log(x)\r\n\r\n```\r\n\r\nThe error:\r\n```\r\nnode: symbol lookup error: /root/code/jq-bindings/build/Release/jq-node-bindings.node: undefined symbol: _Z7jq_init\r\n```\r\n\r\n`nm` command output\r\n\r\n\r\n```\r\n nm -g build/deps/libjq.so.1 | grep jq_init\r\n000000000003acb0 T jq_init\r\n```\r\n\r\n`ldd` command output\r\n\r\n\r\n```\r\nldd /root/code/jq-bindings/build/Release/jq-node-bindings.node\r\n        linux-vdso.so.1 (0x00007ffe0bbf0000)\r\n        libjq.so.1 =&gt; /root/code/jq-bindings/build/Release/../deps/libjq.so.1 (0x00007feb84541000)\r\n        libstdc++.so.6 =&gt; /lib64/libstdc++.so.6 (0x00007feb84316000)\r\n        libm.so.6 =&gt; /lib64/libm.so.6 (0x00007feb8423b000)\r\n        libgcc_s.so.1 =&gt; /lib64/libgcc_s.so.1 (0x00007feb84220000)\r\n        libc.so.6 =&gt; /lib64/libc.so.6 (0x00007feb84017000)\r\n        /lib64/ld-linux-x86-64.so.2 (0x00007feb84630000)\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75447527/bindings-of-jq-to-nodejs-undefined-symbol",
        "title": "Bindings of jq to nodejs undefined symbol"
    },
    {
        "tags": [
            "json",
            "awk",
            "sed",
            "boost",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676392245,
                "post_id": 75450348,
                "comment_id": 133125986,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 229381,
                    "reputation": 4150,
                    "user_id": 492307,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://www.gravatar.com/avatar/8085cc47ff63666ad11f782ea46325d4?s=256&d=identicon&r=PG",
                    "display_name": "Tryer",
                    "link": "https://stackoverflow.com/users/492307/tryer"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676392519,
                "post_id": 75450348,
                "comment_id": 133126069,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1676392319,
                "creation_date": 1676392319,
                "answer_id": 75450708,
                "question_id": 75450348,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `jq`, you could use the `keys` built-in to get the key names in sorted order and form the corresponding value object\r\n\r\n\r\n```none\r\njq &#39;keys[] as $k | { ($k) : .[$k] }&#39; json\r\n```\r\n\r\nNote that `jq` does have a field `--sort-keys` option, which **cannot** be used here, as it internally sorts the inner level objects as well.",
                "title": "Sorting a JSON file by outer object name"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1676427926,
                "last_edit_date": 1676427926,
                "creation_date": 1676404731,
                "answer_id": 75452725,
                "question_id": 75450348,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a variable-free jq solution:\r\n```\r\nto_entries | sort_by(.key) | from_entries\r\n```\r\n\r\nIt is also worth noting that `gojq`, the Go implementation of jq, currently always sorts the keys within all JSON objects.",
                "title": "Sorting a JSON file by outer object name"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1676427926,
        "creation_date": 1676390483,
        "last_edit_date": 1676390739,
        "question_id": 75450348,
        "body_markdown": "I have a json file `input.json` thus:\r\n\r\n    {\r\n       &quot;foo&quot;:{\r\n           &quot;prefix&quot;:&quot;abc&quot;,\r\n           &quot;body&quot;:[1,2,3]\r\n       },\r\n       &quot;bar&quot;:{\r\n           &quot;prefix&quot;:&quot;def&quot;,\r\n           &quot;body&quot;:[4,5,6]    \r\n       }\r\n    }\r\n\r\nI would like to sort it by the outer object names, with `&quot;bar&quot;` coming before `&quot;foo&quot;` in alphabetical order like so:\r\n\r\n    {\r\n       &quot;bar&quot;:{\r\n           &quot;prefix&quot;:&quot;def&quot;,\r\n           &quot;body&quot;:[4,5,6]    \r\n       },\r\n       &quot;foo&quot;:{\r\n           &quot;prefix&quot;:&quot;abc&quot;,\r\n           &quot;body&quot;:[1,2,3]\r\n       }\r\n    }\r\n\r\nto produce file `output.json`.\r\n\r\nVersions of this question have been asked of Java/Javascript ([here](https://stackoverflow.com/questions/4277715/how-to-sort-json-object-in-java) and [here](https://stackoverflow.com/questions/979256/sorting-an-array-of-objects-by-property-values))\r\n\r\nIs there a way to accomplish this using a command line tool like sed/awk or boost.json?",
        "link": "https://stackoverflow.com/questions/75450348/sorting-a-json-file-by-outer-object-name",
        "title": "Sorting a JSON file by outer object name"
    },
    {
        "tags": [
            "json",
            "bash",
            "syntax-error",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1676457939,
                "post_id": 75458568,
                "comment_id": 133139109,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676463454,
                "post_id": 75458568,
                "comment_id": 133140623,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1676458721,
                "last_edit_date": 1676458721,
                "creation_date": 1676458056,
                "answer_id": 75458644,
                "question_id": 75458568,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq can only process valid JSON.\r\n\r\nIf the value of `OUTPUT` is literally `&quot;id&quot;: &quot;c258d7b330&quot;,&quot;name&quot;: &quot;abc-group&quot;`, then you could enclose it in curly braces to make it valid JSON. No guarantees though; this depends on the exact format of your input.\r\n\r\n```\r\nOUTPUT=&#39;&quot;id&quot;: &quot;c258d7b330&quot;,\r\n&quot;name&quot;: &quot;abc-group&quot;&#39;\r\nUSERNAME=&quot;$(printf &#39;%s\\n&#39; &quot;{$OUTPUT}&quot; | jq -r &#39;.name&#39;)&quot;\r\nprintf &#39;%s\\n&#39; &quot;$USERNAME&quot;; // abc-group\r\n```\r\n\r\nIf it cannot be converted to valid JSON, maybe a simple solution using `grep`+`cut` or `awk` would suffice?\r\n\r\n```\r\nOUTPUT=&#39;&quot;id&quot;: &quot;c258d7b330&quot;,\r\n&quot;name&quot;: &quot;abc-group&quot;&#39;\r\nUSERNAME=&quot;$(printf &#39;%s\\n&#39; &quot;$OUTPUT&quot; | grep &#39;^&quot;name&quot;:&#39; | cut -d&#39;&quot;&#39; -f4)&quot;\r\n```\r\n\r\nawk:\r\n\r\n```\r\nprintf &#39;%s\\n&#39; &quot;$OUTPUT&quot; | awk -F&#39;&quot;&#39; &#39;/^&quot;name&quot;:/{print $4}&#39;\r\n```\r\n\r\nOr even use jq to parse the input as array of strings and then filter for the line in which you are interested:\r\n\r\n```\r\njq -Rr &#39;(select(startswith(&quot;\\&quot;name\\&quot;:&quot;)) / &quot;\\&quot;&quot;)[3]&#39;\r\n```\r\n\r\nAll options are really fragile and I recommend to fix your input to be actual, valid JSON",
                "title": "Extract a particular field from json output using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1676467625,
        "creation_date": 1676457726,
        "last_edit_date": 1676467625,
        "question_id": 75458568,
        "body_markdown": "I&#39;m working a bash script to extraxt specific field from json output using `jq`.\r\n\r\n```\r\nUSERNAME=$(echo &quot;$OUTPUT&quot; | jq -r &#39;.[] | .name&#39;)\r\n```\r\nDue to `jq` it always fails with `parse error: Invalid numeric literal at line 1, column 2` error.\r\n\r\nMy restapi result has the below output.\r\n\r\n```\r\n[\r\n  {\r\n    &quot;url&quot;: &quot;#/systemadm/groups/uuid-d6e4e05&quot;,\r\n    &quot;options&quot;: {},\r\n    &quot;group_id&quot;: 313,\r\n    &quot;owner&quot;: &quot;abc-123-mec&quot;,\r\n    &quot;owner_id&quot;: &quot;ad1337884&quot;,\r\n    &quot;id&quot;: &quot;c258d7b330&quot;,\r\n    &quot;name&quot;: &quot;abc-group&quot;\r\n  },\r\n  {\r\n    &quot;options&quot;: {},\r\n    &quot;id&quot;: &quot;global%3Regmebers&quot;,\r\n    &quot;name&quot;: &quot;Udata-123&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;#/systemadm/groups/uuid-38943000&quot;,\r\n    &quot;options&quot;: {},\r\n    &quot;group_id&quot;: 910,\r\n    &quot;owner&quot;: &quot;framework-abcc&quot;,\r\n    &quot;owner_id&quot;: &quot;78d4472b738bc&quot;,\r\n    &quot;id&quot;: &quot;38943000057a&quot;,\r\n    &quot;name&quot;: &quot;def-group&quot;\r\n  },\r\n........................\r\n............................\r\n......................................\r\n```\r\n\r\nSo what&#39;s wrong with this `jq` response of code to get &quot;name&quot; ? ",
        "link": "https://stackoverflow.com/questions/75458568/extract-a-particular-field-from-json-output-using-jq",
        "title": "Extract a particular field from json output using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1676460452,
                "post_id": 75459038,
                "comment_id": 133139784,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676461491,
                "post_id": 75459038,
                "comment_id": 133140046,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27792060,
                    "reputation": 18,
                    "user_id": 21218309,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AEdFTp68w-G4RuL8zbLMo3tpPWYw2OSTsM9dudO66IXHGx0=k-s256",
                    "display_name": "buanet",
                    "link": "https://stackoverflow.com/users/21218309/buanet"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676462486,
                "post_id": 75459038,
                "comment_id": 133140338,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676465180,
                "post_id": 75459038,
                "comment_id": 133141157,
                "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"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676470196,
                "post_id": 75459038,
                "comment_id": 133142848,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1676465297,
                "creation_date": 1676465297,
                "answer_id": 75460029,
                "question_id": 75459038,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do it with a single jq command:\r\n\r\n```\r\n#!/bin/sh\r\nobjectshost=&quot;1.1.1.1,2.2.2.2&quot;\r\n\r\njq --arg value &quot;$objectshost&quot; &#39;.objects.host = ($value / &quot;,&quot;)&#39; ./test.json &gt; ./test.json.tmp\r\n```\r\n\r\nThis has the added benefit of not requiring Bash arrays, but can be used with any shell.\r\n\r\n*****\r\n\r\nIf you already have a JSON array, you must use `--argjson` and not `--arg`. `--arg` always creates a variable of type string, `--argjson` however parses the value as JSON entity.\r\n\r\n```\r\n#!/bin/bash\r\nobjectshost=&quot;1.1.1.1,2.2.2.2&quot;\r\nobjectshost_array=$(printf &#39;%s\\n&#39; &quot;$objectshost&quot; | jq -c &#39;split(&quot;,&quot;)&#39;)\r\n\r\njq --argjson value &quot;$objectshost_array&quot; &#39;.objects.host = $value&#39; ./test.json &gt; ./test.json.tmp\r\n```",
                "title": "How to replace an objects value with array in a json file using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1676469577,
                "last_edit_date": 1676469577,
                "creation_date": 1676468378,
                "answer_id": 75460660,
                "question_id": 75459038,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It would work with a conditional assignment from arguments:\r\n\r\n```sh\r\njq &#39;\r\n.objects.host = (\r\n  .objects.host |\r\n  if type == &quot;array&quot;\r\n  then .\r\n  else [ . ]\r\n  end + $ARGS.positional\r\n)\r\n&#39; input.json --args 1.2.3.4 2.2.2.2 4.4.4.4\r\n```\r\n\r\nOr the same as a stand-alone jq script; which is more readable and maintainable:\r\n\r\n`myJQScript`:\r\n```jq\r\n#!/usr/bin/env -S jq --from-file --args\r\n\r\n.objects.host = (\r\n  .objects.host |\r\n  if type == &quot;array&quot;\r\n  then .\r\n  else [ . ]\r\n  end + $ARGS.positional\r\n)\r\n```\r\n\r\nMake it executable:\r\n```sh\r\nchmod +x myJQScript\r\n```\r\n\r\nRun it with arguments to add array entries to host\r\n```sh\r\n$ ./myJQScript 1.2.3.4 2.2.2.2 4.4.4.4 &lt; input.json\r\n{\r\n  &quot;objects&quot;: {\r\n    &quot;type&quot;: &quot;foo&quot;,\r\n    &quot;host&quot;: [\r\n      &quot;1.1.1.1&quot;,\r\n      &quot;1.2.3.4&quot;,\r\n      &quot;2.2.2.2&quot;,\r\n      &quot;4.4.4.4&quot;\r\n    ],\r\n    &quot;port&quot;: &quot;1234&quot;\r\n  }\r\n}\r\n```\r\n\r\n",
                "title": "How to replace an objects value with array in a json file using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1676469577,
        "creation_date": 1676460056,
        "question_id": 75459038,
        "body_markdown": "I&#39;m simply trying to replace an objects value in a json file with an array, using jq in a bash script. \r\nThe json file (truncated) looks like this:\r\n\r\n```\r\n{\r\n  &quot;objects&quot;: {\r\n    &quot;type&quot;: &quot;foo&quot;,\r\n    &quot;host&quot;: &quot;1.1.1.1&quot;,\r\n    &quot;port&quot;: &quot;1234&quot;\r\n  }\r\n}\r\n```\r\nI want to replace the host objects value with an array of different values, so it looks like this:\r\n\r\n```\r\n{\r\n  &quot;objects&quot;: {\r\n    &quot;type&quot;: &quot;foo&quot;,\r\n    &quot;host&quot;: [&quot;1.1.1.1&quot;,&quot;2.2.2.2&quot;],\r\n    &quot;port&quot;: &quot;1234&quot;\r\n  }\r\n}\r\n```\r\n\r\n\r\nI tested around with this script. The Input comes from a simple, comma separated string which I convert into a proper json array (which seems to work).\r\nBut I&#39;m not able replace the value with the array.\r\n```\r\n#!/bin/bash\r\nobjectshost=&quot;1.1.1.1,2.2.2.2&quot;\r\nobjectshost_array=$(jq -c -n --arg arg $objectshost &#39;$arg|split(&quot;,&quot;)&#39;)\r\n\r\njq --arg value &quot;$objectshost_array&quot; &#39;.objects.host = $value&#39; ./test.json &gt; ./test.json.tmp\r\n```\r\nThe best I ended up with, is this:\r\n```\r\n{\r\n  &quot;objects&quot;: {\r\n    &quot;type&quot;: &quot;foo&quot;,\r\n    &quot;host&quot;: &quot;[\\&quot;1.1.1.1\\&quot;,\\&quot;2.2.2.2\\&quot;]&quot;,\r\n    &quot;port&quot;: &quot;1234&quot;\r\n  }\r\n}\r\n```\r\nThe result seems to be some logical result, as the script simply replaces the value with the arrays string. But it&#39;s not what I expected to get. ;)\r\n\r\nI found some similar questions, but all of them were dealing with replacing values in existing arrays or key/value pairs, but my problem seems to be the conversion from a single value to an array. \r\n\r\nCan somebody please push me into the right direction? Or should I forget about jq and threat the json file as a simple text file?\r\n\r\nThanks in advance,&lt;br&gt;\r\nAndr&#233;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75459038/how-to-replace-an-objects-value-with-array-in-a-json-file-using-jq",
        "title": "How to replace an objects value with array in a json file using jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1676557036,
                "last_edit_date": 1676557036,
                "creation_date": 1676473110,
                "answer_id": 75461652,
                "question_id": 75461609,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nmap(.reference |= map(. + &quot; is &quot; + .))\r\n```\r\n\r\nWill change each `.reference` to be `.reference is .reference`\r\n\r\n\r\n----------\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;title&quot;: &quot;Title1&quot;,\r\n    &quot;reference&quot;: [\r\n      &quot;123 is 123&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;title&quot;: &quot;Title2&quot;,\r\n    &quot;reference&quot;: [\r\n      &quot;234 is 234&quot;,\r\n      &quot;345 is 345&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n[Demo](https://www.devtoolsdaily.com/jq_playground/?#%7B%22inputText%22%3A%22%5B%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%20%20%5C%22title%5C%22%3A%20%5C%22Title1%5C%22%2C%5Cn%20%20%20%20%20%20%20%20%5C%22reference%5C%22%3A%20%5B%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%5C%22123%5C%22%5Cn%20%20%20%20%20%20%20%20%5D%5Cn%20%20%20%20%7D%2C%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%20%20%5C%22title%5C%22%3A%20%5C%22Title2%5C%22%2C%5Cn%20%20%20%20%20%20%20%20%5C%22reference%5C%22%3A%20%5B%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%5C%22234%5C%22%2C%5Cn%20%20%20%20%20%20%20%20%20%20%20%20%5C%22345%5C%22%5Cn%20%20%20%20%20%20%20%20%5D%5Cn%20%20%20%20%7D%5Cn%5D%22%2C%22filterExpr%22%3A%22map(.reference%20%7C%3D%20map(.%20%2B%20%5C%22%20is%20%5C%22%20%2B%20.))%22%2C%22rawOutput%22%3Afalse%7D)",
                "title": "How to modify each element of an array in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1676473141,
                "creation_date": 1676473141,
                "answer_id": 75461663,
                "question_id": 75461609,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should work just fine:\r\n\r\n```\r\njq &#39;.[].reference[] |= &quot;\\(.) is \\(.)&quot;&#39;\r\n```\r\n\r\nIt replaces every item of the reference arrays with a string which contains itself two times and the word &quot;is&quot;",
                "title": "How to modify each element of an array in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1676557036,
        "creation_date": 1676472911,
        "question_id": 75461609,
        "body_markdown": "Suppose I have a JSON:\r\n```\r\n[\r\n    {\r\n        &quot;title&quot;: &quot;Title1&quot;,\r\n        &quot;reference&quot;: [\r\n            &quot;123&quot;\r\n        ]\r\n    },\r\n    {\r\n        &quot;title&quot;: &quot;Title2&quot;,\r\n        &quot;reference&quot;: [\r\n            &quot;234&quot;,\r\n            &quot;345&quot;\r\n        ]\r\n    }\r\n]\r\n```\r\n\r\nId like to modify each element of the reference array so that the reference appears twice. I&#39;d like to achieve:\r\n```\r\n[\r\n    {\r\n        &quot;title&quot;: &quot;Title1&quot;,\r\n        &quot;reference&quot;: [\r\n            &quot;123 is 123&quot;\r\n        ]\r\n    },\r\n    {\r\n        &quot;title&quot;: &quot;Title2&quot;,\r\n        &quot;reference&quot;: [\r\n            &quot;234 is 234&quot;,\r\n            &quot;345 is 345&quot;\r\n        ]\r\n    }\r\n]\r\n```\r\n\r\nI&#39;ve tried:\r\n```\r\njq &#39;.[] | .reference = [(&quot;\\(.reference[]) is \\(.reference[])&quot;)]&#39;\r\n```\r\n\r\nbut this fails where the array has more than one item:\r\n\r\n```\r\n{\r\n  &quot;title&quot;: &quot;Title1&quot;,\r\n  &quot;reference&quot;: [\r\n    &quot;123 is 123&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;title&quot;: &quot;Title2&quot;,\r\n  &quot;reference&quot;: [\r\n    &quot;234 is 234&quot;,\r\n    &quot;345 is 234&quot;,\r\n    &quot;234 is 345&quot;,\r\n    &quot;345 is 345&quot;\r\n  ]\r\n}\r\n\r\n```\r\n\r\nHow can I modify the above jq to achieve the desired result?\r\n\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/75461609/how-to-modify-each-element-of-an-array-in-jq",
        "title": "How to modify each element of an array in jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1676579982,
                "last_edit_date": 1676579982,
                "creation_date": 1676557503,
                "answer_id": 75473632,
                "question_id": 75473591,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Take the first item using `.`, and the second using `input` (prepended by `try` to handle cases of not enough input items). Then, wrap them both into array brackets, and provide the `-c` option for compact output. jq will work through its whole input one by one (or two by two). \r\n```sh\r\n./messages.sh | jq -c &#39;[., try input]&#39;\r\n```\r\n```json\r\n[{&quot;a&quot;:&quot;v1&quot;},{&quot;b&quot;:&quot;v2&quot;}]\r\n[{&quot;c&quot;:&quot;v3&quot;},{&quot;d&quot;:&quot;v4&quot;}]\r\n```\r\n\r\n---\r\n&gt; What if I want more objects in the array than 2? For example, 3, 10, 100?\r\n\r\nYou can surround the array body with `limit`, and use `inputs` instead (note the `s`) to fetch more than just one item:\r\n```sh\r\n./messages.sh | jq -c &#39;[limit(3; ., try inputs)]&#39;\r\n```\r\n```json\r\n[{&quot;a&quot;:&quot;v1&quot;},{&quot;b&quot;:&quot;v2&quot;},{&quot;c&quot;:&quot;v3&quot;}]\r\n[{&quot;d&quot;:&quot;v4&quot;}]\r\n```\r\n",
                "title": "Convert messages to arrays using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1676558020,
                "last_edit_date": 1676558020,
                "creation_date": 1676557561,
                "answer_id": 75473646,
                "question_id": 75473591,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `slurp` with `_nwise(2)` to chunk into parts of 2:\r\n```\r\njq --slurp --compact-output &#39;_nwise(2)&#39; &lt;&lt;&lt; $(./messages.sh)\r\n```\r\n\r\n```json\r\n[{&quot;a&quot;:&quot;v1&quot;},{&quot;b&quot;:&quot;v2&quot;}]\r\n[{&quot;c&quot;:&quot;v3&quot;},{&quot;d&quot;:&quot;v4&quot;}]\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nThe `--compact-output` is to output each array on a single line",
                "title": "Convert messages to arrays using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1676577100,
                "last_edit_date": 1676577100,
                "creation_date": 1676559153,
                "answer_id": 75474016,
                "question_id": 75473591,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a stream-oriented, generic and portable def of nwise:\r\n \r\n```\r\n# Group the items in the given stream into arrays of up to length $n\r\n# assuming $n is a non-negative integer &gt; 0\r\n# Input: a stream\r\n# Output: a stream of arrays no longer than $n\r\n# such that [stream] == ([ nwise(stream; $n) ] | add)\r\n# Notice that there is no assumption about an eos marker.\r\ndef nwise(stream; $n):\r\n  foreach ((stream | [.]), null) as $x ([];\r\n    if $x == null then . \r\n    elif length == $n then $x\r\n    else . + $x end;\r\n    if $x == null and length&gt;0 then .\r\n    elif length==$n then .\r\n    else empty\r\n    end);\r\n```\r\n\r\nFor the task at hand, you could use it like so:\r\n\r\n    nwise(inputs; 2)\r\n\r\nwith the -n command-line option.",
                "title": "Convert messages to arrays using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1676579982,
        "creation_date": 1676557299,
        "question_id": 75473591,
        "body_markdown": "My messages generator output\r\n\r\n```bash\r\n$ ./messages.sh\r\n{&quot;a&quot;:&quot;v1&quot;}\r\n{&quot;b&quot;:&quot;v2&quot;}\r\n{&quot;c&quot;:&quot;v3&quot;}\r\n...\r\n```\r\n\r\nRequired output\r\n\r\n```bash\r\n$ ./messages.sh | jq xxxxxx\r\n[{&quot;a&quot;:&quot;v1&quot;},{&quot;b&quot;:&quot;v2&quot;}]\r\n[{&quot;c&quot;:&quot;v3&quot;},{&quot;d&quot;:&quot;v4&quot;}]\r\n...\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75473591/convert-messages-to-arrays-using-jq",
        "title": "Convert messages to arrays using jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "concatenation",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676562880,
                "post_id": 75474323,
                "comment_id": 133165900,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676564815,
                "post_id": 75474323,
                "comment_id": 133166580,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1676563731,
                "creation_date": 1676563731,
                "answer_id": 75474974,
                "question_id": 75474323,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not quite optimised, but I though&#39;t I&#39;d share the general idea:\r\n```\r\njq -r &#39;map(.State as $s | \r\n    (.Drivers | group_by(.Car))[] \r\n    | [ \r\n        $s, \r\n        (map(.Users[].Name) | join(&quot;;&quot;)),\r\n        (map(.Users[].Details.Location) | join(&quot;;&quot;)),\r\n        (map(.Users[].Details.Time) | join(&quot;;&quot;))\r\n    ])\r\n[] | @csv&#39; b\r\n```\r\n\r\n- `map()` over each state, remember the name (`map(.State as $s | `)\r\n- `group_by(.Car)`\r\n- Create an array containing all your fields that is passed to `@csv`\r\n    - Use `map()` and `join()` to create the fields for `Name`, `Location` and `Time`  \r\n   &lt;sub&gt;This part could be improved so you don&#39;t need that duplicated part&lt;/sub&gt;\r\n\r\n\r\n----------\r\n\r\nOutput (with `--raw-output`:\r\n```json\r\n&quot;NewYork&quot;,&quot;John&quot;,&quot;Home&quot;,&quot;12p-5p&quot;\r\n&quot;NewYork&quot;,&quot;Steve;Roger&quot;,&quot;Home;Office&quot;,&quot;9a-7p;3p-6p&quot;\r\n```\r\n\r\n\r\n----------\r\n\r\n&lt;sub&gt;JqPlay seems down, so I&#39;m still searching for an other way of sharing a public demo&lt;/sub&gt;",
                "title": "JQ - Groupby and concatenate text objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1676564210,
                "creation_date": 1676564210,
                "answer_id": 75475063,
                "question_id": 75474323,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n``` jq\r\n.[] | [.State] + (\r\n  .Drivers | group_by(.Car)[] | [.[0].Car] + (\r\n    map(.Users) | add | [\r\n      map(.Name),\r\n      map(.Details.Location),\r\n      map(.Details.Time)\r\n    ] | map(join(&quot;;&quot;))\r\n  )\r\n) | @csv\r\n```\r\n``` none\r\n$ jq -r -f tst.jq file\r\n&quot;NewYork&quot;,&quot;Ford&quot;,&quot;John&quot;,&quot;Home&quot;,&quot;12p-5p&quot;\r\n&quot;NewYork&quot;,&quot;Jetta&quot;,&quot;Steve;Roger&quot;,&quot;Home;Office&quot;,&quot;9a-7p;3p-6p&quot;\r\n$\r\n```",
                "title": "JQ - Groupby and concatenate text objects"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1676565715,
                "creation_date": 1676565715,
                "answer_id": 75475377,
                "question_id": 75474323,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Far from perfect, but it builds the result incrementally so it should be easily debuggable and extensible:\r\n\r\n```\r\nmap({State} + (.Drivers[] | {Car} + (.Users[] | {Name} + (.Details | {Location, Time}))))\r\n| group_by(.Car)\r\n| map(reduce .[] as $item (\r\n  {State:null,Car:null,Name:[],Location:[],Time:[]};\r\n  . + ($item | {State,Car}) | .Name += [$item.Name] | .Location += [$item.Location] | .Time += [$item.Time]))\r\n| .[]\r\n| [.State, .Car, (.Name,.Location,.Time|join(&quot;,&quot;))]\r\n| @csv\r\n```",
                "title": "JQ - Groupby and concatenate text objects"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1676565715,
        "creation_date": 1676560713,
        "question_id": 75474323,
        "body_markdown": "Not quite getting it.  I can produce multiple lines but cannot get multiple entries to combine.  Looking to take Source JSON and output to CSV as shown:\r\n\r\nSource JSON:\r\n\r\n    [{&quot;State&quot;: &quot;NewYork&quot;,&quot;Drivers&quot;: [\r\n    {&quot;Car&quot;: &quot;Jetta&quot;,&quot;Users&quot;: [{&quot;Name&quot;: &quot;Steve&quot;,&quot;Details&quot;: {&quot;Location&quot;: &quot;Home&quot;,&quot;Time&quot;: &quot;9a-7p&quot;}}]},\r\n    {&quot;Car&quot;: &quot;Jetta&quot;,&quot;Users&quot;: [{&quot;Name&quot;: &quot;Roger&quot;,&quot;Details&quot;: {&quot;Location&quot;: &quot;Office&quot;,&quot;Time&quot;: &quot;3p-6p&quot;}}]},\r\n    {&quot;Car&quot;: &quot;Ford&quot;,&quot;Users&quot;: [{&quot;Name&quot;: &quot;John&quot;,&quot;Details&quot;: {&quot;Location&quot;: &quot;Home&quot;,&quot;Time&quot;: &quot;12p-5p&quot;}}]}\r\n    ]}]\r\n\r\nDesired CSV:\r\n\r\n  \r\n    &quot;NewYork&quot;,&quot;Jetta&quot;,&quot;Steve;Roger&quot;,&quot;Home;Office&quot;,&quot;9a-7p;3p-6p&quot;  \r\n    &quot;NewYork&quot;,&quot;Ford&quot;,&quot;John&quot;,&quot;Home&quot;,&quot;12p-5p&quot;\r\n\r\nJQ code that does not work:\r\n\r\n    .\\[\\] | .Drivers\\[\\] | .Car as $car |\r\n        .Users\\[\\] |  \r\n        \\[$car, .Name\\] | @csv",
        "link": "https://stackoverflow.com/questions/75474323/jq-groupby-and-concatenate-text-objects",
        "title": "JQ - Groupby and concatenate text objects"
    },
    {
        "tags": [
            "arrays",
            "json",
            "group-by",
            "nested",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676577508,
                "post_id": 75477073,
                "comment_id": 133170447,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27738534,
                    "reputation": 53,
                    "user_id": 21175546,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/092c2237ed0b426341aca380b685ad79?s=256&d=identicon&r=PG",
                    "display_name": "CD007",
                    "link": "https://stackoverflow.com/users/21175546/cd007"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676578754,
                "post_id": 75477073,
                "comment_id": 133170739,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676579362,
                "post_id": 75477073,
                "comment_id": 133170877,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27738534,
                    "reputation": 53,
                    "user_id": 21175546,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/092c2237ed0b426341aca380b685ad79?s=256&d=identicon&r=PG",
                    "display_name": "CD007",
                    "link": "https://stackoverflow.com/users/21175546/cd007"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676579822,
                "post_id": 75477073,
                "comment_id": 133170976,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1676603503,
                "creation_date": 1676603503,
                "answer_id": 75479933,
                "question_id": 75477073,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n```\r\njq -r &#39;.[]\r\n  | .field as $field\r\n  | (.results[].details[]\r\n     | [$field, .name] + \r\n       [([.matches[] | &quot;\\(.displayName) &lt;\\(.smtpAddress)&gt;&quot;] | join(&quot;;&quot;)) ])\r\n  | @csv&#39;\r\n```",
                "title": "JQ - Groupby and join using mapping"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1676603503,
        "creation_date": 1676575904,
        "last_edit_date": 1676578723,
        "question_id": 75477073,
        "body_markdown": "Submitted my [first question ](https://stackoverflow.com/questions/75474323/jq-groupby-and-concatenate-text-objects) and had hoped to apply it to the bigger JSON file but I am just not getting it.\r\n\r\nUsing JQ I am trying to turn this JSON:\r\n\r\n        [{&quot;field&quot;: &quot;F1&quot;,&quot;results&quot;: [{&quot;details&quot;: [\r\n        \t{&quot;name&quot;: &quot;P1&quot;,&quot;matches&quot;: [\r\n        \t\t{&quot;displayName&quot;: &quot;User1&quot;,&quot;smtpAddress&quot;: &quot;user1@foo.bar&quot;},\r\n        \t\t{&quot;displayName&quot;: &quot;User2&quot;,&quot;smtpAddress&quot;: &quot;user2@foo.bar&quot;}\r\n        \t\t]\r\n        \t},\r\n        \t{&quot;name&quot;: &quot;P2&quot;,&quot;matches&quot;: [\r\n        \t\t{&quot;displayName&quot;: &quot;User3&quot;,&quot;smtpAddress&quot;: &quot;user3@foo.bar&quot;},\r\n        \t\t{&quot;displayName&quot;: &quot;User4&quot;,&quot;smtpAddress&quot;: &quot;user4@foo.bar&quot;}\r\n        \t\t]\r\n        \t}]}]},\r\n        {&quot;field&quot;: &quot;F2&quot;,&quot;results&quot;: [{&quot;details&quot;: [\r\n        \t{&quot;name&quot;: &quot;P3&quot;,&quot;matches&quot;: [\r\n        \t\t{&quot;displayName&quot;: &quot;User1&quot;,&quot;smtpAddress&quot;: &quot;user1@foo.bar&quot;},\r\n        \t\t{&quot;displayName&quot;: &quot;User5&quot;,&quot;smtpAddress&quot;: &quot;user5@foo.bar&quot;}\r\n        \t\t]\r\n        \t},\r\n        \t{&quot;name&quot;: &quot;P4&quot;,&quot;matches&quot;: [\r\n        \t\t{&quot;displayName&quot;: &quot;User6&quot;,&quot;smtpAddress&quot;: &quot;user6@foo.bar&quot;},\r\n        \t\t{&quot;displayName&quot;: &quot;User7&quot;,&quot;smtpAddress&quot;: &quot;user7@foo.bar&quot;}\r\n        \t\t]\r\n        \t}]}]}]\r\n\r\ninto CSV like this.\r\n\r\n    &quot;F1&quot;,&quot;P1&quot;,&quot;User1 &lt;user1@foo.bar&gt;;User2 &lt;user2@foo.bar&gt;&quot;\r\n    &quot;F1&quot;,&quot;P2&quot;,&quot;User3 &lt;user3@foo.bar&gt;;User4 &lt;user4@foo.bar&gt;&quot;\r\n    &quot;F2&quot;,&quot;P3&quot;,&quot;User1 &lt;user1@foo.bar&gt;;User5 &lt;user5@foo.bar&gt;&quot;\r\n    &quot;F2&quot;,&quot;P4&quot;,&quot;User6 &lt;user6@foo.bar&gt;;User7 &lt;user7@foo.bar&gt;&quot;\r\n\r\nCannot get the sub nested array to be respected by MAP.  Any explanation is appreciated.",
        "link": "https://stackoverflow.com/questions/75477073/jq-groupby-and-join-using-mapping",
        "title": "JQ - Groupby and join using mapping"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1676580362,
                "creation_date": 1676580362,
                "answer_id": 75477750,
                "question_id": 75477628,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be using `to_entries` to access the keys, then `group_by` for the grouping, and `map` to construct the final structure:\r\n```sh\r\n.data |= (map(to_entries[]) | group_by(.key) | map({(first.key): map(.value)}))\r\n```\r\n```json\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;a&quot;: [\r\n        11,\r\n        21,\r\n        31\r\n      ]\r\n    },\r\n    {\r\n      &quot;b&quot;: [\r\n        12,\r\n        22,\r\n        32\r\n      ]\r\n    },\r\n    {\r\n      &quot;c&quot;: [\r\n        13,\r\n        23,\r\n        33\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n---\r\nSuggestion: Instead of having an array of objects with a single field, you could instead build one object containing all fields:\r\n```sh\r\n.data |= reduce (.[] | to_entries[]) as {$key, $value} ({}; .[$key] += [$value])\r\n```\r\n```json\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;a&quot;: [\r\n      11,\r\n      21,\r\n      31\r\n    ],\r\n    &quot;b&quot;: [\r\n      12,\r\n      22,\r\n      32\r\n    ],\r\n    &quot;c&quot;: [\r\n      13,\r\n      23,\r\n      33\r\n    ]\r\n  }\r\n}\r\n```",
                "title": "How to reconstruct array data?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1676613548,
        "creation_date": 1676579559,
        "last_edit_date": 1676613548,
        "question_id": 75477628,
        "body_markdown": "I have this data:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;a&quot;: 11,\r\n      &quot;b&quot;: 12,\r\n      &quot;c&quot;: 13\r\n    },\r\n    {\r\n      &quot;a&quot;: 21,\r\n      &quot;b&quot;: 22,\r\n      &quot;c&quot;: 23\r\n    },\r\n    {\r\n      &quot;a&quot;: 31,\r\n      &quot;b&quot;: 32,\r\n      &quot;c&quot;: 33\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to collate it into arrays based on the key names like this:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;a&quot;: [\r\n        11,\r\n        21,\r\n        31\r\n      ]\r\n    },\r\n    {\r\n      &quot;b&quot;: [\r\n        12,\r\n        22,\r\n        32\r\n      ]\r\n    },\r\n    {\r\n      &quot;c&quot;: [\r\n        13,\r\n        23,\r\n        33\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nFor this example we can assume that each element of the original array has the same set of keys, just different values for them.\r\n\r\n\r\nThis jq code can do it for select keys:\r\n\r\n\r\n```\r\njq &#39;(.data[0]|keys_unsorted) as $keys | { ($keys[2]): [.data[]|.[$keys[2]]] }&#39; data.json\r\n```\r\n\r\n```\r\n{\r\n  &quot;c&quot;: [\r\n    13,\r\n    23,\r\n    33\r\n  ]\r\n}\r\n```\r\n\r\nHow do I do this for all keys?",
        "link": "https://stackoverflow.com/questions/75477628/how-to-reconstruct-array-data",
        "title": "How to reconstruct array data?"
    },
    {
        "tags": [
            "windows",
            "powershell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 20882047,
                    "reputation": 64022,
                    "user_id": 15339544,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/F0aQdYPV.jpg?s=256",
                    "display_name": "Santiago Squarzon",
                    "link": "https://stackoverflow.com/users/15339544/santiago-squarzon"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1676583118,
                "post_id": 75478107,
                "comment_id": 133171755,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19375,
                    "reputation": 447959,
                    "user_id": 45375,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/39f6e2dc52425b1e08027c01bb880be0?s=256&d=identicon&r=PG",
                    "display_name": "mklement0",
                    "link": "https://stackoverflow.com/users/45375/mklement0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676588057,
                "post_id": 75478107,
                "comment_id": 133172872,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1676588870,
        "creation_date": 1676582832,
        "last_edit_date": 1676588870,
        "question_id": 75478107,
        "body_markdown": "In a directory i have few hundred json files. Each file has a json property called qlist that i want to remove from that file. \r\n\r\n\r\n\r\n```powrshell\r\n$files = Get-ChildItem &quot;...path...\\*.json&quot;\r\nforeach($file in $files)\r\n{\r\n\t.\\jq.exe &#39;del(.qlist)&#39; $file | Out-File -FilePath $file\r\n}\r\n```\r\n\r\nthe jq part works fine, but i cannot figure out how to write output of jq into a file, code above prunes all json files for me.\r\n\r\nFor example if i would be on a llinux os would simply do\r\n\r\n```\r\n./jq &#39;del(.qlist)&#39; $file &gt; $file\r\n```",
        "link": "https://stackoverflow.com/questions/75478107/powershell-replace-file-content-with-output-of-previous-command",
        "title": "Powershell replace file content with output of previous command"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq",
            "zsh"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 22249835,
                    "reputation": 2020,
                    "user_id": 16482938,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/VtZMd.jpg?s=256",
                    "display_name": "j_b",
                    "link": "https://stackoverflow.com/users/16482938/j-b"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676596186,
                "post_id": 75479247,
                "comment_id": 133174106,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22249835,
                    "reputation": 2020,
                    "user_id": 16482938,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/VtZMd.jpg?s=256",
                    "display_name": "j_b",
                    "link": "https://stackoverflow.com/users/16482938/j-b"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676596674,
                "post_id": 75479247,
                "comment_id": 133174156,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8957164,
                    "reputation": 189,
                    "user_id": 6681047,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/10153848042932898/picture?type=large",
                    "display_name": "Joey Slomowitz",
                    "link": "https://stackoverflow.com/users/6681047/joey-slomowitz"
                },
                "reply_to_user": {
                    "account_id": 22249835,
                    "reputation": 2020,
                    "user_id": 16482938,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/VtZMd.jpg?s=256",
                    "display_name": "j_b",
                    "link": "https://stackoverflow.com/users/16482938/j-b"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676596816,
                "post_id": 75479247,
                "comment_id": 133174172,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8957164,
                    "reputation": 189,
                    "user_id": 6681047,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/10153848042932898/picture?type=large",
                    "display_name": "Joey Slomowitz",
                    "link": "https://stackoverflow.com/users/6681047/joey-slomowitz"
                },
                "reply_to_user": {
                    "account_id": 22249835,
                    "reputation": 2020,
                    "user_id": 16482938,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/VtZMd.jpg?s=256",
                    "display_name": "j_b",
                    "link": "https://stackoverflow.com/users/16482938/j-b"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676597022,
                "post_id": 75479247,
                "comment_id": 133174195,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1676596878,
        "creation_date": 1676594089,
        "last_edit_date": 1676596878,
        "question_id": 75479247,
        "body_markdown": "this is the JSON I am working with - \r\n\r\n```json\r\n{\r\n  &quot;content&quot;: {\r\n    &quot;macOS&quot;: {\r\n      &quot;releases&quot;: [\r\n        {\r\n          &quot;version&quot;: &quot;3.21&quot;,\r\n          &quot;updateItems&quot;: [\r\n            {\r\n              &quot;id&quot;: 1,\r\n              &quot;title&quot;: &quot;Automatic detection for inactivity is here&quot;,\r\n              &quot;message&quot;: &quot;We&#39;ve finally added a feature long requested - Orby now detects when you&#39;ve been inactive on your computer.  You can modify the maximum allowable inactive time through settings, or just turn it off if you don&#39;t need it&quot;,\r\n              &quot;image&quot;: &quot;https://static.image.png&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: 2,\r\n              &quot;title&quot;: &quot;In case you missed it... We have an iOS app &#128241; &#128588;&quot;,\r\n              &quot;message&quot;: &quot;It&#39;s far from perfect, but it&#39;s come a long way since we first pushed out version 1.0.  We don&#39;t that many users on it so far, but I&#39;m hoping that it&#39;s useful.  Please send any feedback and feature requests my way&quot;,\r\n              &quot;image&quot;: &quot;https://static.image.png&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n    &quot;iOS&quot;: {\r\n      &quot;releases&quot;: [\r\n        {\r\n          &quot;version&quot;: &quot;1.31&quot;,\r\n          &quot;updateItems&quot;: [\r\n            {\r\n              &quot;image&quot;: &quot;https://static.image.png&quot;,\r\n              &quot;id&quot;: 1,\r\n              &quot;link&quot;: &quot;orbit://com.orbit:/settings&quot;,\r\n              &quot;message&quot;: &quot;Strict mode offers a fantastic new way to keep your focus and get more done.  To enable it, go to settings and toggle it on.  Now when you want to run a timer, put your device face down on a surface.  The timer will stop if you pick it up.&quot;,\r\n              &quot;title&quot;: &quot;Strict mode is here &#128588; ⚠️ ⚠️ ⚠️&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI want to translate all the title values and message values (I use shell translate).\r\n\r\nIn my attempt, I have looped through the `releases`, gotten the indices, then looped through the `updateItems` and gotten their indices, then translated the `title` and `message` based off both these indices, and then I&#39;ve attempted to assign these new values to replace the existing `title` and `message`.\r\n\r\nI&#39;ve noticed that this results in all the title values being the same, and all the message values being the same.\r\n\r\nI&#39;m clearly using `jq` the wrong way, but am unsure how to correct.\r\n\r\nPlease help.\r\n\r\n```shell\r\ncurl ${URL} | jq &gt;englishContent.json\r\n\r\nLANGUAGES=(\r\n    # &quot;en&quot;\r\n    # &quot;de&quot;\r\n    # &quot;fr&quot;\r\n    # &quot;es&quot;\r\n    &quot;it&quot;\r\n    # &quot;ja&quot;\r\n    # &quot;ko&quot;\r\n    # &quot;nl&quot;\r\n    # &quot;pt-BR&quot;\r\n    # &quot;ru&quot;\r\n    # &quot;zh-Hans&quot;\r\n)\r\n\r\nfor language in $LANGUAGES; do\r\n\r\n    # Create new json payload from the downloaded english content json\r\n    result=$(jq &#39;{ &quot;language&quot;: &quot;&#39;$language&#39;&quot;, &quot;response&quot;: . }&#39; englishContent.json)\r\n\r\n    # Get the total number of release items\r\n    macOS_releases_length=$(jq -r &quot;.response.content.macOS.releases | length&quot; &lt;(echo &quot;$result&quot;))\r\n\r\n    # Iterate over releases items and then use index to substitute values into nested arrays\r\n    macOS_releases_length=$(expr &quot;$macOS_releases_length&quot; - 1)\r\n    for macOS_release_index in $(seq 0 $macOS_releases_length); do\r\n\r\n        update_items_length=$(jq &quot;.response.content.macOS.releases[$macOS_release_index].updateItems | length&quot; &lt;(echo &quot;$result&quot;))\r\n\r\n        update_items_length=$(expr &quot;$update_items_length&quot; - 1)\r\n        for update_item_index in $(seq 0 $update_items_length); do\r\n\r\n            title=$(jq &quot;.response.content.macOS.releases[$macOS_release_index].updateItems[$update_item_index].title&quot; &lt;(echo &quot;$result&quot;))\r\n            translated_title=$(trans -brief -no-warn :$language $title | xargs)\r\n\r\n            message=$(jq &quot;.response.content.macOS.releases[$macOS_release_index].updateItems[$update_item_index].message&quot; &lt;(echo &quot;$result&quot;))\r\n            translated_message=$(trans -brief -no-warn :$language $message | xargs)\r\n            \r\n            result=$(jq --arg release_index &quot;$(echo &quot;$macOS_release_index&quot; | jq &#39;tonumber&#39;)&quot; --arg item_index &quot;$(&quot;$update_item_index&quot; | jq &#39;tonumber&#39;)&quot; --arg new_title $translated_title &#39;.response.content.macOS.releases[&#39;$release_index&#39;].updateItems[&#39;$item_index&#39;].title |= $new_title&#39; &lt;(echo &quot;$result&quot;))\r\n            result=$(jq --arg release_index &quot;$(echo &quot;$macOS_release_index&quot; | jq &#39;tonumber&#39;)&quot; --arg item_index &quot;$(&quot;$update_item_index&quot; | jq &#39;tonumber&#39;)&quot; --arg new_message $translated_message &#39;.response.content.macOS.releases[&#39;$release_index&#39;].updateItems[&#39;$item_index&#39;].message |= $new_message&#39; &lt;(echo &quot;$result&quot;))\r\n        done\r\n    done\r\n    echo $result\r\ndone\r\n```",
        "link": "https://stackoverflow.com/questions/75479247/how-to-loop-over-nested-json-arrays-get-values-and-then-modify-them-based-off-i",
        "title": "How to loop over nested JSON arrays, get values and then modify them based off index in shell using JQ"
    }
]