[
    {
        "tags": [
            "filter",
            "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": 1649290714,
                "post_id": 71774941,
                "comment_id": 126841157,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649295603,
                "creation_date": 1649295603,
                "answer_id": 71775372,
                "question_id": 71774941,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another possibility to consider:\r\n\r\n    {foobar: del(.bat)}",
                "title": "Is there a way to instantiate key with JQ?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1663702844,
                "creation_date": 1663702844,
                "answer_id": 73791846,
                "question_id": 71774941,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t have to &quot;create a dictionary&quot; first. Simply define your object&#39;s structure (`.|` is a redundant no-op, it can be left out):\r\n\r\n    jq &#39;{ foobar: { foo, bar } }&#39;",
                "title": "Is there a way to instantiate key with JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1663702844,
        "creation_date": 1649290552,
        "question_id": 71774941,
        "body_markdown": "Is there a way for jq to instantiate a key to output?\r\n\r\nGiven:\r\n```\r\n{\r\n  &quot;foo&quot;: &quot;bizz&quot;,\r\n  &quot;bar&quot;: &quot;buzz&quot;,\r\n  &quot;bat&quot;: [\r\n    &quot;somestring&quot;\r\n  ]\r\n}\r\n``` \r\n\r\nI would like to do something like `jq &#39;. | {foobar.foo, foobar.bar}&#39;`\r\nand have it output:\r\n```\r\n{\r\n  &quot;foobar&quot;: {\r\n    &quot;foo&quot;: &quot;bizz&quot;,\r\n    &quot;bar&quot;: &quot;buzz&quot;\r\n  }\r\n}\r\n```\r\n\r\nwithout having to make the initial `foobar` dictionary.",
        "link": "https://stackoverflow.com/questions/71774941/is-there-a-way-to-instantiate-key-with-jq",
        "title": "Is there a way to instantiate key with JQ?"
    },
    {
        "tags": [
            "json",
            "apache",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1649343221,
                "last_edit_date": 1649343221,
                "creation_date": 1649339408,
                "answer_id": 71783392,
                "question_id": 71783196,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `if ... then ... else ... end` to implement different behaviours depending  on a value.\r\n\r\n```sh\r\njq &#39;.user |= if startswith(&quot;Basic &quot;)\r\n             then .[6:] | @base64d\r\n             else . end\r\n  &#39; file.json\r\n```",
                "title": "jq - decode json value in flow"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1649343221,
        "creation_date": 1649338733,
        "last_edit_date": 1649339672,
        "question_id": 71783196,
        "body_markdown": "I am need to decode the authorization value from apache in flow and replace the value with the username , returning the modified json.\r\n\r\noriginal Json:\r\n\r\n    { &quot;time&quot;:&quot;2022-04-07T12:53:39.302+0300&quot;, \r\n    .... \r\n    &quot;user&quot;:&quot;Basic c2RwC2ZhcmZZc3Q6c2RfX2ZhcmVhz3Q=&quot; }\r\n\r\nI want to get json:\r\n\r\n    { &quot;time&quot;:&quot;2022-04-07T12:53:39.302+0300&quot;, \r\n    .... \r\n    &quot;user&quot;:&quot;&lt;login&gt;&quot; }\r\nDecoded value here is `&lt;username&gt;:&lt;password&gt;`\r\n\r\nI&#39;m trying to use the `jq` utility for this\r\n\r\n    stdin&gt; | jq -r  &#39;.user | gsub (&quot;Basic &quot;; &quot;&quot;) | @base64d | gsub (&quot;^.*:&quot;; &quot;&quot;)&#39;\r\n\r\nBut `jq` returns the value itself, not the modified json.\r\nAlso, I get an error if json value (`user`) isn&#39;t base64 \r\n`&quot;user&quot;:&quot;-&quot;`\r\n\r\n    jq: error (at &lt;stdin&gt;:1): string (&quot;-&quot;) is not valid base64 data\r\n\r\nHow can I get the full modified json and avoid modification if the user value does not contain &quot;Basic&quot; ?",
        "link": "https://stackoverflow.com/questions/71783196/jq-decode-json-value-in-flow",
        "title": "jq - decode json value in flow"
    },
    {
        "tags": [
            "arrays",
            "json",
            "loops",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1649351176,
                "creation_date": 1649351176,
                "answer_id": 71786279,
                "question_id": 71785892,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use a `reduce` loop with a `range`\r\n\r\n```none\r\n.partitions[] |= reduce range(0; ( .replicas | length ) ) as $r \r\n  ( . ; .log_dirs[$r] += ( .replicas[$r] | tostring ) )\r\n```\r\n\r\nThe reduce expression works by iterating over the entire `log_dirs` array upto the length of `replicas` list and modifying each entry `.log_dirs[$r]` (here `r` runs from 0 - length of `replicas`) by appending the corresponding value at `replicas[$r]`. Since `replicas` contains numerics, it needs to be converted to string for the append operation.\r\n\r\n[jqplay - demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/jmoVwLwKKr",
                "title": "Iterating over arrays simultaneously using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1649351176,
                "creation_date": 1649351176,
                "answer_id": 71786280,
                "question_id": 71785892,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not quite happy with this, but it does work:\r\n\r\n```\r\njq &#39;.partitions[] |= . + (\r\n  . as $p | {\r\n    log_dirs: [\r\n      range(.replicas | length) |\r\n      &quot;\\($p.log_dirs[.])\\($p.replicas[.])&quot;\r\n    ]\r\n  }\r\n)&#39; in.json\r\n```\r\n\r\n",
                "title": "Iterating over arrays simultaneously using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1649351176,
        "creation_date": 1649349281,
        "question_id": 71785892,
        "body_markdown": "I&#39;m describing the output I&#39;d like to have using [jq][1]  \r\n\r\nHere my json file\r\n```json\r\n{\r\n  &quot;partitions&quot;: [\r\n    {\r\n      &quot;replicas&quot;: [\r\n        0,\r\n        1,\r\n        2\r\n      ],\r\n      &quot;log_dirs&quot;: [\r\n        &quot;any&quot;,\r\n        &quot;any&quot;,\r\n        &quot;any&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;replicas&quot;: [\r\n        2,\r\n        0,\r\n        1\r\n      ],\r\n      &quot;log_dirs&quot;: [\r\n        &quot;any&quot;,\r\n        &quot;any&quot;,\r\n        &quot;any&quot;\r\n      ]\r\n    },\r\n[...]\r\n\r\n```\r\nI would like, for every object in partitions[] to replace the value of the i th string in log_dirs[] by its concatenation with the i th number in replicas[] in order to have something like this   \r\n\r\n```json\r\n{\r\n  &quot;partitions&quot;: [\r\n    {\r\n      &quot;replicas&quot;: [\r\n        0,\r\n        1,\r\n        2\r\n      ],\r\n      &quot;log_dirs&quot;: [\r\n        &quot;any0&quot;,\r\n        &quot;any1&quot;,\r\n        &quot;any2&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;replicas&quot;: [\r\n        2,\r\n        0,\r\n        1\r\n      ],\r\n      &quot;log_dirs&quot;: [\r\n        &quot;any2&quot;,\r\n        &quot;any0&quot;,\r\n        &quot;any1&quot;\r\n      ]\r\n    },\r\n[...]\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/71785892/iterating-over-arrays-simultaneously-using-jq",
        "title": "Iterating over arrays simultaneously using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1649357338,
                "creation_date": 1649357338,
                "answer_id": 71787489,
                "question_id": 71787424,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can only pass raw strings (with the `--arg` option) or JSON-encoded strings (with the `--argjson` option) as arguments. You cannot pass jq code as a variable (and evaluate it inside jq).\r\n\r\nYou can, however, reference fields by their string representation. Thus, just use the field name as argument, and `.[$var]` to address it:\r\n~~~sh\r\necho &#39;{&quot;profiles&quot;: {&quot;a&quot;:&quot;1&quot;, &quot;b&quot;:&quot;2&quot;}}&#39; | jq --arg a &#39;a&#39; &#39;.profiles | del(.[$a])&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;b&quot;: &quot;2&quot;\r\n}\r\n~~~",
                "title": "jq delete function doesn&#39;t work with variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1649357338,
        "creation_date": 1649357042,
        "question_id": 71787424,
        "body_markdown": "I&#39;m trying to pass a variable to a jq delete function. It doesn&#39;t work with the variable, but does work if hard-coded. Could someone help me understand what I&#39;m doing wrong.\r\n\r\nDoesn&#39;t work:\r\n\r\n    echo &#39;{&quot;profiles&quot;: {&quot;a&quot;:&quot;1&quot;, &quot;b&quot;:&quot;2&quot;}}&#39; | jq --arg a &#39;.a&#39; &#39;.profiles | del($a)&#39;\r\n\r\nWorks:\r\n\r\n    echo &#39;{&quot;profiles&quot;: {&quot;a&quot;:&quot;1&quot;, &quot;b&quot;:&quot;2&quot;}}&#39; | jq &#39;.profiles | del(.a)&#39;\r\n",
        "link": "https://stackoverflow.com/questions/71787424/jq-delete-function-doesnt-work-with-variable",
        "title": "jq delete function doesn&#39;t work with variable"
    },
    {
        "tags": [
            "json",
            "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": 1649399313,
                "post_id": 71789307,
                "comment_id": 126869824,
                "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": 1649399455,
                "post_id": 71789307,
                "comment_id": 126869858,
                "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": 1649399490,
                "post_id": 71789307,
                "comment_id": 126869869,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1649398472,
                "last_edit_date": 1649398472,
                "creation_date": 1649368545,
                "answer_id": 71789383,
                "question_id": 71789307,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "``` \r\nNAME=$(jq -r &#39;.ConfigurationRecorders[].name&#39; &lt;&lt;&lt;&quot;$CONFIG_RECORDER&quot;)\r\n```\r\n\r\n`&lt;&lt;&lt;` is known as `here-string`.\r\n\r\n`-r` removes the quotes in the result.\r\n\r\n`[]` in the jq query is necessary as ConfigurationRecorders is a JSON array.\r\n\r\n`$( … )` is just an other form of command substitution than backticks. I prefer this one as it is more readable to me.",
                "title": "Retrieving value from JSON object in bash using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1649398472,
        "creation_date": 1649368107,
        "last_edit_date": 1649369402,
        "question_id": 71789307,
        "body_markdown": "I have the following script:\r\n\r\n    #!/bin/bash\r\n\r\n    CONFIG_RECORDER=`aws configservice describe-configuration-recorders`\r\n    NAME=$(jq -r ‘.ConfigurationRecorders[].name’ &lt;&lt;&lt;“$CONFIG_RECORDER”)\r\n    echo $NAME\r\n\r\nI am trying to retrieve the value for name from the following JSON object:\r\n\r\n    {\r\n\t&quot;ConfigurationRecorders&quot;: [{\r\n\t\t&quot;name&quot;: &quot;default&quot;,\r\n\t\t&quot;roleARN&quot;: &quot;arn:aws:iam::xxxxxxxxxxxx:role/Config-Recorder&quot;,\r\n\t\t&quot;recordingGroup&quot;: {\r\n\t\t\t&quot;allSupported&quot;: true,\r\n\t\t\t&quot;includeGlobalResourceTypes&quot;: true,\r\n\t\t\t&quot;resourceTypes&quot;: []\r\n\t\t}\r\n\t}]\r\n    }\r\n\r\nWhen running the script, I am getting an error stating that jq could not open the file. That is because I am trying to pass in the result stored in a variable. How can I move past this? Below is the error:\r\n\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end \r\n    (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    ‘.ConfigurationRecorders[].name’\r\n    jq: 1 compile error",
        "link": "https://stackoverflow.com/questions/71789307/retrieving-value-from-json-object-in-bash-using-jq",
        "title": "Retrieving value from JSON object in bash using JQ"
    },
    {
        "tags": [
            "kubernetes",
            "jq",
            "kubectl",
            "jsonpath"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649375007,
                "creation_date": 1649375007,
                "answer_id": 71790120,
                "question_id": 71789787,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;ve not tried this.\r\n\r\nIf (!) it works, it&#39;s not quite what you want as it should give you every Pod name and then a list of Container names that match the predicate.\r\n\r\nI think you **can&#39;t** use `kubectl --output=jsonpath` alone to filter only the Pod names that have a Container with restarts.\r\n\r\n```bash\r\nFILTER=&#39;\r\n{range .items[*]}\r\n  {.metadata.name}\r\n  {&quot;\\t&quot;}\r\n  [\r\n    {.status.containerStatuses[?(@.restartCount&gt;0)].name}\r\n  ]\r\n  {&quot;\\n&quot;}\r\n{end}\r\n&#39;\r\n\r\nkubectl get pods \\\r\n--output=jsonpath=&quot;${FILTER}&quot;\r\n```",
                "title": "How to get the list of pods with container name for pods that have restarted"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1649410387,
                "creation_date": 1649410387,
                "answer_id": 71794715,
                "question_id": 71789787,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s much easier to get json with kubectl and then process it with jq :\r\n\r\n```\r\n#!/usr/bin/env bash\r\n\r\nkubectl get pods -o=json |\r\n    jq -r &#39;.items[] |\r\n        &quot;\\(.metadata.name) \\(.status.containerStatuses[]|select(.restartCount&gt;0).name)&quot;&#39;\r\n```",
                "title": "How to get the list of pods with container name for pods that have restarted"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1649410387,
        "creation_date": 1649371957,
        "last_edit_date": 1649372344,
        "question_id": 71789787,
        "body_markdown": "Using this command, I am able to get the container name that have restarted.\r\n\r\n```kubectl get pods -o jsonpath=&#39;{.items[*].status.containerStatuses[?(@.restartCount&gt;0)].name}&#39;```\r\n\r\nIs there a way to get the pod name as well in the same command?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71789787/how-to-get-the-list-of-pods-with-container-name-for-pods-that-have-restarted",
        "title": "How to get the list of pods with container name for pods that have restarted"
    },
    {
        "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": 0,
                "creation_date": 1649408696,
                "post_id": 71791959,
                "comment_id": 126872896,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4760558,
                    "reputation": 31,
                    "user_id": 3848049,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e6ce4580d8d50368f57f4248494a1def?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "prem",
                    "link": "https://stackoverflow.com/users/3848049/prem"
                },
                "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": 1649412898,
                "post_id": 71791959,
                "comment_id": 126874316,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1649406203,
                "last_edit_date": 1649406203,
                "creation_date": 1649403159,
                "answer_id": 71793260,
                "question_id": 71791959,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This approach uses `INDEX` to create a dictionary of unique elements based on their `.name` field, `reduce` to iterate over the group fields to be considered, and an initial state created by combining the slurped (`-s`) input files using `add` after removing the group fileds to be processed separately using `del`.\r\n~~~sh\r\njq -s &#39;\r\n  [ &quot;group1&quot;, &quot;group2&quot; ] as $gs | . as $in | reduce $gs[] as $g (\r\n    map(del(.[$gs[]])) | add; .[$g] = [INDEX($in[][$g][]; .name)[]]\r\n  )\r\n&#39; file1.json file2.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;version&quot;: 4,\r\n  &quot;group1&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;olditem1&quot;,\r\n      &quot;content&quot;: &quot;new content&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;newitem1&quot;\r\n    }\r\n  ],\r\n  &quot;group2&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;olditem2&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;newitem2&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/eZIlkf7nUI)\r\n",
                "title": "Combine multiple json to single json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1649406203,
        "creation_date": 1649394686,
        "question_id": 71791959,
        "body_markdown": "I am new to jq and stuck with this problem for a while. Any help is appreciable.\r\n\r\nI have two json files,\r\n\r\nIn file1.json:\r\n\r\n    {\r\n        &quot;version&quot;: 4,\r\n        &quot;group1&quot;: [\r\n            {\r\n                &quot;name&quot;:&quot;olditem1&quot;,\r\n                &quot;content&quot;: &quot;old content&quot;\r\n            }\r\n        ],\r\n        &quot;group2&quot;: [\r\n            {\r\n                &quot;name&quot;:&quot;olditem2&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nAnd in file2.json:\r\n\r\n    {\r\n        &quot;group1&quot;: [\r\n            {\r\n                &quot;name&quot; : &quot;newitem1&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;:&quot;olditem1&quot;,\r\n                &quot;content&quot;: &quot;new content&quot;\r\n            }\r\n        ],\r\n        &quot;group2&quot;: [\r\n            {\r\n                &quot;name&quot; : &quot;newitem2&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nExpected result is:\r\n\r\n    {\r\n        &quot;version&quot;: 4,\r\n        &quot;group1&quot;: [\r\n            {\r\n                &quot;name&quot;:&quot;olditem1&quot;,\r\n                &quot;content&quot;: &quot;old content&quot;\r\n            },\r\n            {\r\n                &quot;name&quot; : &quot;newitem1&quot;\r\n            }\r\n        ],\r\n        &quot;group2&quot;: [\r\n            {\r\n                &quot;name&quot;:&quot;olditem2&quot;\r\n            },\r\n            {\r\n                &quot;name&quot; : &quot;newitem2&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nCriterial for merge:\r\n1) Has to merge only group1 and group2\r\n2) Match only by name\r\n\r\nI have tried \r\n\r\n    jq -S &#39;.group1+=.group1|.group1|unique_by(.name)&#39; file1.json file2.json\r\n\r\nbut this is filtering group1 and all other info are lost.",
        "link": "https://stackoverflow.com/questions/71791959/combine-multiple-json-to-single-json-using-jq",
        "title": "Combine multiple json to single json using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1649412344,
                "last_edit_date": 1649412344,
                "creation_date": 1649411837,
                "answer_id": 71795047,
                "question_id": 71794871,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `inputs` in combination with the `-n` option to sequentially access all input files.\r\n\r\nIn direct analogy, you could just create the array that would have been created by the `-s` option using `[inputs]`, and then `add` up the items as you did before:\r\n~~~sh\r\njq -n &#39;[inputs | {(input_filename): .property}] | add&#39; *\r\n~~~\r\n\r\nBut in a more straightforward way, you could employ `reduce` to  iteratively build up your result object:\r\n~~~sh\r\njq -n &#39;reduce inputs as $in ({}; .[input_filename] = $in.property)&#39; *\r\n~~~\r\n",
                "title": "How can I summarize a property across multiple files with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1649412344,
        "creation_date": 1649411077,
        "question_id": 71794871,
        "body_markdown": "I have a number of JSON files that look like this:\r\n\r\n```json\r\n{\r\n  &quot;property&quot;: &quot;value1&quot;,\r\n  ...\r\n}\r\n```\r\n\r\nWhat I want is an output file that looks like this:\r\n\r\n```json\r\n{\r\n  &quot;&lt;filename1&gt;&quot;: &quot;&lt;value1&gt;&quot;, \r\n  &quot;&lt;filename2&gt;&quot;: &quot;&lt;value2&gt;&quot;, \r\n  &quot;&lt;filename3&gt;&quot;: &quot;&lt;value3&gt;&quot;, \r\n  ...\r\n}\r\n```\r\n\r\nThis can be achieved with two `jq` invocations and a shell pipe:\r\n\r\n```bash\r\njq &#39;{(input_filename):.property}&#39; * | jq -s add\r\n```\r\n\r\nHowever, I was wondering whether this is possible with a single `jq` invocation (or any other simpler way).\r\n\r\nI&#39;m currently using `jq` version 1.5-1 in case it&#39;s relevant.",
        "link": "https://stackoverflow.com/questions/71794871/how-can-i-summarize-a-property-across-multiple-files-with-jq",
        "title": "How can I summarize a property across multiple files with jq?"
    },
    {
        "tags": [
            "bash",
            "command-line-interface",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649419980,
                "post_id": 71796678,
                "comment_id": 126876872,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649420373,
                "post_id": 71796678,
                "comment_id": 126877027,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6727,
                    "reputation": 28422,
                    "user_id": 11439,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/ad4df20b2f152eb065b9f3d8c77c7b66?s=256&d=identicon&r=PG",
                    "display_name": "sumek",
                    "link": "https://stackoverflow.com/users/11439/sumek"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649420401,
                "post_id": 71796678,
                "comment_id": 126877041,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6727,
                    "reputation": 28422,
                    "user_id": 11439,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/ad4df20b2f152eb065b9f3d8c77c7b66?s=256&d=identicon&r=PG",
                    "display_name": "sumek",
                    "link": "https://stackoverflow.com/users/11439/sumek"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649420474,
                "post_id": 71796678,
                "comment_id": 126877068,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1649430113,
                "last_edit_date": 1649430113,
                "creation_date": 1649421358,
                "answer_id": 71797124,
                "question_id": 71796678,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have an array of JSON objects coming-in, you can pipe that to `jq` and form the resulting file with a tool like `awk` (note that a simple bash loop could also be used)\r\n\r\nPipe the command or the JSON array of objects to the following pipeline\r\n\r\n```\r\njq  -cr &#39;.[] | [.name, .content.nested] | join(&quot;\\t&quot;)&#39; | \r\n  awk -F&#39;\\t&#39; &#39;{fname = $1&quot;.sql&quot;; print $2 &gt; fname; close(fname)}&#39;\r\n```\r\n\r\nIf you suspect `\\t` to be present in your data and want to delimit with a non-occuring character, use the NULL delimit as\r\n\r\n```\r\njq -cjr &#39;.[] | (.name, &quot;\\u0000&quot;, .content.nested)&#39; | \r\n  awk -F&#39;\\0&#39; &#39;{fname = $1&quot;.sql&quot;; print $2 &gt; fname; close(fname)}&#39;\r\n```",
                "title": "Create multiple output files based on the contents of JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1649430113,
        "creation_date": 1649419430,
        "last_edit_date": 1649421552,
        "question_id": 71796678,
        "body_markdown": "I have a json array of objects.I filter it with jq to get data I want:\r\n```\r\ncat [{&#39;name&#39;: &#39;a&#39;, &#39;content&#39;: {&#39;nested&#39;: &#39;important content&#39;}}, ...] &gt;&gt; jq &quot;.[]|select(MY_FILTER)|.name,.content.nested&quot;\r\n```\r\n\r\nHow can I write the output to multiple files, each named `{.name}.sql` and containing `{.content.nested}`\r\n\r\nI&#39;ve tried experimenting with echo, tee, --unbuffered and --raw, but with no success",
        "link": "https://stackoverflow.com/questions/71796678/create-multiple-output-files-based-on-the-contents-of-json",
        "title": "Create multiple output files based on the contents of JSON"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq",
            "cut"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1649429436,
                "creation_date": 1649429436,
                "answer_id": 71799064,
                "question_id": 71797910,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Probably not the best, but working\r\n\r\n    grep FileViewed AnnoyingLogFile.csv | cut -d, -f 4- | sed -e &#39;s/&quot;&quot;/&quot;/g&#39; -e &#39;s/^&quot;//&#39; -e &#39;s/&quot;$//&#39; | jq .\r\n\r\nFirst sed replace `&quot;&quot;` with `&quot;`, the second remove `&quot;` at the beginning and third at the end\r\n\r\nIf json is not the last column, you can use `rev` and cut it from the end and `rev` it back",
                "title": "Pass JSON field contained in CSV file using JQ"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1649432587,
                "creation_date": 1649432587,
                "answer_id": 71799843,
                "question_id": 71797910,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You might want to try &lt;a href=&quot;https://miller.readthedocs.io/en/latest/&quot;&gt;Miller&lt;/a&gt;, which is available &lt;a href=&quot;https://github.com/johnkerl/miller/releases&quot;&gt;here&lt;/a&gt; as a stand-alone executable for various OSs.\r\n\r\nWith Miller, the parsing and conversion of your CSV containing JSON fields becomes a breeze:\r\n\r\n```sh\r\nmlr --icsv --ojson json-parse AnnoyingLogFile.csv\r\n```\r\n```json\r\n[\r\n{\r\n  &quot;CreationDate&quot;: &quot;2022-01-01T15:00:00.0000000Z&quot;,\r\n  &quot;UserIds&quot;: &quot;username@domain.com&quot;,\r\n  &quot;Operations&quot;: &quot;FileViewed&quot;,\r\n  &quot;AuditData&quot;: {\r\n    &quot;AppAccessContext&quot;: {\r\n      &quot;CorrelationId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;\r\n    },\r\n    &quot;CreationTime&quot;: &quot;2022-01-01T15:00:00&quot;,\r\n    &quot;Id&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;,\r\n    &quot;Operation&quot;: &quot;FileViewed&quot;,\r\n    &quot;OrganizationId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;,\r\n    &quot;RecordType&quot;: 0,\r\n    &quot;UserType&quot;: 0,\r\n    &quot;Version&quot;: 0,\r\n    &quot;Workload&quot;: &quot;OneDrive&quot;,\r\n    &quot;ClientIP&quot;: &quot;172.0.0.1&quot;,\r\n    &quot;ObjectId&quot;: &quot;https://websitebame-my.sharepoint.com/personal/user_directory/Documents/TextFile.txt&quot;,\r\n    &quot;UserId&quot;: &quot;username@domain.com&quot;,\r\n    &quot;CorrelationId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;,\r\n    &quot;EventSource&quot;: &quot;SharePoint&quot;,\r\n    &quot;ItemType&quot;: &quot;File&quot;,\r\n    &quot;ListId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;,\r\n    &quot;ListItemUniqueId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;,\r\n    &quot;Site&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;,\r\n    &quot;WebId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;,\r\n    &quot;SourceFileName&quot;: &quot;TextFile.txt&quot;,\r\n    &quot;SourceRelativeUrl&quot;: &quot;Documents&quot;\r\n  }\r\n}, ...\r\n```\r\n\r\nAnd for outputting a stack of JSON objects equivalent to your expected output:\r\n\r\n```sh\r\nmlr --icsv --ojsonl json-parse then filter &#39;emit1 $AuditData; false;&#39; AnnoyingLogFile.csv\r\n```\r\n\r\n```json\r\n{&quot;AppAccessContext&quot;: {&quot;CorrelationId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;}, &quot;CreationTime&quot;: &quot;2022-01-01T15:00:00&quot;, &quot;Id&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;Operation&quot;: &quot;FileViewed&quot;, &quot;OrganizationId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;RecordType&quot;: 0, &quot;UserType&quot;: 0, &quot;Version&quot;: 0, &quot;Workload&quot;: &quot;OneDrive&quot;, &quot;ClientIP&quot;: &quot;172.0.0.1&quot;, &quot;ObjectId&quot;: &quot;https://websitebame-my.sharepoint.com/personal/user_directory/Documents/TextFile.txt&quot;, &quot;UserId&quot;: &quot;username@domain.com&quot;, &quot;CorrelationId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;EventSource&quot;: &quot;SharePoint&quot;, &quot;ItemType&quot;: &quot;File&quot;, &quot;ListId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;ListItemUniqueId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;Site&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;WebId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;SourceFileName&quot;: &quot;TextFile.txt&quot;, &quot;SourceRelativeUrl&quot;: &quot;Documents&quot;}\r\n{&quot;AppAccessContext&quot;: {&quot;CorrelationId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;}, &quot;CreationTime&quot;: &quot;2022-01-01T15:01:15&quot;, &quot;Id&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;Operation&quot;: &quot;FileViewed&quot;, &quot;OrganizationId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;RecordType&quot;: 0, &quot;UserType&quot;: 0, &quot;Version&quot;: 0, &quot;Workload&quot;: &quot;OneDrive&quot;, &quot;ClientIP&quot;: &quot;172.0.0.1&quot;, &quot;ObjectId&quot;: &quot;https://websitebame-my.sharepoint.com/personal/user_directory/Documents/TextFile.txt&quot;, &quot;UserId&quot;: &quot;username@domain.com&quot;, &quot;CorrelationId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;EventSource&quot;: &quot;SharePoint&quot;, &quot;ItemType&quot;: &quot;File&quot;, &quot;ListId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;ListItemUniqueId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;Site&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;WebId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;SourceFileName&quot;: &quot;TextFile.txt&quot;, &quot;SourceRelativeUrl&quot;: &quot;Documents&quot;}\r\n{&quot;AppAccessContext&quot;: {&quot;CorrelationId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;}, &quot;CreationTime&quot;: &quot;2022-01-01T15:02:02&quot;, &quot;Id&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;Operation&quot;: &quot;FileViewed&quot;, &quot;OrganizationId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;RecordType&quot;: 0, &quot;UserType&quot;: 0, &quot;Version&quot;: 0, &quot;Workload&quot;: &quot;OneDrive&quot;, &quot;ClientIP&quot;: &quot;172.0.0.1&quot;, &quot;ObjectId&quot;: &quot;https://websitebame-my.sharepoint.com/personal/user_directory/Documents/TextFile.txt&quot;, &quot;UserId&quot;: &quot;username@domain.com&quot;, &quot;CorrelationId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;EventSource&quot;: &quot;SharePoint&quot;, &quot;ItemType&quot;: &quot;File&quot;, &quot;ListId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;ListItemUniqueId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;Site&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;WebId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;, &quot;SourceFileName&quot;: &quot;TextFile.txt&quot;, &quot;SourceRelativeUrl&quot;: &quot;Documents&quot;}\r\n```\r\n",
                "title": "Pass JSON field contained in CSV file using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1649432587,
        "creation_date": 1649424550,
        "question_id": 71797910,
        "body_markdown": "I have a log file from our friends at Microsoft in a very challenging format. The file is as follows:\r\n\r\n - File is a .CSV\r\n - Four fields, the fourth contains JSON\r\n - All JSON key pairs are wrapped with two sets of double quotes\r\n\r\nI have an export of several of these files, and I want to quickly parse them in Terminal using GREP to find key events.\r\n\r\n**Sanitized Example:**\r\n\r\n    CreationDate,UserIds,Operations,AuditData\r\n    2022-01-01T15:00:00.0000000Z,username@domain.com,FileViewed,&quot;{&quot;&quot;AppAccessContext&quot;&quot;:{&quot;&quot;CorrelationId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;},&quot;&quot;CreationTime&quot;&quot;:&quot;&quot;2022-01-01T15:00:00&quot;&quot;,&quot;&quot;Id&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;Operation&quot;&quot;:&quot;&quot;FileViewed&quot;&quot;,&quot;&quot;OrganizationId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;RecordType&quot;&quot;:0,&quot;&quot;UserType&quot;&quot;:0,&quot;&quot;Version&quot;&quot;:0,&quot;&quot;Workload&quot;&quot;:&quot;&quot;OneDrive&quot;&quot;,&quot;&quot;ClientIP&quot;&quot;:&quot;&quot;172.0.0.1&quot;&quot;,&quot;&quot;ObjectId&quot;&quot;:&quot;&quot;https://websitebame-my.sharepoint.com/personal/user_directory/Documents/TextFile.txt&quot;&quot;,&quot;&quot;UserId&quot;&quot;:&quot;&quot;username@domain.com&quot;&quot;,&quot;&quot;CorrelationId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;EventSource&quot;&quot;:&quot;&quot;SharePoint&quot;&quot;,&quot;&quot;ItemType&quot;&quot;:&quot;&quot;File&quot;&quot;,&quot;&quot;ListId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;ListItemUniqueId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;Site&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;WebId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;SourceFileName&quot;&quot;:&quot;&quot;TextFile.txt&quot;&quot;,&quot;&quot;SourceRelativeUrl&quot;&quot;:&quot;&quot;Documents&quot;&quot;}&quot;\r\n    2022-01-01T15:01:15.0000000Z,username@domain.com,FileViewed,&quot;{&quot;&quot;AppAccessContext&quot;&quot;:{&quot;&quot;CorrelationId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;},&quot;&quot;CreationTime&quot;&quot;:&quot;&quot;2022-01-01T15:01:15&quot;&quot;,&quot;&quot;Id&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;Operation&quot;&quot;:&quot;&quot;FileViewed&quot;&quot;,&quot;&quot;OrganizationId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;RecordType&quot;&quot;:0,&quot;&quot;UserType&quot;&quot;:0,&quot;&quot;Version&quot;&quot;:0,&quot;&quot;Workload&quot;&quot;:&quot;&quot;OneDrive&quot;&quot;,&quot;&quot;ClientIP&quot;&quot;:&quot;&quot;172.0.0.1&quot;&quot;,&quot;&quot;ObjectId&quot;&quot;:&quot;&quot;https://websitebame-my.sharepoint.com/personal/user_directory/Documents/TextFile.txt&quot;&quot;,&quot;&quot;UserId&quot;&quot;:&quot;&quot;username@domain.com&quot;&quot;,&quot;&quot;CorrelationId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;EventSource&quot;&quot;:&quot;&quot;SharePoint&quot;&quot;,&quot;&quot;ItemType&quot;&quot;:&quot;&quot;File&quot;&quot;,&quot;&quot;ListId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;ListItemUniqueId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;Site&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;WebId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;SourceFileName&quot;&quot;:&quot;&quot;TextFile.txt&quot;&quot;,&quot;&quot;SourceRelativeUrl&quot;&quot;:&quot;&quot;Documents&quot;&quot;}&quot;\r\n    2022-01-01T15:02:02.0000000Z,username@domain.com,FileViewed,&quot;{&quot;&quot;AppAccessContext&quot;&quot;:{&quot;&quot;CorrelationId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;},&quot;&quot;CreationTime&quot;&quot;:&quot;&quot;2022-01-01T15:02:02&quot;&quot;,&quot;&quot;Id&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;Operation&quot;&quot;:&quot;&quot;FileViewed&quot;&quot;,&quot;&quot;OrganizationId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;RecordType&quot;&quot;:0,&quot;&quot;UserType&quot;&quot;:0,&quot;&quot;Version&quot;&quot;:0,&quot;&quot;Workload&quot;&quot;:&quot;&quot;OneDrive&quot;&quot;,&quot;&quot;ClientIP&quot;&quot;:&quot;&quot;172.0.0.1&quot;&quot;,&quot;&quot;ObjectId&quot;&quot;:&quot;&quot;https://websitebame-my.sharepoint.com/personal/user_directory/Documents/TextFile.txt&quot;&quot;,&quot;&quot;UserId&quot;&quot;:&quot;&quot;username@domain.com&quot;&quot;,&quot;&quot;CorrelationId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;EventSource&quot;&quot;:&quot;&quot;SharePoint&quot;&quot;,&quot;&quot;ItemType&quot;&quot;:&quot;&quot;File&quot;&quot;,&quot;&quot;ListId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;ListItemUniqueId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;Site&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;WebId&quot;&quot;:&quot;&quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;&quot;,&quot;&quot;SourceFileName&quot;&quot;:&quot;&quot;TextFile.txt&quot;&quot;,&quot;&quot;SourceRelativeUrl&quot;&quot;:&quot;&quot;Documents&quot;&quot;}&quot;\r\n\r\nI am attempting to parse the files with a combination of the `cut` and `jq` in terminal, but I am struggling as the `cut` command does not work well with a comma delimiter when the JSON field is riddled with them. I would change the file to a tab-delimited file, ideally I want to avoid that if possible as I&#39;d like to quickly inspect the logs for key events on the fly and not have to open each one up and convert the format.\r\n\r\nWhere I am at:\r\n\r\n    grep FileViewed AnnoyingLogFile.csv | cut -d, -f 4 | jq .\r\n\r\nOutput:\r\n\r\n    &quot;{&quot;\r\n    &quot;AppAccessContext&quot;\r\n    &quot;:{&quot;\r\n    &quot;CorrelationId&quot;\r\n    &quot;:&quot;\r\n    &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;\r\n\r\nOutput I want:\r\n\r\n    {\r\n        &quot;AppAccessContext&quot;:\r\n        {\r\n            &quot;CorrelationId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;\r\n        },\r\n        &quot;CreationTime&quot;: &quot;2022-01-01T15:00:00&quot;,\r\n        &quot;Id&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;,\r\n        &quot;Operation&quot;: &quot;FileViewed&quot;,\r\n        &quot;OrganizationId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;,\r\n        &quot;RecordType&quot;: 0,\r\n        &quot;UserType&quot;: 0,\r\n        &quot;Version&quot;: 0,\r\n        &quot;Workload&quot;: &quot;OneDrive&quot;,\r\n        &quot;ClientIP&quot;: &quot;172.0.0.1&quot;,\r\n        &quot;ObjectId&quot;: &quot;https://websitebame-my.sharepoint.com/personal/user_directory/Documents/TextFile.txt&quot;,\r\n        &quot;UserId&quot;: &quot;username@domain.com&quot;,\r\n        &quot;CorrelationId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;,\r\n        &quot;EventSource&quot;: &quot;SharePoint&quot;,\r\n        &quot;ItemType&quot;: &quot;File&quot;,\r\n        &quot;ListId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;,\r\n        &quot;ListItemUniqueId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;,\r\n        &quot;Site&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;,\r\n        &quot;WebId&quot;: &quot;f6298547-d934-4c79-8bab-c5c394f31f65&quot;,\r\n        &quot;SourceFileName&quot;: &quot;TextFile.txt&quot;,\r\n        &quot;SourceRelativeUrl&quot;: &quot;Documents&quot;\r\n    }\r\n    ...\r\n\r\nI have already used an alternative to analyze these logs, but I wanted to throw this question here to see if it is achievable to parse in terminal using `cut`, `jq`, or any other commands.",
        "link": "https://stackoverflow.com/questions/71797910/pass-json-field-contained-in-csv-file-using-jq",
        "title": "Pass JSON field contained in CSV file using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1649500289,
                "last_edit_date": 1649500289,
                "creation_date": 1649432420,
                "answer_id": 71799796,
                "question_id": 71799447,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to concatenate two arrays you can use the `+` operator:\r\n```\r\njq -c &#39;[..|.animal_potato_carrot?|select(. != null)|.options[0].url] + [..|.cat_dog_rabbit?|select(. != null)|.[0].url]&#39; json.txt\r\n```\r\nPlease notice that the order of items in the result is not exactly as you requested, because first all `animal_potato_carrot`-urls are determined and then all `cat_dog_rabbit`-urls.\r\n\r\nCombining two filters with `,` may come closest to your needs:\r\n```\r\njq -c &#39;[..|(.animal_potato_carrot?.options),(.cat_dog_rabbit?)|.[0].url|select(. != null)]&#39; json.txt\r\n```",
                "title": "Get all nested urls based on nested tag in JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1649500289,
        "creation_date": 1649431064,
        "last_edit_date": 1649465672,
        "question_id": 71799447,
        "body_markdown": "I have a following Json input in a text file `json.txt`:\r\n\r\n```\r\n{\r\n   &quot;files&quot;:[\r\n      {\r\n         &quot;id&quot;:49894894,\r\n         &quot;list&quot;:[\r\n            {\r\n               &quot;name&quot;:&quot;one&quot;,\r\n               &quot;animal_potato_carrot&quot;:{\r\n                  &quot;options&quot;:[\r\n                     {\r\n                        &quot;id&quot;:4989,\r\n                        &quot;url&quot;:&quot;https://example.com/text.txt&quot;\r\n                     },\r\n                     {\r\n                        &quot;id&quot;:3994,\r\n                        &quot;url&quot;:&quot;https://example.com/randomfile.json&quot;\r\n                     }\r\n                  ]\r\n               }\r\n            },\r\n            {\r\n               &quot;name&quot;:&quot;two&quot;,\r\n               &quot;cat_dog_rabbit&quot;:[\r\n                  {\r\n                     &quot;id&quot;:4989,\r\n                     &quot;url&quot;:&quot;https://example.com/text2.txt&quot;\r\n                  },\r\n                  {\r\n                     &quot;id&quot;:3994,\r\n                     &quot;url&quot;:&quot;https://example.com/randomfile.json&quot;\r\n                  }\r\n               ]\r\n            },\r\n            {\r\n               &quot;name&quot;:&quot;three&quot;,\r\n               &quot;animal_potato_carrot&quot;:{\r\n                  &quot;options&quot;:[\r\n                     {\r\n                        &quot;id&quot;:4989,\r\n                        &quot;url&quot;:&quot;https://example.com/text3.txt&quot;\r\n                     },\r\n                     {\r\n                        &quot;id&quot;:3994,\r\n                        &quot;url&quot;:&quot;https://example.com/randomfile.json&quot;\r\n                     }\r\n                  ]\r\n               }\r\n            }\r\n         ]\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nI want to get only the first url in the list of `options` for each `animal_potato_carrot` or `cat_dog_rabbit` nested tag only (note they have different structures)\r\n\r\nSo my output will be first three urls in those blocks:\r\n\r\n```\r\n[&quot;https://example.com/text.txt&quot;, &quot;https://example.com/text2.txt, &quot;https://example.com/text3.txt&quot;]\r\n```\r\n\r\nI tried `jq json.txt -c &#39;.. |.&quot;animal_potato_carrot&quot;? | select(. != null)&#39;` but that returns all the things inside the body, not just the FIRST url.\r\n\r\nEdit: \r\n\r\nthese two commands return the urls for `animal_potato_carrot` and `cat_dog_rabbit` separately but is there a way to combine these commands?\r\n\r\n```\r\njq -c &#39;[..|.animal_potato_carrot?|select(. != null)|.options[0].url]&#39; json.txt\r\n```\r\n\r\n```\r\njq -c &#39;[..|.cat_dog_rabbit?|select(. != null)|.[0].url]&#39; json.txt\r\n```",
        "link": "https://stackoverflow.com/questions/71799447/get-all-nested-urls-based-on-nested-tag-in-json",
        "title": "Get all nested urls based on nested tag in JSON"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649470016,
                "last_edit_date": 1649470016,
                "creation_date": 1649468768,
                "answer_id": 71804670,
                "question_id": 71804236,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The jq program\r\n\r\n   .[] | select(any(.Type[]; IN(&quot;A&quot;,&quot;B&quot;,&quot;A, B&quot;,&quot;Universal&quot;))) | .Code\r\n\r\nproduces:\r\n```\r\n&quot;DEF&quot;\r\n&quot;GHI&quot;\r\n&quot;JKL&quot;\r\n&quot;MNO&quot;\r\n```",
                "title": "Matching When Value Is List"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1649501977,
                "creation_date": 1649501977,
                "answer_id": 71807442,
                "question_id": 71804236,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you wanted exact match, save following into `script.jq` :\r\n\r\n```\r\n.[] | select(.Type == $match) | .Code\r\n```\r\n\r\nThen test with \r\n\r\n\r\n```\r\n$ jq -r --argjson match &#39;[&quot;A&quot;]&#39; -f script.jq test.json\r\nDEF\r\n$ jq -r --argjson match &#39;[&quot;B&quot;]&#39; -f script.jq test.json\r\nGHI\r\n$ jq -r --argjson match &#39;[&quot;A&quot;, &quot;B&quot;]&#39; -f script.jq test.json\r\nJKL\r\n```",
                "title": "Matching When Value Is List"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1649501977,
        "creation_date": 1649462588,
        "last_edit_date": 1649469295,
        "question_id": 71804236,
        "body_markdown": "I have an API dump file that is similar to this.\r\n&lt;pre&gt;\r\n&lt;code&gt;{\r\n  &quot;abc&quot;: {\r\n    &quot;Code&quot;: &quot;ABC&quot;,\r\n    &quot;Type&quot;: []  },\r\n  &quot;def&quot;: {\r\n    &quot;Code&quot;: &quot;DEF&quot;,\r\n    &quot;Type&quot;: [\r\n      &quot;A&quot;\r\n    ]\r\n  },\r\n  &quot;ghi&quot;: {\r\n    &quot;Code&quot;: &quot;GHI&quot;,\r\n    &quot;Type&quot;: [\r\n      &quot;B&quot;\r\n    ]\r\n  },\r\n  &quot;jkl&quot;: {\r\n    &quot;Code&quot;: &quot;JKL&quot;,\r\n    &quot;Type&quot;: [\r\n      &quot;A&quot;,\r\n      &quot;B&quot;\r\n    ]\r\n  },\r\n   &quot;mno&quot;: {\r\n    &quot;Code&quot;: &quot;MNO&quot;,\r\n    &quot;Type&quot;: [ &quot;Universal&quot; ]\r\n  }\r\n}&lt;/pre&gt;&lt;/code&gt;\r\nI am trying to extract objects, and get Code keys based on certain Type matches.\r\n\r\nFor example.\r\nTrying to where Type matches &quot;A&quot;, &quot;B&quot;, &quot;A, B&quot;, or Universal, I am getting objects that contain both, or nothing in certain cases.\r\n\r\nHere is what I tried.\r\n&lt;pre&gt;&lt;code&gt;jq -r &#39;.[] | select(.Type[] == &quot;A&quot;) | .Code&#39; /tmp/test.json&lt;/pre&gt;&lt;/code&gt;\r\nI get\r\n&lt;blockquote&gt;DEF &lt;br /&gt;JKL&lt;/blockquote&gt;\r\nWhich is unexpectedly matching Type [&quot;A&quot;} and Type [&quot;A&quot;, &quot;B&quot;]\r\n&lt;pre&gt;&lt;code&gt;jq -r &#39;.[] | select(.Type[] == &quot;B&quot;) | .Code&#39; /tmp/test.json&lt;/pre&gt;&lt;/code&gt;\r\nI get.\r\n&lt;blockquote&gt;GHI &lt;br /&gt;JKL&lt;/blockquote&gt;\r\nWhich is unexpectedly matching Type [&quot;B&quot;} and Type [&quot;A&quot;, &quot;B&quot;]\r\n&lt;pre&gt;&lt;code&gt;jq -r &#39;.[] | select(.Type[] == &quot;A, B&quot;) | .Code&#39; /tmp/test.json&lt;/pre&gt;&lt;/code&gt;\r\nMatches nothing.\r\n\r\nThis works as expected.\r\n&lt;pre&gt;&lt;code&gt;jq -r &#39;.[] | select(.Type[] == &quot;Universal&quot;) | .Code&#39; /tmp/test.json&lt;/pre&gt;&lt;/code&gt;\r\n&lt;blockquote&gt;MNO&lt;/blockquote&gt;\r\n",
        "link": "https://stackoverflow.com/questions/71804236/matching-when-value-is-list",
        "title": "Matching When Value Is List"
    },
    {
        "tags": [
            "bash",
            "parsing",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16016658,
                    "reputation": 64,
                    "user_id": 11559187,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/82b1743192789d7f796f608740921b40?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Volzy",
                    "link": "https://stackoverflow.com/users/11559187/volzy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649490654,
                "post_id": 71806138,
                "comment_id": 126892957,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24873914,
                    "reputation": 3,
                    "user_id": 18748075,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/690c2c24c765268e3735aaf6da54dd30?s=256&d=identicon&r=PG",
                    "display_name": "willsmith69",
                    "link": "https://stackoverflow.com/users/18748075/willsmith69"
                },
                "reply_to_user": {
                    "account_id": 16016658,
                    "reputation": 64,
                    "user_id": 11559187,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/82b1743192789d7f796f608740921b40?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Volzy",
                    "link": "https://stackoverflow.com/users/11559187/volzy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649491537,
                "post_id": 71806138,
                "comment_id": 126893105,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649493472,
                "post_id": 71806138,
                "comment_id": 126893453,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649493194,
                "last_edit_date": 1649493194,
                "creation_date": 1649491720,
                "answer_id": 71806295,
                "question_id": 71806138,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "if you are calling a command, to get the list of links, you can simply iterate over the result of the command, something like:\r\n\r\n```sh\r\nfor link in &quot;$(jq &lt;args...&gt;)&quot;; do\r\n    # do something here\r\ndone\r\n```\r\nor:\r\n\r\n```sh\r\nwhile read -r link; do\r\n    # do something here\r\ndone &lt;&lt;&lt; $(jq &lt;args...&gt;)\r\n```",
                "title": "bash script to curl all urls in array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649494625,
                "creation_date": 1649494625,
                "answer_id": 71806581,
                "question_id": 71806138,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As the JSON array is &quot;coming out of a jq call&quot;, just have jq output it as a list of raw-text urls using `.[]` and the `-r` option, then pipe that list into `xargs` using `curl`.\r\n~~~sh\r\njq -r &#39;… | .[]&#39; | xargs -I{} curl -O {}\r\n~~~\r\n\r\nIf you cannot modify the original jq filter, insert another call to jq to your pipe:\r\n~~~\r\n… | jq -r &#39;.[]&#39; | xargs -I{} curl -O {}\r\n~~~",
                "title": "bash script to curl all urls in array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649503433,
                "last_edit_date": 1649503433,
                "creation_date": 1649503122,
                "answer_id": 71807593,
                "question_id": 71806138,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Add the following to the end of your jq code, and pipe to `sh` to run it:\r\n\r\n    jq -r &#39;[ &quot;curl&quot;, .[] ] | @sh&#39; | sh\r\n\r\n- The `@sh` filter correctly escapes output for a shell\r\n\r\n- A single shell command is an array/list, delimited by whitespace: `cmd opts ... args ...`, and curl can take multiple URL arguments.\r\n\r\n- So in jq, you can prepend the `curl` command (and any options) as extra elements in the array, and filter through `@sh`, to generate a correctly quoted shell command.\r\n\r\n- Note that the order of elements in a JSON array is preserved, which is what we want - `curl` first.\r\n\r\n- You can run jq without the pipe, to inspect what will be executed:\r\n\r\nFor example:\r\n\r\n    echo &#39;[&quot;https://example.com/text.txt&quot;, &quot;https://example.com/text2.txt&quot;, &quot;https://example.com/text3.txt&quot;]&#39; |\r\n    jq -r &#39;[ &quot;curl&quot;, .[] ] | @sh&#39;\r\n\r\nShould produce:\r\n\r\n    &#39;curl&#39; &#39;https://example.com/text.txt&#39; &#39;https://example.com/text2.txt&#39; &#39;https://example.com/text3.txt&#39;\r\n\r\nThe quotes around `curl` are fine. This  output can be piped (in the shell) to `sh`, to execute.\r\n",
                "title": "bash script to curl all urls in array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649596682,
                "creation_date": 1649596682,
                "answer_id": 71816965,
                "question_id": 71806138,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will create 3 files in the current directory:\r\n\r\n    echo &#39;[&quot;https://example.com/text.txt&quot;, &quot;https://example.com/text2.txt&quot;, &quot;https://example.com/text3.txt&quot;]&#39; | jq &#39;.[]&#39; | xargs -n 1 curl -O\r\n\r\n\r\n",
                "title": "bash script to curl all urls in array"
            }
        ],
        "is_answered": false,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1649596682,
        "creation_date": 1649490107,
        "last_edit_date": 1649492705,
        "question_id": 71806138,
        "body_markdown": "i have an array of urls like (coming out of a jq call):\r\n\r\n```\r\n[&quot;https://example.com/text.txt&quot;, &quot;https://example.com/text2.txt&quot;, &quot;https://example.com/text3.txt&quot;]\r\n```\r\n\r\nhow to loop through this and curl each of these urls into the current folder?\r\n\r\n\r\nedit:\r\n\r\n```\r\nfor link in $(jq -c &#39;xxxx&#39; file.txt); do\r\n\techo &quot;$link&quot;\r\n  done\r\n```\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71806138/bash-script-to-curl-all-urls-in-array",
        "title": "bash script to curl all urls in array"
    },
    {
        "tags": [
            "php",
            "json",
            "linux",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2485432,
                    "reputation": 3662,
                    "user_id": 2163927,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://i.sstatic.net/DLj89.jpg?s=256",
                    "display_name": "Petro",
                    "link": "https://stackoverflow.com/users/2163927/petro"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649518238,
                "post_id": 71809428,
                "comment_id": 126898364,
                "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": 1649518453,
                "post_id": 71809428,
                "comment_id": 126898430,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24883498,
                    "reputation": 21,
                    "user_id": 18756427,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/27a87e6b8b76b35198e4e07143752885?s=256&d=identicon&r=PG",
                    "display_name": "ohMMM",
                    "link": "https://stackoverflow.com/users/18756427/ohmmm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649518631,
                "post_id": 71809428,
                "comment_id": 126898480,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24883498,
                    "reputation": 21,
                    "user_id": 18756427,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/27a87e6b8b76b35198e4e07143752885?s=256&d=identicon&r=PG",
                    "display_name": "ohMMM",
                    "link": "https://stackoverflow.com/users/18756427/ohmmm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649519076,
                "post_id": 71809428,
                "comment_id": 126898586,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1253831,
                    "reputation": 57236,
                    "user_id": 1213708,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e617b05eacf75c49dcf76ebb312292ec?s=256&d=identicon&r=PG",
                    "display_name": "Nigel Ren",
                    "link": "https://stackoverflow.com/users/1213708/nigel-ren"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649522011,
                "post_id": 71809428,
                "comment_id": 126899218,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24883498,
                    "reputation": 21,
                    "user_id": 18756427,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/27a87e6b8b76b35198e4e07143752885?s=256&d=identicon&r=PG",
                    "display_name": "ohMMM",
                    "link": "https://stackoverflow.com/users/18756427/ohmmm"
                },
                "reply_to_user": {
                    "account_id": 1253831,
                    "reputation": 57236,
                    "user_id": 1213708,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e617b05eacf75c49dcf76ebb312292ec?s=256&d=identicon&r=PG",
                    "display_name": "Nigel Ren",
                    "link": "https://stackoverflow.com/users/1213708/nigel-ren"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1649524510,
                "post_id": 71809428,
                "comment_id": 126899751,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1649518894,
                "creation_date": 1649518894,
                "answer_id": 71809543,
                "question_id": 71809428,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "there are a lot of reasons for this issue try to check \r\n\r\nthe group and the permission also use the full path of the command \r\n\r\nI hope it&#39;s help full",
                "title": "Trying to run command line jq from php"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1649518894,
        "creation_date": 1649518068,
        "question_id": 71809428,
        "body_markdown": "I have been trying to run this PHP script. There is no output whatsoever and I cannot seem to understand the reason. \r\n\r\n\r\n    &lt;?php\r\n\r\n\techo &quot;Example DOI Query &lt;be&gt;&quot;;\r\n\r\n\t$doi = someDOIvalue;\r\n\r\n\techo &#39;DOI: &#39;.$doi.&#39;&lt;br&gt;&#39;;\r\n\r\n\t$query = &#39;curl -LH &quot;Accept: application/json&quot; http://doi.org/&#39;;\r\n\r\n\t$cmd = $query.$doi.&quot; | jq &#39;.title&#39;&quot;;\r\n\r\n\techo $cmd;\r\n\r\n\t$title = shell_exec($cmd);\r\n\r\n\techo &#39;Title:&lt;br&gt;&#39;.$title;\r\n\r\n    ?&gt;\r\n\r\n\r\nHowever, when I try to use the same command on my LINUX command line (as below), it works perfectly fine. \r\n\r\n\r\n\r\n    curl -LH &quot;Accept: application/json&quot; http://doi.org/10.1016/someDOIvalue | jq &#39;.title&#39; \r\n\r\n\r\nAny idea what I&#39;m doing wrong? \r\n",
        "link": "https://stackoverflow.com/questions/71809428/trying-to-run-command-line-jq-from-php",
        "title": "Trying to run command line jq from php"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1649520332,
                "post_id": 71809695,
                "comment_id": 126898839,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1694936147,
                "last_edit_date": 1694936147,
                "creation_date": 1649520524,
                "answer_id": 71809747,
                "question_id": 71809695,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**Update:** As of [jq 1.7](https://github.com/jqlang/jq/releases/tag/jq-1.7), `.data | .[]` can be abbreviated as either `.data[]` or `.data.[]`. Thus, it is now equally valid to write\r\n```sh\r\njq &quot;.data.[].paragraphs.[].qas.[].question&quot; dev-v2.0.json | head\r\n```\r\n\r\n---\r\n\r\n- `.[]` accesses the members of the array (or object) in the context `.`.\r\n- `.data | .[]` accesses a field called `data` of the object in the context `.`. By piping it into the next filter, the accessed field becomes the new context `.`, so `.[]` accesses the members of the array (or object) in that context.\r\n- `.data[]` accesses the members of the array (or object) in a field called `data` of the object in the context `.`.\r\n\r\n~~~sh\r\njq &quot;.data[].paragraphs[].qas[].question&quot; dev-v2.0.json | head\r\n~~~\r\n~~~json\r\n&quot;In what country is Normandy located?&quot;\r\n&quot;When were the Normans in Normandy?&quot;\r\n&quot;From which countries did the Norse originate?&quot;\r\n&quot;Who was the Norse leader?&quot;\r\n&quot;What century did the Normans first gain their separate identity?&quot;\r\n&quot;Who gave their name to Normandy in the 1000&#39;s and 1100&#39;s&quot;\r\n&quot;What is France a region of?&quot;\r\n&quot;Who did King Charles III swear fealty to?&quot;\r\n&quot;When did the Frankish identity emerge?&quot;\r\n&quot;Who was the duke in the battle of Hastings?&quot;\r\n~~~\r\n",
                "title": "Concise notation for JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1694936141,
                "last_edit_date": 1694936141,
                "creation_date": 1649520722,
                "answer_id": 71809768,
                "question_id": 71809695,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Before [jq 1.7](https://github.com/jqlang/jq/releases/tag/jq-1.7), the only valid abbreviated form of `.x|.[]|.y` was `.x[].y`. Now, `.x.[].y` is equally valid.\r\n",
                "title": "Concise notation for JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1694936147,
        "creation_date": 1649520085,
        "question_id": 71809695,
        "body_markdown": "According to [jq tutorial, end of &#167;4.1](https://www.baeldung.com/linux/jq-command-json#1-iteration), there is a compact notation for jq where the `|` operator (and the spaces surrounding it) can just be skipped.\r\n\r\nOn the SQuAD 2.0 devset ([download link](https://rajpurkar.github.io/SQuAD-explorer/dataset/dev-v2.0.json)), the following expressions work:\r\n\r\n\t$&gt; cat src/dev-v2.0.json | jq &quot;.data&quot; | jq &quot;.[]&quot; | jq &quot;.paragraphs&quot; | jq &quot;.[]&quot; | jq &quot;.qas&quot; | jq &quot;.[]&quot; | jq &quot;.question&quot; | head\r\n\t$&gt; cat src/dev-v2.0.json | jq &quot;.data | .[] | .paragraphs | .[] | .qas | .[] | .question&quot; | head\r\n\r\nBut the &quot;concise&quot; notation doesn&#39;t:\r\n\r\n\t$&gt; cat src/dev-v2.0.json | jq &quot;.data.[].paragraphs.[].qas.[].question&quot; | head\r\n\r\n\tjq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:jq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\t.data.[].paragraphs.[].qas.[].question      \r\n\tjq: 1 compile error\r\n\r\nAs the error hints, this *may* be an encoding issue, but with the quotes around the expression, this seems unlikely. I thus follow the [jq recommendation](https://github.com/stedolan/jq/issues/new?assignees=&amp;labels=&amp;template=bug_report.md) to ask that at StackOverflow: What am I missing here?\r\n\r\nI am using Ubuntu 20.04.3 LTS, jq-1.6, bash 5.0.17(1).\r\n",
        "link": "https://stackoverflow.com/questions/71809695/concise-notation-for-jq",
        "title": "Concise notation for JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1649557906,
                "last_edit_date": 1649557906,
                "creation_date": 1649536645,
                "answer_id": 71811716,
                "question_id": 71811677,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```[.a1[] | select(.group_sourceId | startswith(&quot;sunday&quot;)) | .ids[]] | sort[]```\r\n\r\nproduces the sorted listing.  If you want the unique values, use `unique` instead of `sort`.  If you want the output as a line of CSV, you could replace the final `[]` with `| @csv`.\r\n",
                "title": "JQ: combine arrays into single string"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1649537134,
                "creation_date": 1649537134,
                "answer_id": 71811774,
                "question_id": 71811677,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another approach using `map`. Also, you could use `==` to test for an exact match.\r\n```sh\r\njq -r &#39;.a1 | map(select(.group_sourceId == &quot;sunday&quot;).ids[]) | join(&quot;,&quot;)&#39;\r\n```\r\n```json\r\nc,d,e,f,g,h\r\n```\r\n[Demo](https://jqplay.org/s/RBq9p5xQFP)",
                "title": "JQ: combine arrays into single string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1649557906,
        "creation_date": 1649536316,
        "question_id": 71811677,
        "body_markdown": "Here is my json file. I would like to get string &quot;c,d,e,f,g,h&quot; using JQ query.\r\n```\r\n{\r\n    &quot;a1&quot;: [\r\n      {\r\n        &quot;group_sourceId&quot;: &quot;monday&quot;,\r\n        &quot;ids&quot;: [&quot;a&quot;, &quot;b&quot;]\r\n      },\r\n      {\r\n        &quot;group_sourceId&quot;: &quot;sunday&quot;,\r\n        &quot;ids&quot;: [&quot;c&quot;, &quot;d&quot;]\r\n      },\r\n      {\r\n        &quot;group_sourceId&quot;: &quot;sunday&quot;,\r\n        &quot;ids&quot;: [&quot;e&quot;, &quot;f&quot;]\r\n      },\r\n      {\r\n        &quot;group_sourceId&quot;: &quot;sunday&quot;,\r\n        &quot;ids&quot;: [&quot;g&quot;, &quot;h&quot;]\r\n      }\r\n    ],\r\n    &quot;m1&quot;: [\r\n      {\r\n        &quot;group_sourceId&quot;: &quot;sunday&quot;\r\n      },\r\n      {\r\n        &quot;group_sourceId&quot;: &quot;sunday&quot;\r\n      }\r\n    ]\r\n}\r\n```\r\nThis is what I tried.\r\n\r\n**cat /tmp/example.json  | jq -r &#39;.a1[] | select(.group_sourceId | startswith(&quot;sunday&quot;)) | .ids&#39;**\r\n\r\nreturns\r\n```\r\n[\r\n  &quot;c&quot;,\r\n  &quot;d&quot;\r\n]\r\n[\r\n  &quot;e&quot;,\r\n  &quot;f&quot;\r\n]\r\n[\r\n  &quot;g&quot;,\r\n  &quot;h&quot;\r\n]\r\n```\r\nthen\r\n\r\n**cat /tmp/example.json  | jq -r &#39;.a1[] | select(.group_sourceId | startswith(&quot;sunday&quot;)) | .ids | join(&quot;,&quot;)&#39;**\r\n\r\n```\r\nc,d\r\ne,f\r\ng,h\r\n```\r\nHow to get &quot;c,d,e,f,g,h&quot; as a output considering there could be any number of &quot;ids&quot; in &quot;a1&quot; object and any number of strings in &quot;ids&quot; array?\r\n",
        "link": "https://stackoverflow.com/questions/71811677/jq-combine-arrays-into-single-string",
        "title": "JQ: combine arrays into single string"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1649611109,
                "creation_date": 1649611109,
                "answer_id": 71818915,
                "question_id": 71818537,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just `walk` the path with the expression to select an object type when `.c` equals to your desired value\r\n\r\n```none\r\njq &#39;walk(if type == &quot;object&quot; and .c == &quot;text1&quot; then .c |= &quot;newtext&quot; else . end)&#39;\r\n```\r\n\r\n[jqplay demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/QA2Nkuajgr",
                "title": "JQ - Deep child value replace through wildcard search and merge to the original JSON"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1649623986,
                "creation_date": 1649623986,
                "answer_id": 71820481,
                "question_id": 71818537,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Along the lines of your attempt:\r\n\r\n    (.. | objects | select(has(&quot;c&quot;)) | .c) |= (sub(&quot;^text1$&quot;;&quot;newtext&quot;))\r\n\r\nor in order of increasing brevity:\r\n\r\n    (.. | select(try has(&quot;c&quot;)) | .c) |= (sub(&quot;^text1$&quot;;&quot;newtext&quot;))\r\n\r\n    (.. | select(has(&quot;c&quot;)?) | .c) |= (sub(&quot;^text1$&quot;;&quot;newtext&quot;))\r\n",
                "title": "JQ - Deep child value replace through wildcard search and merge to the original JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1649623986,
        "creation_date": 1649608339,
        "question_id": 71818537,
        "body_markdown": "My question is similar to https://stackoverflow.com/questions/41389347/unix-jq-parsing-wildcards but want to merge to the original JSON.\r\n\r\nSay, input JSON:\r\n\r\n```\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;1&quot;: {\r\n      &quot;c&quot;: &quot;text1&quot;\r\n    },\r\n    &quot;999&quot;: {\r\n      &quot;c&quot;: &quot;text99&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI want to manipulate the inner `&quot;c&quot;: &quot;text1&quot;` and modify it to `&quot;c&quot;: &quot;newtext&quot;`. But, also need to merge with the original JSON. IOW, it is not about extracting, but about manipulating.\r\n\r\nExpected output:\r\n\r\n```\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;1&quot;: {\r\n      &quot;c&quot;: &quot;newtext&quot;\r\n    },\r\n    &quot;999&quot;: {\r\n      &quot;c&quot;: &quot;text99&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n\r\nI tried:\r\n\r\n```\r\n.. | .c? |= (sub(&quot;^text1$&quot;;&quot;newtext&quot;))\r\n```\r\nBut, it throws `null (null) cannot be matched, as it is not a string`\r\n\r\njqplay: https://jqplay.org/s/2nFAus6Umz",
        "link": "https://stackoverflow.com/questions/71818537/jq-deep-child-value-replace-through-wildcard-search-and-merge-to-the-original",
        "title": "JQ - Deep child value replace through wildcard search and merge to the original JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1649644229,
                "creation_date": 1649644229,
                "answer_id": 71822129,
                "question_id": 71821374,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The &quot;,&quot; operator is the magic ingredient you seem to be looking for:\r\n\r\n    .items[].spec | keys[] as $k | $k, .[$k]\r\n\r\n",
                "title": "iterate on key to get the contents of the key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1649644229,
        "creation_date": 1649634231,
        "last_edit_date": 1649638773,
        "question_id": 71821374,
        "body_markdown": "IF I have json that looks like\r\n\r\n```\r\n{\r\n    &quot;items&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;issue1&quot;,\r\n            &quot;spec&quot;: {\r\n                &quot;config&quot;: {\r\n                    &quot;setting1&quot;: abc,\r\n                    &quot;setting2&quot;: {\r\n                        &quot;name&quot;: &quot;xyz&quot;\r\n                    }\r\n                },\r\n                &quot;files&quot;: {\r\n                    &quot;name&quot;: &quot;cde&quot;,\r\n                    &quot;path&quot;: &quot;/home&quot;\r\n                },\r\n                &quot;program&quot;: {\r\n                    &quot;name&quot;: &quot;apache&quot;\r\n                }\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nand I want to have iteration at .items[0].spec where the key config,files,program&#39;s contents can be shown.. something like\r\n\r\n```\r\nconfig:\r\n{\r\n    &quot;setting1&quot;: abc,\r\n    &quot;setting2&quot;: {\r\n        &quot;name&quot;: &quot;xyz&quot;\r\n    }\r\n}\r\n\r\nfiles:\r\n{\r\n    &quot;name&quot;: &quot;cde&quot;,\r\n    &quot;path&quot;: &quot;/home&quot;\r\n}\r\n\r\nprogram:\r\n{\r\n    &quot;name&quot;: &quot;apache&quot;\r\n}\r\n```\r\n\r\nand there might be things more or less than config/files/programs for each items.\r\n\r\nI know that I can get the list of keys by `jq -r &#39;.items[0].spec| to_entries[].key&#39;` but not sure about formating the output and getting the contents of .items[].spec.xxxxx like above.\r\n\r\nI also got very close by `jq -r &#39;{test: .items[0].spec  | with_entries(select(.value != null)) }&#39;` but I want to seperate each item per key\r\n\r\n\r\nAlso this got me even closer! but how do you get the json syntax of the object to display uncompressed?\r\n\r\n`jq -r &#39;.items[].spec | keys[] as $k | &quot;\\($k):\\n   \\(.[$k])&quot;&#39;`",
        "link": "https://stackoverflow.com/questions/71821374/iterate-on-key-to-get-the-contents-of-the-key",
        "title": "iterate on key to get the contents of the key"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649670792,
                "creation_date": 1649670792,
                "answer_id": 71825819,
                "question_id": 71825711,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n&lt; file.json jq -r &#39;to_entries\r\n                   | .[] \r\n                   | .key as $k\r\n                   | ((.value | to_entries )[]\r\n                      | [$k, .key, .value])\r\n                   | @csv&#39;\r\n```\r\nOutput:\r\n```\r\n0,&quot;a&quot;,1\r\n0,&quot;b&quot;,10\r\n1,&quot;a&quot;,2\r\n1,&quot;d&quot;,&quot;fred&quot;\r\n1,&quot;e&quot;,30\r\n```\r\nYou just need to remove the double quotes.",
                "title": "How to use jq to format array of objects to separated list of key values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649683667,
                "creation_date": 1649683667,
                "answer_id": 71828702,
                "question_id": 71825711,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`to_entries` can be used to loop over the elements of arrays and objects in a way that gives both the key (index) and the value of the element.\r\n\r\n```sh\r\njq -r &#39;\r\n   to_entries[] |\r\n   .key as $id |\r\n   .value |\r\n   to_entries[] |\r\n   [ $id, .key, .value ] |\r\n   join(&quot;|&quot;)\r\n&#39;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/hWKu2TbJ3z) on jqplay\r\n\r\n\r\nReplace `join(&quot;|&quot;)` with `@csv` to get proper CSV.\r\n",
                "title": "How to use jq to format array of objects to separated list of key values"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1649701675,
                "creation_date": 1649701675,
                "answer_id": 71832612,
                "question_id": 71825711,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution using `tostream`, which creates a stream of paths and their values. Filter out those having values using `select`, `flatten` to align both, and `join` for the output format:\r\n~~~sh\r\njq -r &#39;tostream | select(has(1)) | flatten | join(&quot;|&quot;)&#39;\r\n~~~\r\n~~~json\r\n0|a|1\r\n0|b|10\r\n1|a|2\r\n1|d|fred\r\n1|e|30\r\n~~~\r\n[Demo](https://jqplay.org/s/VQqmJ11D83)\r\n\r\nOr a very similar one using `paths` to get the paths, `scalars` for the filter, and `getpath` for the corresponding value:\r\n~~~sh\r\njq -r &#39;paths(scalars) as $p | [$p[], getpath($p)] | join(&quot;|&quot;)&#39;\r\n~~~\r\n~~~json\r\n0|a|1\r\n0|b|10\r\n1|a|2\r\n1|d|fred\r\n1|e|30\r\n~~~\r\n[Demo](https://jqplay.org/s/ExGOQiaf7v)",
                "title": "How to use jq to format array of objects to separated list of key values"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1649701675,
        "creation_date": 1649670233,
        "question_id": 71825711,
        "body_markdown": "How can I (generically) transform the input file below to the output file below, using jq.  The record format of the output file is: array_index | key | value\r\n\r\n**Input file:**\r\n```\r\n[{&quot;a&quot;: 1, &quot;b&quot;: 10},\r\n {&quot;a&quot;: 2, &quot;d&quot;: &quot;fred&quot;, &quot;e&quot;: 30}]\r\n```\r\n**Output File:**\r\n```\r\n0|a|1\r\n0|b|10\r\n1|a|2\r\n1|d|fred\r\n1|e|30\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/71825711/how-to-use-jq-to-format-array-of-objects-to-separated-list-of-key-values",
        "title": "How to use jq to format array of objects to separated list of key values"
    },
    {
        "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": 0,
                "creation_date": 1649709633,
                "post_id": 71834015,
                "comment_id": 126940693,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3036185,
                    "reputation": 53,
                    "user_id": 6849597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IuhuY.png?s=256",
                    "display_name": "Creative Arc",
                    "link": "https://stackoverflow.com/users/6849597/creative-arc"
                },
                "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": 1649710626,
                "post_id": 71834015,
                "comment_id": 126940975,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649711476,
                "creation_date": 1649711476,
                "answer_id": 71834349,
                "question_id": 71834015,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the alternative operator //, and you parentheses to create &#39;temporary&#39; values:\r\n\r\n```\r\necho &#39;[{&quot;a&quot;: &quot;rst&quot;}, {&quot;b&quot;:&quot;rst&quot;}]&#39; | jq -cr &#39;.[]| { a: ( .a // &quot;-&quot; ) }&#39;\r\n{&quot;a&quot;:&quot;rst&quot;}\r\n{&quot;a&quot;:&quot;-&quot;}\r\n``` \r\n\r\nTransposed\r\n```\r\ncurl https://MyUrl | jq -cr   &#39;.[] | {id: .id, completed: .completed,  content: .content  | sub(&quot;,&quot;; &quot;&quot;) , assignee: ( .assignees[] | objects | .name ) // &quot;-&quot; } &#39;\r\n```",
                "title": "Display row when field value is absent"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649711511,
                "creation_date": 1649711511,
                "answer_id": 71834356,
                "question_id": 71834015,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `if` might be easiest:\r\n```\r\nassignee: (if .assignees|type == &quot;array&quot; \r\n           then .assignees[] | objects | .name\r\n           else &quot;-&quot; end)\r\n```",
                "title": "Display row when field value is absent"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649791533,
                "creation_date": 1649791533,
                "answer_id": 71848127,
                "question_id": 71834015,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks to all of you! This minor change seemed to do the trick, with ```//```\r\n\r\n```&#39;.[] | {id: .id, completed: .completed,  content: .content  | sub(&quot;,&quot;; &quot;&quot;) , assignee:  (  .assignees[]  .name // &quot;TBD&quot; )} &#39;```\r\n\r\nI simplified the `.assignees[] | objects | .name` portion which made the Alternative `//` operator work on the first try.",
                "title": "Display row when field value is absent"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1649791533,
        "creation_date": 1649709477,
        "question_id": 71834015,
        "body_markdown": "This bash one-liner is working great.\r\n\r\n```curl https://MyUrl | jq -cr   &#39;.[] | {id: .id, completed: .completed,  content: .content  | sub(&quot;,&quot;; &quot;&quot;) , assignee: .assignees[] | objects | .name} &#39;```\r\n\r\nThe output:\r\n\r\n```\r\n{&quot;id&quot;:4799371614,&quot;completed&quot;:false,&quot;content&quot;:&quot;todo item A&quot;,&quot;assignee&quot;:&quot;Goofy&quot;}\r\n{&quot;id&quot;:4799371614,&quot;completed&quot;:false,&quot;content&quot;:&quot;todo item B&quot;,&quot;assignee&quot;:&quot;Donald Duck&quot;}\r\n{&quot;id&quot;:4799371930,&quot;completed&quot;:false,&quot;content&quot;:&quot;todo item C&quot;,&quot;assignee&quot;:&quot;Mickey&quot;}\r\n{&quot;id&quot;:4799371981,&quot;completed&quot;:false,&quot;content&quot;:&quot;todo item D&quot;,&quot;assignee&quot;:&quot;Mickey&quot;}\r\n```\r\n\r\nAlmost perfect! But, there are actually 9 rows. It just happens that the 4 entries above have the .assignees array.\r\n\r\nIs there a way I can return rows, even if .assignees is empty? Perhaps output a &quot;-&quot; or &quot;empty&quot; value?\r\n\r\nExample output if I remove the .assignees filter:\r\n\r\n```\r\n{&quot;id&quot;:4799371614,&quot;completed&quot;:false,&quot;content&quot;:&quot;todo item A&quot;}\r\n{&quot;id&quot;:4799371614,&quot;completed&quot;:false,&quot;content&quot;:&quot;todo item B&quot;}\r\n{&quot;id&quot;:4799371930,&quot;completed&quot;:false,&quot;content&quot;:&quot;todo item C&quot;}\r\n{&quot;id&quot;:4799371981,&quot;completed&quot;:false,&quot;content&quot;:&quot;todo item D&quot;}\r\n{&quot;id&quot;:5799371614,&quot;completed&quot;:false,&quot;content&quot;:&quot;todo item E&quot;}\r\n{&quot;id&quot;:6799371614,&quot;completed&quot;:false,&quot;content&quot;:&quot;todo item F&quot;}\r\n{&quot;id&quot;:7799371930,&quot;completed&quot;:false,&quot;content&quot;:&quot;todo item G&quot;}\r\n{&quot;id&quot;:8799371981,&quot;completed&quot;:false,&quot;content&quot;:&quot;todo item H&quot;}\r\n{&quot;id&quot;:9799371981,&quot;completed&quot;:false,&quot;content&quot;:&quot;todo item I&quot;}\r\n```\r\nThat is, E-I do not have .assignees, so they are not part of the first jq output, but they are part of the first.",
        "link": "https://stackoverflow.com/questions/71834015/display-row-when-field-value-is-absent",
        "title": "Display row when field value is absent"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 127329,
                    "reputation": 4261,
                    "user_id": 324407,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/e2db7bf7197630d0c180d741ce927b2c?s=256&d=identicon&r=PG",
                    "display_name": "Delta George",
                    "link": "https://stackoverflow.com/users/324407/delta-george"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649716026,
                "post_id": 71834966,
                "comment_id": 126942311,
                "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": 1649716618,
                "post_id": 71834966,
                "comment_id": 126942418,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1649722520,
                "creation_date": 1649722520,
                "answer_id": 71835611,
                "question_id": 71834966,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given a string `&quot;Tiger Woods plays golf&quot;`\r\n\r\nusing jq&#39;s expression `gsub(&quot;\\\\s&quot;;&quot;+&quot;)` - you should be able to replace those spaces by &quot;+&quot; characters\r\n\r\nresult[1]: `&quot;Tiger+Woods+plays+golf&quot;`\r\n\r\n\r\n[1] https://jqplay.org/s/SxiKIClW13 \r\n\r\n",
                "title": "Replace spaces with plus signs in string using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1649722520,
        "creation_date": 1649715784,
        "question_id": 71834966,
        "body_markdown": "Let&#39;s say I have the following phrase:\r\n\r\n```\r\nTiger Woods plays golf\r\n```\r\n\r\nI&#39;m trying to use [jq](https://stedolan.github.io/jq/) to replace all of the spaces with `+` signs so the final result would be:\r\n\r\n```\r\nTiger+Woods+plays+golf\r\n```\r\n\r\nIs there any way to do this?",
        "link": "https://stackoverflow.com/questions/71834966/replace-spaces-with-plus-signs-in-string-using-jq",
        "title": "Replace spaces with plus signs in string using jq"
    },
    {
        "tags": [
            "bash",
            "jq",
            "herestring"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649757400,
                "post_id": 71840560,
                "comment_id": 126951376,
                "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": 0,
                "creation_date": 1649757421,
                "post_id": 71840560,
                "comment_id": 126951383,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 274681,
                    "reputation": 12207,
                    "user_id": 567059,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/7d7d39a98d3d247926786bb60208893b?s=256&d=identicon&r=PG",
                    "display_name": "David Gard",
                    "link": "https://stackoverflow.com/users/567059/david-gard"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1649757600,
                "post_id": 71840560,
                "comment_id": 126951450,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1649758120,
                "post_id": 71840560,
                "comment_id": 126951626,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 274681,
                    "reputation": 12207,
                    "user_id": 567059,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/7d7d39a98d3d247926786bb60208893b?s=256&d=identicon&r=PG",
                    "display_name": "David Gard",
                    "link": "https://stackoverflow.com/users/567059/david-gard"
                },
                "reply_to_user": {
                    "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": 1649758556,
                "post_id": 71840560,
                "comment_id": 126951767,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 274681,
                    "reputation": 12207,
                    "user_id": 567059,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/7d7d39a98d3d247926786bb60208893b?s=256&d=identicon&r=PG",
                    "display_name": "David Gard",
                    "link": "https://stackoverflow.com/users/567059/david-gard"
                },
                "reply_to_user": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649758859,
                "post_id": 71840560,
                "comment_id": 126951868,
                "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": 0,
                "creation_date": 1649758899,
                "post_id": 71840560,
                "comment_id": 126951884,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 274681,
                    "reputation": 12207,
                    "user_id": 567059,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/7d7d39a98d3d247926786bb60208893b?s=256&d=identicon&r=PG",
                    "display_name": "David Gard",
                    "link": "https://stackoverflow.com/users/567059/david-gard"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1649759684,
                "post_id": 71840560,
                "comment_id": 126952148,
                "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": 0,
                "creation_date": 1649759878,
                "post_id": 71840560,
                "comment_id": 126952202,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 274681,
                    "reputation": 12207,
                    "user_id": 567059,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/7d7d39a98d3d247926786bb60208893b?s=256&d=identicon&r=PG",
                    "display_name": "David Gard",
                    "link": "https://stackoverflow.com/users/567059/david-gard"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1649760460,
                "post_id": 71840560,
                "comment_id": 126952405,
                "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": 0,
                "creation_date": 1649760716,
                "post_id": 71840560,
                "comment_id": 126952503,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 274681,
                    "reputation": 12207,
                    "user_id": 567059,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/7d7d39a98d3d247926786bb60208893b?s=256&d=identicon&r=PG",
                    "display_name": "David Gard",
                    "link": "https://stackoverflow.com/users/567059/david-gard"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1649761160,
                "post_id": 71840560,
                "comment_id": 126952663,
                "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": 1,
                "creation_date": 1649761495,
                "post_id": 71840560,
                "comment_id": 126952804,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 274681,
                    "reputation": 12207,
                    "user_id": 567059,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/7d7d39a98d3d247926786bb60208893b?s=256&d=identicon&r=PG",
                    "display_name": "David Gard",
                    "link": "https://stackoverflow.com/users/567059/david-gard"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649762045,
                "post_id": 71840560,
                "comment_id": 126952994,
                "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": 1,
                "creation_date": 1649762821,
                "post_id": 71840560,
                "comment_id": 126953298,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 274681,
                    "reputation": 12207,
                    "user_id": 567059,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/7d7d39a98d3d247926786bb60208893b?s=256&d=identicon&r=PG",
                    "display_name": "David Gard",
                    "link": "https://stackoverflow.com/users/567059/david-gard"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1649771710,
                "post_id": 71840560,
                "comment_id": 126956909,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1649761160,
                "last_edit_date": 1649761160,
                "creation_date": 1649760153,
                "answer_id": 71841244,
                "question_id": 71840560,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\nOUTPUTS=$(cat &lt;&lt;JSON\r\n[\r\n    {\r\n        &quot;OutputKey&quot;: &quot;ProxyFunctionName&quot;,\r\n        &quot;OutputValue&quot;: &quot;MyFunctionName&quot;,\r\n        &quot;Description&quot;: &quot;Proxy Lambda Function ARN&quot;\r\n    },\r\n    {\r\n        &quot;OutputKey&quot;: &quot;ProxyFunctionUrl&quot;,\r\n        &quot;OutputValue&quot;: &quot;https://my.function.url&quot;,\r\n        &quot;Description&quot;: &quot;Proxy Lambda Function invocation URL&quot;\r\n    }\r\n]\r\nJSON\r\n)\r\nOutputKey=ProxyFunctionName\r\n\r\nGET_FUNCTION_NAME_CMD=&quot;jq -r &#39;.[] | objects | select(.OutputKey == \\&quot;$OutputKey\\&quot;) | .OutputValue&#39;&quot;\r\necho &quot;$GET_FUNCTION_NAME_CMD &lt;&lt;&lt;\\&quot;\\$OUTPUTS\\&quot;&quot;\r\n# jq -r &#39;.[] | objects | select(.OutputKey == &quot;ProxyFunctionName&quot;) | .OutputValue&#39; &lt;&lt;&lt;&quot;$OUTPUTS&quot;\r\nFUNCTION_NAME=$(eval $GET_FUNCTION_NAME_CMD &lt;&lt;&lt;&quot;$OUTPUTS&quot;)\r\necho $FUNCTION_NAME\r\n# MyFunctionName\r\n```",
                "title": "Bash command in variable with herestring as input"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1649761160,
        "creation_date": 1649757085,
        "last_edit_date": 1649761116,
        "question_id": 71840560,
        "body_markdown": "Using bash, I have a need to echo a series of commands before I run them. Take this example, which is nice and easy and works as expected. Note that all code examples have been run through [ShellCheck][1] which reports no issues detected.\r\n\r\n```shell\r\nOUTPUTS_CMD=(aws cloudformation describe-stacks --stack-name &quot;#{StackName}&quot; --query &#39;Stacks[0].Outputs&#39;)\r\necho &quot;${OUTPUTS_CMD[*]}&quot;\r\nOUTPUTS=$(&quot;${OUTPUTS_CMD[@]}&quot;)\r\n```\r\n\r\nHowever, other commands require input, and while I can successfully echo these commands, I can&#39;t actually get them to run.\r\n\r\n```shell\r\nGET_FUNCTION_NAME_CMD=(jq --raw-output &quot;&#39;map(select(.OutputKey == \\&quot;ProxyFunctionName\\&quot;)) | .[].OutputValue&#39;&quot;)\r\necho &quot;${GET_FUNCTION_NAME_CMD[*]} &lt;&lt;&lt; \\&quot;\\$OUTPUTS\\&quot;&quot;\r\nFUNCTION_NAME=$(&quot;${GET_FUNCTION_NAME_CMD[@]}&quot; &lt;&lt;&lt; &quot;$OUTPUTS&quot;)\r\n```\r\n\r\nThe above example outputs the following, which if copied and pasted returns the correct value.\r\n&gt; jq --raw-output &#39;map(select(.OutputKey == &quot;ProxyFunctionName&quot;)) | .[].OutputValue&#39; &lt;&lt;&lt; &quot;$OUTPUTS&quot;\r\n\r\nHowever, the command `&quot;${GET_FUNCTION_NAME_CMD[@]}&quot; &lt;&lt;&lt; &quot;$OUTPUTS&quot;` returns an error. The same error occurs if I `echo &quot;$OUTPUTS&quot;` and pipe that in to the command saved in the variable instead of using a herestring, so I believe the error is with how the command is defined in the array.\r\n\r\n```shell\r\n$ FUNCTION_NAME=$(&quot;${GET_FUNCTION_NAME_CMD[@]}&quot; &lt;&lt;&lt; &quot;$OUTPUTS&quot;)\r\n\r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&#39;map(select(.OutputKey == &quot;ProxyFunctionName&quot;)) | .[].OutputValue&#39;\r\njq: 1 compile error\r\n```\r\n\r\nHow can I get the command in the variable to run with a herestring?\r\n\r\n---\r\n\r\n#### Example value for `$OUTPUTS`\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;OutputKey&quot;: &quot;ProxyFunctionName&quot;,\r\n        &quot;OutputValue&quot;: &quot;MyFunctionName&quot;,\r\n        &quot;Description&quot;: &quot;Proxy Lambda Function ARN&quot;\r\n    },\r\n    {\r\n        &quot;OutputKey&quot;: &quot;ProxyFunctionUrl&quot;,\r\n        &quot;OutputValue&quot;: &quot;https://my.function.url&quot;,\r\n        &quot;Description&quot;: &quot;Proxy Lambda Function invocation URL&quot;\r\n    }\r\n]\r\n```\r\n\r\n\r\n  [1]: https://www.shellcheck.net/",
        "link": "https://stackoverflow.com/questions/71840560/bash-command-in-variable-with-herestring-as-input",
        "title": "Bash command in variable with herestring as input"
    },
    {
        "tags": [
            "jq",
            "localtime",
            "mktime"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649772133,
                "last_edit_date": 1649772133,
                "creation_date": 1649770988,
                "answer_id": 71843821,
                "question_id": 71841835,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes.\r\n\r\nFrom the jq docs:\r\n\r\n&gt; The `mktime` builtin consumes &quot;broken down time&quot; representations of time output by `gmtime` and `strptime`.\r\n\r\nYou originally passed a local time, but it expects a UTC time. As you surmised, this is why your original code failed and the latter code worked. jq&#39;s `mktime` is the inverse of `gmtime`.&lt;sup&gt;[1]&lt;/sup&gt;\r\n\r\n```none\r\n$ jq -rn &#39;now | ., ( gmtime | mktime )&#39;\r\n1649770973.430903\r\n1649770973\r\n```\r\n\r\njq does not appear to provide a means to convert from a local time to epoch time.&lt;sup&gt;[2]&lt;/sup&gt;\r\n\r\n---\r\n\r\n1. This differs from the behaviour of C&#39;s `mktime`. C&#39;s `mktime` expects a local time, making it the inverse of `localtime`.\r\n\r\n2. In C, `mktime` can serve both roles. While it normally converts from local time, it can also convert from UTC by setting the local time zone to UTC.\r\n",
                "title": "Chaining localtime and mktime in jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1649772133,
        "creation_date": 1649762978,
        "question_id": 71841835,
        "body_markdown": "If I do:\r\n\r\n```\r\n$ jq -cn &#39;now | localtime&#39;\r\n[2022,3,12,21,9,29.65448808670044,2,101]\r\n```\r\n\r\nIt correctly gives the &quot;broken down time&quot; representation of current local time.\r\n\r\nBut If I do:\r\n\r\n```\r\n$ jq -cn &#39;now | localtime | mktime | localtime&#39;\r\n[2022,3,13,7,10,36,3,102]\r\n```\r\n\r\nIt gives back a &quot;broken down time&quot; representation that is **different** than current local time.\r\n\r\nI think when output of `localtime` is converted to seconds since unix epoch by `mktime` it is converted wrongly because it wrongly assumes GMT time?\r\n\r\nIf I do:\r\n\r\n```\r\n$ jq -cn &#39;now | gmtime | mktime | localtime&#39;\r\n```\r\n\r\nNow this gives correct results (gives &quot;broken down time&quot; representation of current local time).\r\n\r\nAm I correct? Thanks.",
        "link": "https://stackoverflow.com/questions/71841835/chaining-localtime-and-mktime-in-jq",
        "title": "Chaining localtime and mktime in jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1649768671,
                "last_edit_date": 1649768671,
                "creation_date": 1649768247,
                "answer_id": 71843173,
                "question_id": 71843093,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `unique_by` you can reduce the `.teams` array to those that differ in their `.team_id`, and with `select` and `length` you can filter for those that have strictly more than just one such item.\r\n~~~sh\r\njq &#39;.[] | select(.teams | unique_by(.team_id) | length &gt; 1)&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;id&quot;: 338744,\r\n  &quot;name&quot;: &quot;Eric Gonzales&quot;,\r\n  &quot;teams&quot;: [\r\n    {\r\n      &quot;year&quot;: &quot;2010-2011&quot;,\r\n      &quot;team_id&quot;: 12\r\n    },\r\n    {\r\n      &quot;year&quot;: &quot;2011-2012&quot;,\r\n      &quot;team_id&quot;: 17\r\n    },\r\n    {\r\n      &quot;year&quot;: &quot;2013-2014&quot;,\r\n      &quot;team_id&quot;: 17\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/eM5y829IQp)\r\n\r\nThis gives you a stream of objects (in case there&#39;s more than one result). Use `map(select(…))` instead of `.[] | select(…)` if you want to have them as an array.",
                "title": "jq filter items where values in a nested array array are different"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1649768671,
        "creation_date": 1649767925,
        "question_id": 71843093,
        "body_markdown": "Let&#39;s say I have the following json. I want to get all the items where the &quot;employee&quot; had different teams over the year. \r\n```\r\n[\r\n    {\r\n        &quot;id&quot;: 122343,\r\n        &quot;name&quot;: &quot;Tom Muller&quot;,\r\n        &quot;teams&quot;: [\r\n            {\r\n                &quot;year&quot;: &quot;2010-2011&quot;,\r\n                &quot;team_id&quot;: 27\r\n            },\r\n            {\r\n                &quot;year&quot;: &quot;2011-2012&quot;,\r\n                &quot;team_id&quot;: 27\r\n            },\r\n            {\r\n                &quot;year&quot;: &quot;2013-2014&quot;,\r\n                &quot;team_id&quot;: 27\r\n            }\r\n        ]\r\n    },\r\n    {\r\n        &quot;id&quot;: 338744,\r\n        &quot;name&quot;: &quot;Eric Gonzales&quot;,\r\n        &quot;teams&quot;: [\r\n            {\r\n                &quot;year&quot;: &quot;2010-2011&quot;,\r\n                &quot;team_id&quot;: 12\r\n            },\r\n            {\r\n                &quot;year&quot;: &quot;2011-2012&quot;,\r\n                &quot;team_id&quot;: 17\r\n            },\r\n            {\r\n                &quot;year&quot;: &quot;2013-2014&quot;,\r\n                &quot;team_id&quot;: 17\r\n            }\r\n        ]\r\n    }\r\n]\r\n```\r\nI would like to query the array with jq and the output would return \r\n```\r\n{\r\n        &quot;id&quot;: 338744,\r\n        &quot;name&quot;: &quot;Eric Gonzales&quot;,\r\n        &quot;teams&quot;: [\r\n            {\r\n                &quot;year&quot;: &quot;2010-2011&quot;,\r\n                &quot;team_id&quot;: 12\r\n            },\r\n            {\r\n                &quot;year&quot;: &quot;2011-2012&quot;,\r\n                &quot;team_id&quot;: 17\r\n            },\r\n            {\r\n                &quot;year&quot;: &quot;2013-2014&quot;,\r\n                &quot;team_id&quot;: 17\r\n            }\r\n        ]\r\n    }\r\n```\r\n\r\nHow would I write such a query ?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/71843093/jq-filter-items-where-values-in-a-nested-array-array-are-different",
        "title": "jq filter items where values in a nested array array are different"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1649823937,
                "post_id": 71851534,
                "comment_id": 126970618,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649828858,
                "last_edit_date": 1649828858,
                "creation_date": 1649826657,
                "answer_id": 71852182,
                "question_id": 71851534,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unlike in XML, there&#39;s no concept of attributes in jq. You&#39;ll need to delete from objects. \r\n\r\nTo delete an element of an object, you need to use `del( obj[ key ] )` (or use `with_entries`). You can get a stream of the keys of an object using  `keys[]`/`keys_unsorted[]` and filter out the ones you don&#39;t want to delete.\r\n\r\nFinally, you need to invert the result of `test` because you want to delete those that *don&#39;t* match.\r\n\r\n---\r\n\r\nAfter fixing these problems, we get the following:\r\n\r\n ```jq\r\nINDEX( &quot;foo&quot;, &quot;bar&quot; ) as $keep |\r\ndel(\r\n   .. | objects |\r\n   .[\r\n      keys_unsorted[] |\r\n      select( $keep[ . ] | not )\r\n   ]\r\n)\r\n```\r\n\r\n[Demo](https://jqplay.org/s/GAS-0cz9qz) on jqplay\r\n\r\nNote that I substituted the regex match with a dictionary lookup. You could use `test( &quot;^(?:foo|bar)\\\\z&quot; )` in lieu of `$keep[ . ]`, but a dictionary lookup should be faster than a regex match. And it should be less error-prone too, considering you [misused `$`](https://jqplay.org/s/El64xj_xXM) and `(...)` in lieu of `\\z` and `(?:...)`.\r\n\r\n---\r\n\r\nThe above visits deleted branches for nothing. We can avoid that by using `walk` instead of `..`.\r\n\r\n```jq\r\nINDEX( &quot;foo&quot;, &quot;bar&quot; ) as $keep |\r\nwalk(\r\n   if type == &quot;object&quot; then \r\n      del(\r\n         .[\r\n            keys_unsorted[] |\r\n            select( $keep[ . ] | not )\r\n         ]\r\n      )\r\n   else\r\n      .\r\n   end\r\n)\r\n```\r\n\r\n[Demo](https://jqplay.org/s/E7GDsXfouP) on jqplay\r\n\r\n---\r\n\r\nSince I mentioned one could use `with_entries` instead of `del`, I&#39;ll demonstrate.\r\n\r\n```jq\r\nINDEX( &quot;foo&quot;, &quot;bar&quot; ) as $keep |\r\nwalk(\r\n   if type == &quot;object&quot; then \r\n      with_entries( select( $keep[ .key ] ) )\r\n   else\r\n      .\r\n   end\r\n)\r\n```\r\n\r\n[Demo](https://jqplay.org/s/DSa0F_shSV) on jqplay\r\n",
                "title": "How can I delete all keys that don&#39;t match certain names with JQ?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649914948,
                "last_edit_date": 1649914948,
                "creation_date": 1649834114,
                "answer_id": 71853382,
                "question_id": 71851534,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a space-efficient, walk-free approach, tailored for the case of a WHITELIST.  It uses the so-called &quot;streaming&quot; parser, so the invocation would look like this:\r\n```\r\njq -n --stream --argjson whitelist WHITELIST -f program.jq input.json\r\n```\r\nwhere WHITELIST is a JSON array of the names of the keys to be deleted, and\r\nwhere program.jq is a file containing the program:\r\n\r\n```\r\n# Input: an array\r\n# Output: the longest head of the array that includes only numbers or items in the dictionary\r\ndef acceptable($dict):\r\n  last(label $out\r\n       | foreach .[] as $x ([];\r\n           if ($x|type == &quot;number&quot;) or $dict[$x] then . + [$x]\r\n           else ., break $out\r\n           end));\r\n\r\nINDEX( $whitelist[]; .) as $dict\r\n| fromstream(inputs\r\n    | if length==2\r\n      then (.[0] | acceptable($dict)) as $p\r\n      | if   ($p|length) == (.[0]|length) - 1 then .[0] = $p | .[1] = {}\r\n        elif ($p|length) &lt;  (.[0]|length) then empty\r\n        else .\r\n        end\r\n      else .\r\n      end )\r\n```\r\n\r\nNote: The reason this is relatively complicated is that it assumes that you want to retain objects all of whose keys have been removed, as illustrated in the following example.  If that is not the case, then the required jq program is much simpler.\r\n\r\n---\r\nExample:\r\n\r\nWHITELIST: `&#39;[&quot;items&quot;, &quot;config&quot;, &quot;spec&quot;, &quot;setting2&quot;, &quot;name&quot;]&#39;`\r\n\r\ninput.json:\r\n```\r\n{\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;issue1&quot;,\r\n      &quot;spec&quot;: {\r\n        &quot;config&quot;: {\r\n          &quot;setting1&quot;: &quot;abc&quot;,\r\n          &quot;setting2&quot;: {\r\n            &quot;name&quot;: &quot;xyz&quot;\r\n          }\r\n        },\r\n        &quot;files&quot;: {\r\n          &quot;name&quot;: &quot;cde&quot;,\r\n          &quot;path&quot;: &quot;/home&quot;\r\n        },\r\n        &quot;program&quot;: {\r\n          &quot;name&quot;: &quot;apache&quot;\r\n        }\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: {\r\n        &quot;etc&quot;: 0\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nOutput:\r\n```\r\n{\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;issue1&quot;,\r\n      &quot;spec&quot;: {\r\n        &quot;config&quot;: {\r\n          &quot;setting2&quot;: {\r\n            &quot;name&quot;: &quot;xyz&quot;\r\n          }\r\n        }\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: {}\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\n",
                "title": "How can I delete all keys that don&#39;t match certain names with JQ?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1649871049,
                "last_edit_date": 1649871049,
                "creation_date": 1649835553,
                "answer_id": 71853649,
                "question_id": 71851534,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that uses a specialized variant of `walk` for efficiency (*).  It retains objects all keys of which are removed; only trivial changes are needed if a blacklist or some other criterion (e.g., regexp-based) is given instead. WHITELIST should be a JSON array of the key names to be retained.\r\n```\r\njq --argjson whitelist WHITELIST &#39;\r\ndef retainKeys($array):\r\n  INDEX($array[]; .) as $keys\r\n  | def r:\r\n      if type == &quot;object&quot; \r\n      then with_entries( select($keys[.key]) )\r\n      | map_values( r )\r\n      elif type == &quot;array&quot; then map( r )\r\n      else .\r\n      end;\r\n  r;\r\n\r\n  retainKeys($whitelist)\r\n\r\n&#39; input.json\r\n```\r\n\r\n---\r\n(*) Note for example:\r\n1. the use of `INDEX`\r\n2. the recursive function, `r`, has arity 0\r\n3. for objects, the top-level deletion occurs first.\r\n ",
                "title": "How can I delete all keys that don&#39;t match certain names with JQ?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1649905731,
                "creation_date": 1649905731,
                "answer_id": 71866054,
                "question_id": 71851534,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In analogy to your approach using `..` and `del`, you could use `paths` and `delpaths` to operate on a stream of path arrays, and delete a given path if not all of its elements meet your conditions.\r\n\r\n~~~sh\r\ndelpaths([paths | select(all(IN(&quot;foo&quot;, &quot;bar&quot;) or type == &quot;number&quot;) | not)])\r\n~~~\r\n\r\nFor the condition I used `IN(&quot;foo&quot;, &quot;bar&quot;)` but `(type == &quot;string&quot; and test(&quot;^(foo|bar)$&quot;))` would work as well. To also retain array elements (which have numeric indices), I added `or type == &quot;number&quot;`.",
                "title": "How can I delete all keys that don&#39;t match certain names with JQ?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1650236852,
                "last_edit_date": 1650236852,
                "creation_date": 1650232150,
                "answer_id": 71905727,
                "question_id": 71851534,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I am going to put my own tentative answer here.\r\n\r\nThe thing is, the solution I had already in my question, meaning I can select keys during forward navigation, but I cannot find out the path leading up to the present value. \r\n\r\nI looked around in the source code of jq to see how come we cannot inquire the path leading up to the present value, so we could ask for the key string or array index of the present value. And indeed it looks like jq does not track the path while it walks through the input structure. \r\n\r\nI think this is actually a huge opportunity forfeited that could be so easily kept track during the tree walk.\r\n\r\nThis is why I continue thinking that XML with XSLT and XPath is a much more robust data representation and tool chain than JSON. In fact, I find JSON harder to read even than XML. The benefit of the JSON being so close to javascript is really only relevant if - as I do in some cases - I read the JSON as a javascript source code assigning it to a variable, and then instrument it by changing the prototype of the anonymous JSON object so that I have methods to go with them. But changing the prototype is said to cause slowness. Though I don&#39;t think it does when setting it for otherwise anonymous JSON objects.\r\n\r\nThere is [JsonPath][1] that tries (by way of the name) to be something like what XPath is for XML. But it is a poor substitute and also has no way to navigate up the parent (or then sibling) axes. \r\n\r\nSo, in summary, while selecting by key in white or black lists is possible in principle, it is quite hard, because a pretty easy to have feature of a JSON navigation language is not specified and not implemented. Other useful features that could be easily achieved in jq is backward navigation to parent or ancestor of the present value. Currently, if you want to navigate back, you need to capture the ancestor you want to get back to as a variable. It is possible, but jq could be massively improved by keeping track of ancestors and paths. \r\n\r\n\r\n  [1]: https://support.smartbear.com/alertsite/docs/monitors/api/endpoint/jsonpath.html",
                "title": "How can I delete all keys that don&#39;t match certain names with JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 0,
        "last_activity_date": 1650236852,
        "creation_date": 1649820781,
        "last_edit_date": 1649821213,
        "question_id": 71851534,
        "body_markdown": "I have a huge JSON file with lots of stuff I don&#39;t care about, and I want to filter it down to only the few keys I care about, preserving the structure. I won&#39;t bother if the same key name might occur in different paths and I get both of them. I gleaned something very close from the answers to [this question][1], it taught me how to delete all properties with certain *values*, like all null values:\r\n\r\n    del(..|nulls)\r\n\r\nor, more powerfully\r\n\r\n    del(..|select(. == null))\r\n\r\nI searched high and low if I could write a predicate over the name of a property when I am looking at a property. I come from XSLT where I could write something like this:\r\n\r\n    del(..|select(name|test(&quot;^(foo|bar)$&quot;)))\r\n\r\nwhere name/1 would be the function that returns the property name or array index number where the current value comes from. But it seems that jq lacks the metadata on its values, so you can only write predicates about their value, and perhaps the type of their value (that&#39;s still just a feature of the value), but you cannot inspect the name, or path leading up to it?\r\n\r\nI tried to use paths and leaf_paths and stuff like that, but I have no clue what that would do and tested it out to see how this path stuff works, but it seems to find child paths inside an object, not the path leading up to the present value.\r\n\r\nSo how could this be done, delete everything but a set of key values? I might have found a way [here][2]:\r\n\r\n    walk(\r\n      if type == &quot;object&quot; then \r\n        with_entries(\r\n          select(    ( .key |test(&quot;^(foo|bar|...)$&quot;) )\r\n                 and ( .value != &quot;&quot; )\r\n                 and ( .value != null ) )\r\n        )\r\n      else \r\n        . \r\n      end\r\n    )\r\n\r\nOK, this seems to work. But I still wonder it would be so much easier if we had a way of querying the current property name, array index, or path leading up to the present item being inspected with the simple recusion ..| form.\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/39500608/remove-all-null-values\r\n  [2]: https://stackoverflow.com/questions/42635140/jq-recursively-delete-all-keys-that-match-a-given-pattern",
        "link": "https://stackoverflow.com/questions/71851534/how-can-i-delete-all-keys-that-dont-match-certain-names-with-jq",
        "title": "How can I delete all keys that don&#39;t match certain names with JQ?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2578132,
                    "reputation": 1921,
                    "user_id": 2235381,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0061f9bd5384a544637692774a6e108f?s=256&d=identicon&r=PG",
                    "display_name": "lojza",
                    "link": "https://stackoverflow.com/users/2235381/lojza"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649837656,
                "post_id": 71853834,
                "comment_id": 126974137,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1649839032,
                "post_id": 71853834,
                "comment_id": 126974703,
                "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": 1649839623,
                "post_id": 71853834,
                "comment_id": 126974966,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user18780371"
                },
                "reply_to_user": {
                    "account_id": 2578132,
                    "reputation": 1921,
                    "user_id": 2235381,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0061f9bd5384a544637692774a6e108f?s=256&d=identicon&r=PG",
                    "display_name": "lojza",
                    "link": "https://stackoverflow.com/users/2235381/lojza"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1649841118,
                "post_id": 71853834,
                "comment_id": 126975507,
                "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": 1662324454,
                "post_id": 71853834,
                "comment_id": 129974466,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1649841841,
        "creation_date": 1649836413,
        "last_edit_date": 1649841841,
        "question_id": 71853834,
        "body_markdown": "I have two json files which I need to merge but when I run \r\n```\r\njq -s &#39;.[0] * .[1]&#39; web-apps.json android-apps.json | tee output.json\r\n```\r\ncommand I get the following error.\r\n```\r\njq: error (at output.json:0): object ({&quot;apps&quot;:{...) and null (null) cannot be multiplied \r\n```\r\n\r\nHere are my json files.\r\n\r\n`web-apps.json`\r\n\r\n```\r\n{\r\n  &quot;apps&quot;: {\r\n    &quot;app1&quot;: [\r\n      &quot;v1.0&quot;\r\n    ],\r\n    &quot;app2&quot;: [\r\n      &quot;v3.7.2&quot;\r\n    ]\r\n }\r\n}\r\n\r\n```\r\n\r\n`android-apps.json`\r\n\r\n```\r\n{\r\n  &quot;apps&quot;: {\r\n    &quot;mob-app1&quot;: [\r\n      &quot;v2.0&quot;\r\n    ],\r\n    &quot;mob-app2&quot;: [\r\n      &quot;v2.1&quot;\r\n    ]\r\n }\r\n}\r\n\r\n```\r\n\r\nThe expected output:\r\n\r\n```\r\n{\r\n  &quot;apps&quot;: {\r\n    &quot;app1&quot;: [\r\n      &quot;v1.0&quot;\r\n    ],\r\n    &quot;app2&quot;: [\r\n      &quot;v3.7.2&quot;\r\n    ],\r\n   &quot;mob-app1&quot;: [\r\n      &quot;v2.0&quot;\r\n    ],\r\n   &quot;mob-app2&quot;: [\r\n     &quot;v2.1&quot;\r\n   ]\r\n }\r\n}\r\n```\r\nI don&#39;t understand what null means in this context. Both json files have the exact same structure/format and this is also the format I need.\r\n\r\nPlease ask for more details if needed. \r\n\r\nEDIT: I referenced the wrong json file with a similar name. ",
        "link": "https://stackoverflow.com/questions/71853834/jq-error-at-output-json0-object-apps-and-null-null-cannot-be-mu",
        "title": "jq: error (at output.json:0): object ({&quot;apps&quot;:{...) and null (null) cannot be multiplied can&#39;t merge two json files"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1649860840,
                "last_edit_date": 1649860840,
                "creation_date": 1649849130,
                "answer_id": 71856695,
                "question_id": 71855587,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can combine `walk` with `..` :\r\n\r\n```\r\njq &#39;walk(\r\n        (.fixedKeyCheckPresence? | .. |\r\n         select(has(&quot;fixedKeyCheckValue&quot;)?).fixedKeyCheckValue) |= sub(&quot;^Foo$&quot;;&quot;Bar&quot;)\r\n    )&#39; input.json\r\n```\r\n\r\n`.fixedKeyCheckPresence?` takes care of find the object key `fixedKeyCheckPresence` and leaves everything else intact.\r\n\r\nThen under `.fixedKeyCheckPresence`, we enumerate all sub-nodes with `..` and select the object containing `fixedKeyCheckValue`.",
                "title": "JQ - Deep child replace through wildcard search, but check parent presence with merge to the original JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1649860840,
        "creation_date": 1649844153,
        "question_id": 71855587,
        "body_markdown": "This is a kind of extension to my previous question https://stackoverflow.com/questions/71818537/jq-deep-child-value-replace-through-wildcard-search-and-merge-to-the-original\r\n\r\nI want to check the presence of a particular key in some parents before replacing the child. *Loosely*, translated to CSS selector, I want something like `* &gt; fixedKeyCheckPresence &gt; * &gt; fixedKeyCheckValue`\r\n\r\n**Input:**\r\n```\r\n{\r\n  &quot;randomKey1&quot;: {\r\n    &quot;randomKey2&quot;: [\r\n      {\r\n        &quot;randomKeyUnderAnyLevel11&quot;: {\r\n          &quot;fixedKeyCheckPresence&quot;: {\r\n            &quot;randomeKeyUnderAnyLevel23&quot;: {\r\n              &quot;fixedKeyCheckValue&quot;: &quot;Foo&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  &quot;randomKey11&quot;: {\r\n    &quot;fixedKeyCheckPresence&quot;: {\r\n      &quot;randomeKeyUnderAnyLevel123&quot;: {\r\n        &quot;fixedKeyCheckValue&quot;: &quot;Foo&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n**Expected Output:**\r\n\r\n```\r\n{\r\n  &quot;randomKey1&quot;: {\r\n    &quot;randomKey2&quot;: [\r\n      {\r\n        &quot;randomKeyUnderAnyLevel11&quot;: {\r\n          &quot;fixedKeyCheckPresence&quot;: {\r\n            &quot;randomeKeyUnderAnyLevel23&quot;: {\r\n              &quot;fixedKeyCheckValue&quot;: &quot;Bar&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  &quot;randomKey11&quot;: {\r\n    &quot;fixedKeyCheckPresence&quot;: {\r\n      &quot;randomeKeyUnderAnyLevel123&quot;: {\r\n        &quot;fixedKeyCheckValue&quot;: &quot;Bar&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n**Tried:** `(.. | select(try has(&quot;fixedKeyCheckPresence&quot;)) | .fixedKeyCheckValue) |= (sub(&quot;^Foo$&quot;;&quot;Bar&quot;))`\r\n\r\n**jq play:** https://jqplay.org/s/_YlLSyTEc7",
        "link": "https://stackoverflow.com/questions/71855587/jq-deep-child-replace-through-wildcard-search-but-check-parent-presence-with",
        "title": "JQ - Deep child replace through wildcard search, but check parent presence with merge to the original JSON"
    },
    {
        "tags": [
            "json",
            "shell",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649851340,
                "creation_date": 1649851340,
                "answer_id": 71857192,
                "question_id": 71855942,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this:\r\n\r\n    #!/bin/bash\r\n\r\n    echo &quot;Enter file name:&quot;\r\n    read filename\r\n\r\n    IFS=&#39;:&#39; read -r s e &lt; $filename\r\n    echo $s $e\r\n\r\n    curl -s &quot;https://search.maven.org/solrsearch/select?q=g:${s}+AND+a:${e}&amp;core=gav&amp;rows=1&amp;wt=json&quot; | jq &quot;.response.docs[].v&quot;\r\n~",
                "title": "shell script-Unable to get expected response by running through loop inside .sh file, but getting it by individually defining variables in file"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1649851340,
        "creation_date": 1649845658,
        "last_edit_date": 1649846075,
        "question_id": 71855942,
        "body_markdown": "**Fileread.sh**\r\n\r\n    #!/bin/bash\r\n    s=ch.qos.logback\r\n    e=logback-access\r\n    curl -s &quot;https://search.maven.org/solrsearch/select?q=g:$s+AND+a:$e&amp;core=gav&amp;rows=1&amp;wt=json&quot; | jq &quot;.response.docs[].v&quot;`\r\n\r\noutput:&quot;1.2.11&quot;\r\n\r\nThis code is working perfectly fine  But when I try storing the s and e values in a .txt file with  : seperated and then try running, I get nothing in response\r\n\r\n**textFile.txt**\r\n\r\nch.qos.logback:logback-access\r\n\r\n**fileread.sh**\r\n\r\n    #!/bin/bash\r\n    read -p &quot;Enter file name:&quot; filename\r\n    while IFS=&#39;:&#39; read -r s e\r\n    do\r\n    curl -s &quot;https://search.maven.org/solrsearch/select?q=g:${s}+AND+a:${e}&amp;core=gav&amp;rows=1&amp;wt=json&quot; | jq &quot;.response.docs[].v&quot;\r\n    done &lt; $filename\r\n\r\nI have tried :\r\n\r\n```\r\nxy=$(curl -s &quot;https://search.maven.org/solrsearch/select?q=g:${s}+AND+a:${e}&amp;core=gav&amp;rows=1&amp;wt=json&quot; | jq &quot;.response.docs[].v&quot;)\r\necho &quot;$xy&quot;      \r\n```\r\n```\r\nxy=$(curl -s &quot;&#39;https://search.maven.org/solrsearch/select?q=g:&#39;${s}&#39;+AND+a:&#39;${e}&amp;core=gav&amp;rows=1&amp;wt=json&quot; | jq &quot;.response.docs[].v&quot;)\r\necho &quot;$xy&quot;\r\n```\r\n```\r\nurl=`https://search.maven.org/solrsearch/select?q=g:${s}+AND+a:${e}&amp;core=gav&amp;rows=1&amp;wt=json`\r\necho url\r\n\r\nxx=`curl -s &quot;$url&quot; | jq &quot;.response.docs[].v&quot;`\r\necho $xx\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71855942/shell-script-unable-to-get-expected-response-by-running-through-loop-inside-sh",
        "title": "shell script-Unable to get expected response by running through loop inside .sh file, but getting it by individually defining variables in file"
    },
    {
        "tags": [
            "python",
            "json",
            "dictionary",
            "jq",
            "jsonparser"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1649900922,
                "creation_date": 1649900922,
                "answer_id": 71865585,
                "question_id": 71864901,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Based on your description, it would seem that could achieve what you describe as your &quot;final result&quot; just by adding `add` to your pipeline.  \r\n\r\n",
                "title": "How to use jq to merge a list of dictionaries into one dictionary"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1741631057,
        "creation_date": 1649893102,
        "last_edit_date": 1741631057,
        "question_id": 71864901,
        "body_markdown": "I&#39;m developing jq expressions on the command line.  (I plan to use the expression  with `pyjq` in python to parse http requests.)\r\n\r\nThe following command line:\r\n\r\n    $ cat some.json | jq &#39;.collection.rows[].rowAnswers | map({ (.refCode) : .answers[0].responseText }) &#39;\r\n\r\nResults in two items.  \r\n\r\n    [\r\n      {\r\n        &quot;NAME&quot;: &quot;some_name1&quot;\r\n      },\r\n      {\r\n        &quot;CODE&quot;: &quot;code1&quot;\r\n      },\r\n      {\r\n        &quot;SERVER&quot;: &quot;server1&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;NAME&quot;: &quot;name2&quot;\r\n      },\r\n      {\r\n        &quot;CODE&quot;: &quot;code2&quot;\r\n      },\r\n      {\r\n        &quot;SERVER&quot;: &quot;server2&quot;\r\n      }\r\n    ]\r\n\r\nThis is a nice intermediate step.  I&#39;d like to merge each list of dictionaries into one dictionary.  I&#39;d like the final result to be:\r\n\r\n    {\r\n        &quot;NAME&quot;: &quot;some_name1&quot;\r\n        &quot;CODE&quot;: &quot;code1&quot;\r\n        &quot;SERVER&quot;: &quot;server1&quot;\r\n    }\r\n    {\r\n        &quot;NAME&quot;: &quot;name2&quot;\r\n        &quot;CODE&quot;: &quot;code2&quot;\r\n        &quot;SERVER&quot;: &quot;server2&quot;\r\n    }\r\n\r\n\r\nIf that&#39;s too difficult, then `[merge_dict][merge_dict]` is good too.\r\n\r\nThere won&#39;t be any key collisions.  Also, this is simplified output.  I&#39;d like an expression that merges all kv-pairs into one dictionary.  I don&#39;t want to hardcode the actual name of the keys in the expression.\r\n\r\nThanks.",
        "link": "https://stackoverflow.com/questions/71864901/how-to-use-jq-to-merge-a-list-of-dictionaries-into-one-dictionary",
        "title": "How to use jq to merge a list of dictionaries into one dictionary"
    },
    {
        "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": 1,
                "creation_date": 1649902080,
                "post_id": 71865329,
                "comment_id": 126994747,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1649902610,
                "creation_date": 1649902610,
                "answer_id": 71865752,
                "question_id": 71865329,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your input consists of a JSON array with {Path, Text} objects as shown, then you could achieve the merging you describe by:\r\n\r\n```\r\nreduce .[] as $x (null;\r\n  if $x|.Path|contains(&quot;/ParagraphSpan[&quot;)\r\n  then .[-1].Text += $x.Text\r\n  else . + [$x] end) \r\n```\r\n\r\nIn practice, you might want to add some checks, or to impose more stringent requirements for merging objects, or to ensure that the merging of texts is done properly.",
                "title": "Concatenate values from adjacent objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1649952147,
        "creation_date": 1649898205,
        "last_edit_date": 1649952147,
        "question_id": 71865329,
        "body_markdown": "I would like to concatenate values from adjacent objects if a given value is matched.\r\n\r\nAs you can see below, Text fields with ParagraphSpan in the Path are split between objects, as opposed to P&#39;s which are self contained. \r\n\r\n    {\r\n      &quot;Path&quot;: &quot;//Document/P[5]&quot;,\r\n      &quot;Text&quot;: &quot;WELLNESS AS A HEALTH GOAL &quot;\r\n    },\r\n    {\r\n      &quot;Path&quot;: &quot;//Document/P[6]/ParagraphSpan&quot;,\r\n      &quot;Text&quot;: &quot;Although we use the words health and wellness interchangeably, they differ in two important ways. Health can be determined &quot;\r\n    },\r\n    {\r\n      &quot;Path&quot;: &quot;//Document/P[6]/ParagraphSpan[2]&quot;,\r\n      &quot;Text&quot;: &quot;or influenced by factors beyond your control, such as your genes, age, and family history.&quot;\r\n    },\r\n    {\r\n      &quot;Path&quot;: &quot;//Document/P[7]&quot;,\r\n      &quot;Text&quot;: &quot;Dimensions of Wellness &quot;\r\n    },\r\n    {\r\n      &quot;Path&quot;: &quot;//Document/P[8]&quot;,\r\n      &quot;Text&quot;: &quot;The process of achieving wellness is continual and dynamic, involving change and growth. &quot;\r\n    },\r\n    {\r\n      &quot;Path&quot;: &quot;//Document/P[9]&quot;,\r\n      &quot;Text&quot;: &quot;Your physical wellness includes not just your body’s overall condition and the absence of disease &quot;\r\n    }\r\n\r\nIs it possible to combine the Text under a ParagraphSpan?\r\n\r\n    &quot;Path&quot;: &quot;//Document/P[6]/ParagraphSpan&quot;,\r\n    &quot;Text&quot;: &quot;Although we use the words health and wellness interchangeably, they differ in two important ways. Health can be determined or influenced by factors beyond your control, such as your genes, age, and family history.  &quot;,\r\n",
        "link": "https://stackoverflow.com/questions/71865329/concatenate-values-from-adjacent-objects-using-jq",
        "title": "Concatenate values from adjacent objects using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1649921981,
                "creation_date": 1649921981,
                "answer_id": 71868062,
                "question_id": 71867828,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get the first output, increase the value directly. Parentheses are needed for precedence.\r\n```\r\njq &#39;[. as { foo: $leafText } | {\r\n    leafCalls: {\r\n      text: ($leafText + 1)\r\n    },\r\n  }\r\n]&#39; input.json\r\n```\r\n\r\nAnd similarly for the string:\r\n```\r\njq &#39;[ . as { foo: $leafText,  bar: $leafCode}\r\n    | { leafCalls: { text: ($leafCode + &quot; string&quot; ) } } ]\r\n    &#39; input.json",
                "title": "syntax error, unexpected |=, expecting &#39;}&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1649921981,
        "creation_date": 1649920843,
        "question_id": 71867828,
        "body_markdown": "I want to build a json with jq filter, the usecase is very simple, \r\n\r\nI have a json file as this,\r\n\r\n```bash\r\n# cat input.json\r\n{&quot;foo&quot;: 42, &quot;bar&quot;: &quot;less interesting data&quot;}\r\n```\r\n\r\nand I want to generate a json file with jq as follow, \r\n\r\noutput: \r\nincrease the value of foo, \r\n```json\r\n[\r\n  {\r\n    &quot;leafCalls&quot;: {\r\n      &quot;text&quot;: 43\r\n    }\r\n  }\r\n]\r\n```\r\nand the filter I am using is defined as this, \r\n```bash\r\n# cat results.jq\r\n[.[] | . as { foo: $leafText,  bar: $leafCode} | {\r\n    leafCall: {\r\n      text: $leafText\r\n    },\r\n  } | {\r\n    leafCalls: .leafCall |= . + 1\r\n}]\r\n```\r\n\r\nBut there is a syntax issue as said below, \r\n\r\n```bash\r\n# &lt;input.json jq  --slurp --from-file results.jq &gt; output.json\r\njq: error: syntax error, unexpected |=, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 6:\r\n    leafCalls: .leafCall |= . + 1\r\njq: 1 compile error\r\n```\r\n\r\n\r\nBeside, there is also a problem if want to concat a string to the value of &quot;bar&quot;, \r\n\r\nFor what I want is, \r\n```\r\n[\r\n  {\r\n    &quot;leafCalls&quot;: {\r\n      &quot;text&quot;: &quot;less interesting data string&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nThe filter is \r\n```\r\n# cat results2.jq\r\n[.[] | . as { foo: $leafText,  bar: $leafCode} | {\r\n    leafCall: {\r\n      text: $leafCode },\r\n  } | {\r\n    leafCalls: .leafCall + &quot; &quot; + &quot;string&quot;\r\n}]\r\n```\r\n\r\nand the jq is saying, \r\n```\r\njq: error: syntax error, unexpected &#39;+&#39;, expecting &#39;}&#39;\r\n```\r\n\r\n\r\nCan anyone tell what&#39;s the problem with the filter definition?\r\n",
        "link": "https://stackoverflow.com/questions/71867828/syntax-error-unexpected-expecting",
        "title": "syntax error, unexpected |=, expecting &#39;}&#39;"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649931320,
                "creation_date": 1649931320,
                "answer_id": 71869981,
                "question_id": 71869690,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Wouldn&#39;t it be simpler to use `map` and build the objects directly?\r\n~~~sh\r\n&lt;input.json jq --slurp &#39;map({values: (.foo + [.bar] | map({key:.}))})&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;values&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;key1&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key2&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key3&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/FhDH_swAvJ)\r\n\r\n",
                "title": "How to append a object to a array?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1650010497,
                "last_edit_date": 1650010497,
                "creation_date": 1649939714,
                "answer_id": 71871722,
                "question_id": 71869690,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Can this achieve what you wanted :\r\n\r\n```\r\nq --slurp &#39;[\r\n    .[] | . as { foo: $names,  bar: $name} |\r\n    {\r\n        names: ([\r\n            $names | range(0;length) as $i |\r\n            { key: ($names[$i]) }\r\n        ] + [{ key: $name }])\r\n    } |\r\n    {\r\n    values: .names,\r\n    }\r\n]&#39; input.json\r\n```",
                "title": "How to append a object to a array?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1650010497,
        "creation_date": 1649929980,
        "question_id": 71869690,
        "body_markdown": "I have a input json file as this,\r\n\r\n```json\r\n{\r\n  &quot;foo&quot;:[\r\n     &quot;key1&quot;,\r\n     &quot;key2&quot;\r\n   ],\r\n  &quot;bar&quot;: &quot;key3&quot;\r\n\r\n}\r\n```\r\n\r\nHere is how the jq filter defined,\r\n```bash\r\n[.[] | . as { foo: $names,  bar: $name} | {\r\n    names: [ $names | range(0;length) as $i | {\r\n        key: ($names[$i])\r\n    }],\r\n  } | {\r\n    values: .names,\r\n}]\r\n```\r\n\r\nThis will generate a json file as this,\r\n```bash\r\n&lt;input.json jq  --slurp --from-file concat.jq &gt; output.json\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;values&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;key1&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key2&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nNow I want to append the `key3` to the output json and define the filter as this, \r\n\r\n```\r\n[.[] | . as { foo: $names,  bar: $name} | {\r\n    names: [ $names | range(0;length) as $i | {\r\n        key: ($names[$i])\r\n    }] |= .+ {key: $name},\r\n  } | {\r\n    values: .names,\r\n}]\r\n```\r\n\r\nThis seems doesn&#39;t work, \r\n```bash\r\n&lt;input.json jq  --slurp --from-file concat.jq &gt; output.json\r\n```\r\n\r\nresult to below exceptions, \r\n```\r\njq: error: syntax error, unexpected |=, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 4:\r\n    }] |= .+ {key: $name},\r\njq: 1 compile error\r\n```\r\n\r\nHow can I solve this problem?",
        "link": "https://stackoverflow.com/questions/71869690/how-to-append-a-object-to-a-array",
        "title": "How to append a object to a array?"
    },
    {
        "tags": [
            "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": 1649939090,
                "post_id": 71870855,
                "comment_id": 127004322,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1649986576,
                "creation_date": 1649986576,
                "answer_id": 71879182,
                "question_id": 71870855,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is underspecified, but you might wish to consider:\r\n\r\n    [.. | strings] | join(&quot; &quot;)\r\n\r\nor similar.",
                "title": "Cannot index array with string &quot;xxx&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1649986576,
        "creation_date": 1649935458,
        "question_id": 71870855,
        "body_markdown": "I have a json file as this,\r\n```\r\n# cat input.json\r\n{\r\n  &quot;foo&quot;:[\r\n     &quot;key1&quot;,\r\n     &quot;key2&quot;\r\n   ],\r\n  &quot;bar&quot;: &quot;key3&quot;\r\n\r\n}\r\n```\r\n\r\nAnd I want to join all those strings (&quot;key1&quot;, &quot;key2&quot;, key3&quot;) into one string, and I define the filter as this, \r\n\r\n``` bash\r\n# cat filter.jq\r\n[.[] | . as { foo: $names,  bar: $name} | {\r\n    name1: [ $names | range(0;length) as $i | {\r\n        key1: ($names[$i])\r\n    }],\r\n    name2: {\r\n        key2: $name\r\n    }\r\n  } | {\r\n    values: (.name1 | map(.key1) | join(&quot; &quot;) + .name2.key2)\r\n}]\r\n```\r\n\r\nBut this doesn&#39;t work, \r\n```\r\n# &lt;input.json jq  --slurp --from-file filter.jq &gt; output.json\r\njq: error (at &lt;stdin&gt;:8): Cannot index array with string &quot;name2&quot;\r\n```\r\n\r\nWhat&#39;s wrong going here?\r\n\r\nbtw. concat with a string seems works.\r\n```\r\nvalues: (.name1 | map(.key1) | join(&quot; &quot;) + &quot;key3&quot;)\r\n```",
        "link": "https://stackoverflow.com/questions/71870855/cannot-index-array-with-string-xxx",
        "title": "Cannot index array with string &quot;xxx&quot;"
    },
    {
        "tags": [
            "cmd",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1649949127,
                "creation_date": 1649949127,
                "answer_id": 71873850,
                "question_id": 71873741,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Put the expression in parentheses:\r\n~~~sh\r\njq &quot;.[] | {c: (.a - .b)}&quot; sample.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;c&quot;: -1\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/1Ghfd8fFbN)\r\n\r\n---\r\n~~~sh\r\njq &quot;.[] | {c: (.a + .b)}&quot; sample.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;c&quot;: 3\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/youRCg-WMe)\r\n",
                "title": "jq arithmetic operation in object constructors on Windows"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1649949127,
        "creation_date": 1649948638,
        "question_id": 71873741,
        "body_markdown": "Assuming there&#39;s a `sample.json` file with contents like this: \r\n```\r\n[\r\n {\r\n  &quot;a&quot;: 1, \r\n  &quot;b&quot;: 2\r\n }\r\n]\r\n```\r\n\r\nif I run a `jq` command as follows (Windows 10 command line): \r\n\r\n```\r\n&gt; type sample.json| jq &quot;.[] | .a - .b&quot;\r\n-1\r\n```\r\n\r\nbut if I try to build an object with a key, whose value would be the result of subtraction operator, I can&#39;t: \r\n\r\n```\r\n&gt; type sample.json| jq &quot;.[] | {c: .a - .b}&quot;\r\njq: error: syntax error, unexpected &#39;-&#39;, expecting &#39;}&#39; (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:                                                                                                                                                                        .[] | {c: .a - .b}                                                                                                                                                                                                                                                                        jq: 1 compile error\r\n```\r\n\r\nwhat kind of a &quot;quoting issue&quot; might this be, and how to &quot;fix&quot; it? thanks! \r\n\r\nEDIT: forgot to mention, it&#39;s the same with `+` operator! ",
        "link": "https://stackoverflow.com/questions/71873741/jq-arithmetic-operation-in-object-constructors-on-windows",
        "title": "jq arithmetic operation in object constructors on Windows"
    },
    {
        "tags": [
            "csv",
            "nested",
            "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": 1650093827,
                "post_id": 71891456,
                "comment_id": 127039083,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1599408,
                    "reputation": 432,
                    "user_id": 1480777,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9f1f82b6832d97a29186da7f0e14e92f?s=256&d=identicon&r=PG",
                    "display_name": "Andreas Guther",
                    "link": "https://stackoverflow.com/users/1480777/andreas-guther"
                },
                "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": 1650125642,
                "post_id": 71891456,
                "comment_id": 127044995,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1650128046,
                "creation_date": 1650128046,
                "answer_id": 71895800,
                "question_id": 71891456,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s a pretty simple combination of grabbing some information, then looping over descendants.\r\n\r\n```jq\r\n(\r\n   [ &quot;Site&quot;, &quot;Account&quot;, &quot;User&quot;, &quot;Counted&quot; ],\r\n   (\r\n      .aggregations.by_site_group_and_account_and_user_name.buckets[] |\r\n      .key as $site |\r\n      .by_account_Id.buckets[] |\r\n      .key as $account |\r\n      .by_user_name.buckets[] |\r\n      [ $site, $account, .key, .doc_count ]\r\n   )\r\n) | @csv\r\n```\r\n\r\n[Demo](https://jqplay.org/s/7aFy19f4CQ) on jqplay\r\n",
                "title": "jq - extract nested objects into CSV"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1650128046,
        "creation_date": 1650088240,
        "question_id": 71891456,
        "body_markdown": "I would like to flatten the following (elasticsearch result, simplified) into a CSV file with repeating parent values. \r\n\r\nThe aggregation has three levels that I would like to flatten, site name, account id, user names, and counted. The renaming of the CSV headers, as shown, would be nice.\r\n\r\nI tried with map_values() but the nested structure gives me a hard time.\r\n\r\nInput File Content\r\n------------------\r\n\r\n\r\n```\r\n{\r\n  &quot;aggregations&quot;: {\r\n    &quot;by_site_group_and_account_and_user_name&quot;: {\r\n      &quot;doc_count_error_upper_bound&quot;: 4880,\r\n      &quot;sum_other_doc_count&quot;: 760270,\r\n      &quot;buckets&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;S1&quot;,\r\n          &quot;doc_count&quot;: 335216,\r\n          &quot;by_account_Id&quot;: {\r\n            &quot;doc_count_error_upper_bound&quot;: 429,\r\n            &quot;sum_other_doc_count&quot;: 34655,\r\n            &quot;buckets&quot;: [\r\n              {\r\n                &quot;key&quot;: 1396220,\r\n                &quot;doc_count&quot;: 277532,\r\n                &quot;by_user_name&quot;: {\r\n                  &quot;doc_count_error_upper_bound&quot;: 0,\r\n                  &quot;sum_other_doc_count&quot;: 2580,\r\n                  &quot;buckets&quot;: [\r\n                    {\r\n                      &quot;key&quot;: &quot;S1_U1&quot;,\r\n                      &quot;doc_count&quot;: 244602\r\n                    },\r\n                    {\r\n                      &quot;key&quot;: &quot;S1_U2&quot;,\r\n                      &quot;doc_count&quot;: 30350\r\n                    }\r\n                  ]}},\r\n              {\r\n                &quot;key&quot;: 14770032,\r\n                &quot;doc_count&quot;: 23029,\r\n                &quot;by_user_name&quot;: {\r\n                  &quot;doc_count_error_upper_bound&quot;: 0,\r\n                  &quot;sum_other_doc_count&quot;: 0,\r\n                  &quot;buckets&quot;: [\r\n                    {\r\n                      &quot;key&quot;: &quot;S1_U3&quot;,\r\n                      &quot;doc_count&quot;: 23016\r\n                    }\r\n                  ]}}]}},\r\n        {\r\n          &quot;key&quot;: &quot;S2&quot;,\r\n          &quot;doc_count&quot;: 146453,\r\n          &quot;by_account_Id&quot;: {\r\n            &quot;doc_count_error_upper_bound&quot;: 2380,\r\n            &quot;sum_other_doc_count&quot;: 108259,\r\n            &quot;buckets&quot;: [\r\n              {\r\n                &quot;key&quot;: 14733289,\r\n                &quot;doc_count&quot;: 20138,\r\n                &quot;by_user_name&quot;: {\r\n                  &quot;doc_count_error_upper_bound&quot;: 0,\r\n                  &quot;sum_other_doc_count&quot;: 2406,\r\n                  &quot;buckets&quot;: [\r\n                    {\r\n                      &quot;key&quot;: &quot;S2_U1&quot;,\r\n                      &quot;doc_count&quot;: 13247\r\n                    },\r\n                    {\r\n                      &quot;key&quot;: &quot;S2_U2&quot;,\r\n                      &quot;doc_count&quot;: 4485\r\n                    }\r\n                  ]}},\r\n              {\r\n                &quot;key&quot;: 14769976,\r\n                &quot;doc_count&quot;: 18056,\r\n                &quot;by_user_name&quot;: {\r\n                  &quot;doc_count_error_upper_bound&quot;: 0,\r\n                  &quot;sum_other_doc_count&quot;: 0,\r\n                  &quot;buckets&quot;: [\r\n                    {\r\n                      &quot;key&quot;: &quot;S2_U3&quot;,\r\n                      &quot;doc_count&quot;: 17015\r\n                    },\r\n                    {\r\n                      &quot;key&quot;: &quot;S2_U4&quot;,\r\n                      &quot;doc_count&quot;: 1041\r\n                    }\r\n                  ]}}]}}]}}}\r\n\r\n```\r\n\r\nDesired Output\r\n--------------\r\n\r\n```\r\n&quot;Site&quot;, &quot;Account&quot;, &quot;User&quot;, &quot;Counted&quot;\r\n&quot;S1&quot;, 1396220, &quot;S1_U1&quot;, 244602 \r\n&quot;S1&quot;, 1396220, &quot;S1_U2&quot;, 30350\r\n&quot;S1&quot;, 14770032, &quot;S1_U3&quot;, 23016\r\n&quot;S2&quot;, 14733289, &quot;S2_U1&quot;, 13247\r\n&quot;S2&quot;, 14733289, &quot;S2_U2&quot;, 4485\r\n&quot;S2&quot;, 14769976, &quot;S2_U3&quot;, 17015\r\n&quot;S2&quot;, 14769976, &quot;S2_U4&quot;, 1041\r\n```\r\nThank you in advance for any help.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71891456/jq-extract-nested-objects-into-csv",
        "title": "jq - extract nested objects into CSV"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1650207233,
                "creation_date": 1650207233,
                "answer_id": 71902892,
                "question_id": 71902380,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Something like this will do the trick:\r\n```\r\n (input | .containerDefinitions[0].environment | from_entries) as $new_env\r\n| input | .containerDefinitions[].environment |= ((from_entries + $new_env) | to_entries)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/UskxXX5sp6)&lt;/sup&gt;\r\n\r\n---\r\nIn case it&#39;s unclear, the invocation should look like so:\r\n```\r\njq -n &#39;...&#39; 2.json 1.json\r\n```",
                "title": "Merge two nested JSON files using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1650213683,
                "creation_date": 1650213683,
                "answer_id": 71903680,
                "question_id": 71902380,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution using `tostream` and `has(1)` to read the values from the second file, and `setpath` to set them in the first file:\r\n~~~sh\r\njq &#39;reduce (input | tostream | select(has(1))) as $i (.; setpath($i[0]; $i[1]))&#39; \\\r\n  1.json 2.json\r\n~~~\r\n[Demo](https://jqplay.org/s/giMzfAA-zB)\r\n\r\n---\r\nWhen providing the files in reversed order (`2.json 1.json`), the context `.` and `input` have to be swapped:\r\n~~~sh\r\njq &#39;reduce (tostream | select(has(1))) as $i (input; setpath($i[0]; $i[1]))&#39; \\\r\n  2.json 1.json\r\n~~~\r\n[Demo](https://jqplay.org/s/T_CKf2MU-8)\r\n",
                "title": "Merge two nested JSON files using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1650213683,
        "creation_date": 1650202950,
        "last_edit_date": 1650207312,
        "question_id": 71902380,
        "body_markdown": "I&#39;m trying to merge two JSON files. The main destination is to overwrite `environment` variables in the 1st file with `environment` variables in the 2nd.\r\n\r\n1st file:\r\n```\r\n{\r\n    &quot;containerDefinitions&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;foo&quot;,\r\n            &quot;image&quot;: &quot;nginx:latest&quot;,\r\n            &quot;cpu&quot;: 1024,\r\n            &quot;memory&quot;: 4096,\r\n            &quot;memoryReservation&quot;: 2048,\r\n            &quot;portMappings&quot;: [\r\n                {\r\n                    &quot;containerPort&quot;: 8080,\r\n                    &quot;hostPort&quot;: 0,\r\n                    &quot;protocol&quot;: &quot;tcp&quot;\r\n                }\r\n            ],\r\n            &quot;essential&quot;: true,\r\n            &quot;environment&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;SERVER_PORT&quot;,\r\n                    &quot;value&quot;: &quot;8080&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;DB_NAME&quot;,\r\n                    &quot;value&quot;: &quot;example_db&quot;\r\n                }\r\n            ],\r\n            &quot;mountPoints&quot;: [],\r\n            &quot;volumesFrom&quot;: [],\r\n            &quot;logConfiguration&quot;: {\r\n                &quot;logDriver&quot;: &quot;awslogs&quot;,\r\n                &quot;options&quot;: {\r\n                    &quot;awslogs-group&quot;: &quot;/dev/ecs/example&quot;,\r\n                    &quot;awslogs-region&quot;: &quot;us-west-1&quot;,\r\n                    &quot;awslogs-stream-prefix&quot;: &quot;ecs&quot;\r\n                }\r\n            }\r\n        }\r\n    ],\r\n    &quot;family&quot;: &quot;bar&quot;,\r\n    &quot;taskRoleArn&quot;: &quot;arn:aws:iam::111111111111:role/assume-ecs-role&quot;,\r\n    &quot;executionRoleArn&quot;: &quot;arn:aws:iam::111111111111:role/ecs-task-execution-role&quot;,\r\n    &quot;networkMode&quot;: &quot;bridge&quot;,\r\n    &quot;volumes&quot;: [],\r\n    &quot;placementConstraints&quot;: [],\r\n    &quot;requiresCompatibilities&quot;: [\r\n        &quot;EC2&quot;\r\n    ]\r\n}\r\n```\r\n2nd file:\r\n```\r\n{\r\n    &quot;containerDefinitions&quot;: [\r\n        {\r\n            &quot;environment&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;SERVER_PORT&quot;,\r\n                    &quot;value&quot;: &quot;8081&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\nThe product has to be next:\r\n```\r\n{\r\n    &quot;containerDefinitions&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;foo&quot;,\r\n            &quot;image&quot;: &quot;nginx:latest&quot;,\r\n            &quot;cpu&quot;: 1024,\r\n            &quot;memory&quot;: 4096,\r\n            &quot;memoryReservation&quot;: 2048,\r\n            &quot;portMappings&quot;: [\r\n                {\r\n                    &quot;containerPort&quot;: 8080,\r\n                    &quot;hostPort&quot;: 0,\r\n                    &quot;protocol&quot;: &quot;tcp&quot;\r\n                }\r\n            ],\r\n            &quot;essential&quot;: true,\r\n            &quot;environment&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;SERVER_PORT&quot;,\r\n                    &quot;value&quot;: &quot;8081&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;DB_NAME&quot;,\r\n                    &quot;value&quot;: &quot;example_db&quot;\r\n                }\r\n            ],\r\n            &quot;mountPoints&quot;: [],\r\n            &quot;volumesFrom&quot;: [],\r\n            &quot;logConfiguration&quot;: {\r\n                &quot;logDriver&quot;: &quot;awslogs&quot;,\r\n                &quot;options&quot;: {\r\n                    &quot;awslogs-group&quot;: &quot;/dev/ecs/example&quot;,\r\n                    &quot;awslogs-region&quot;: &quot;us-west-1&quot;,\r\n                    &quot;awslogs-stream-prefix&quot;: &quot;ecs&quot;\r\n                }\r\n            }\r\n        }\r\n    ],\r\n    &quot;family&quot;: &quot;bar&quot;,\r\n    &quot;taskRoleArn&quot;: &quot;arn:aws:iam::111111111111:role/assume-ecs-role&quot;,\r\n    &quot;executionRoleArn&quot;: &quot;arn:aws:iam::111111111111:role/ecs-task-execution-role&quot;,\r\n    &quot;networkMode&quot;: &quot;bridge&quot;,\r\n    &quot;volumes&quot;: [],\r\n    &quot;placementConstraints&quot;: [],\r\n    &quot;requiresCompatibilities&quot;: [\r\n        &quot;EC2&quot;\r\n    ]\r\n}\r\n```\r\nI tried to do next:\r\n```\r\njq -s &#39;reduce .[] as $item ({}; reduce ($item | keys_unsorted[]) as $key (.; $item[$key] as $val | ($val | type) as $type | .[$key] = if ($type == &quot;array&quot;) then (.[$key] + $val | unique) elif ($type == &quot;object&quot;) then (.[$key] + $val) else $val end))&#39;  1.json 2.json\r\n```\r\nBut the result is:\r\n```\r\n{\r\n  &quot;containerDefinitions&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;image&quot;: &quot;nginx:latest&quot;,\r\n      &quot;cpu&quot;: 1024,\r\n      &quot;memory&quot;: 4096,\r\n      &quot;memoryReservation&quot;: 2048,\r\n      &quot;portMappings&quot;: [\r\n        {\r\n          &quot;containerPort&quot;: 8080,\r\n          &quot;hostPort&quot;: 0,\r\n          &quot;protocol&quot;: &quot;tcp&quot;\r\n        }\r\n      ],\r\n      &quot;essential&quot;: true,\r\n      &quot;environment&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;SERVER_PORT&quot;,\r\n          &quot;value&quot;: &quot;8080&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;DB_NAME&quot;,\r\n          &quot;value&quot;: &quot;example_db&quot;\r\n        }\r\n      ],\r\n      &quot;mountPoints&quot;: [],\r\n      &quot;volumesFrom&quot;: [],\r\n      &quot;logConfiguration&quot;: {\r\n        &quot;logDriver&quot;: &quot;awslogs&quot;,\r\n        &quot;options&quot;: {\r\n          &quot;awslogs-group&quot;: &quot;/dev/ecs/example&quot;,\r\n          &quot;awslogs-region&quot;: &quot;us-west-1&quot;,\r\n          &quot;awslogs-stream-prefix&quot;: &quot;ecs&quot;\r\n        }\r\n      }\r\n    },\r\n    {\r\n      &quot;environment&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;SERVER_PORT&quot;,\r\n          &quot;value&quot;: &quot;8081&quot;\r\n        }\r\n      ]\r\n    }\r\n  ],\r\n  &quot;family&quot;: &quot;bar&quot;,\r\n  &quot;taskRoleArn&quot;: &quot;arn:aws:iam::111111111111:role/assume-ecs-role&quot;,\r\n  &quot;executionRoleArn&quot;: &quot;arn:aws:iam::111111111111:role/ecs-task-execution-role&quot;,\r\n  &quot;networkMode&quot;: &quot;bridge&quot;,\r\n  &quot;volumes&quot;: [],\r\n  &quot;placementConstraints&quot;: [],\r\n  &quot;requiresCompatibilities&quot;: [\r\n    &quot;EC2&quot;\r\n  ]\r\n}\r\n```\r\nCould anyone help to find out how to reach the right result?",
        "link": "https://stackoverflow.com/questions/71902380/merge-two-nested-json-files-using-jq",
        "title": "Merge two nested JSON files using JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1650321109,
                "last_edit_date": 1650321109,
                "creation_date": 1650247338,
                "answer_id": 71906931,
                "question_id": 71906496,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With all your JSON objects in a file, say  output.jsons:\r\n```\r\njq -c -n --argjson list &#39;[ &quot;Tom&quot;, &quot;Sarah&quot;, &quot;Jenny&quot;, &quot;Trinh&quot;, &quot;Nancy&quot;]&#39; &#39;\r\n  (reduce inputs as $in ({}; reduce $in.names[] as $name (.; .[$name] += [$in.country]))) as $dict\r\n  | reduce $list[] as $name ({}; \r\n      if $dict[$name] \r\n      then reduce $dict[$name][] as $country (.; .[$country] += [$name]) \r\n      else . end)\r\n&#39; output.jsons\r\n```\r\nproduces:\r\n```\r\n{&quot;USA&quot;:[&quot;Tom&quot;],&quot;Nigeria&quot;:[&quot;Tom&quot;,&quot;Jenny&quot;]}\r\n```\r\nYou can easily transform this into the desired output.\r\n\r\nOne way to ensure uniqueness of the elements of each array would be to append the following to the filter: `map_values(unique)`.\r\n\r\n---\r\nRe the side question: instead of --argjson you could use --argfile or --slurpfile.",
                "title": "How to check if element(s) exist in JSON array using jq, and put the corresponding object into a new file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1650321109,
        "creation_date": 1650241835,
        "last_edit_date": 1650251685,
        "question_id": 71906496,
        "body_markdown": "I am running curl commands on ~50 URL&#39;s and each have JSON that looks like this (but with different values for &#39;country&#39; with each curl command, but the values for &#39;names&#39; can possibly repeat or be unique:\r\n\r\ne.g. one curl command can give JSON that looks like this:\r\n\r\n    {&quot;names&quot;:[&quot;Mary&quot;,&quot;Tom&quot;,&quot;Sue&quot;,&quot;Rob&quot;],&quot;country&quot;:&quot;USA&quot;}\r\n\r\nwhile the next curl command will give this:\r\n\r\n    {&quot;names&quot;:[&quot;Sue&quot;],&quot;country&quot;:&quot;Russia&quot;}\r\n\r\nand the next curl command will give this:\r\n\r\n    {&quot;names&quot;:[&quot;Tom&quot;,&quot;Jenny&quot;],&quot;country&quot;:&quot;Nigeria&quot;}\r\n\r\nand so on and so forth.\r\n\r\nI have a separate list of names (e.g. Tom, Sarah, Jenny, Trinh, Nancy) and I want to find out if they&#39;re associated with a country in any of the JSON&#39;s I&#39;m running the curl command on. If they exist in &quot;names&quot;, I want to put the name of the person and the country into a new text file (or JSON file, doesn&#39;t matter - i just want it formatted properly), so at the end I have an output file that associates the name of the person and the country they belong to. If a country has multiple people, there shouldn&#39;t be a duplicate value for country in the output file; the names of the people should be listed under that one country.\r\n\r\nI&#39;ve tried multiple ways to solve this, but I&#39;m not able to figure it out as it&#39;s my first time trying to write a script.\r\n\r\nLast command that I tried:\r\n\r\n    curl &quot;https://...&quot; | jq -r &#39;select(.names[] as $a | [&quot;Tom&quot;,&quot;Sarah&quot;,&quot;Jenny&quot;,&quot;Trinh&quot;,&quot;Nancy&quot;] | index($a) | while read output; do tee -a listOfCountries; done; done\r\n^This gave duplicates and I wasnt sure how to format the output so that there were spaces between each output and that the country had *only* the specific names of the people under it\r\n\r\nThe output file (given above example) should be something like:\r\n\r\n    USA: Tom\r\n    \r\n    Nigeria: Tom, Jenny\r\n\r\n\r\nPlease let me know if you have any suggestions, it&#39;ll greatly be appreciated. Thank you!\r\n\r\nSide question: If the list of names to search is extremely long (100+ names), what is the best way to script this?",
        "link": "https://stackoverflow.com/questions/71906496/how-to-check-if-elements-exist-in-json-array-using-jq-and-put-the-correspondi",
        "title": "How to check if element(s) exist in JSON array using jq, and put the corresponding object into a new file"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4391642,
                    "reputation": 582,
                    "user_id": 3579815,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bc829b635d4e335301c108d8ab309e3e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3579815",
                    "link": "https://stackoverflow.com/users/3579815/user3579815"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650275117,
                "post_id": 71909924,
                "comment_id": 127069877,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650275167,
                "post_id": 71909924,
                "comment_id": 127069898,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4391642,
                    "reputation": 582,
                    "user_id": 3579815,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bc829b635d4e335301c108d8ab309e3e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3579815",
                    "link": "https://stackoverflow.com/users/3579815/user3579815"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650275307,
                "post_id": 71909924,
                "comment_id": 127069929,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1650276701,
                "last_edit_date": 1650276701,
                "creation_date": 1650274646,
                "answer_id": 71910083,
                "question_id": 71909924,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to join multiple tags together and produce as a single result, combine them together in a CSV format like below\r\n\r\n```none\r\njq --raw-output &#39;.[] | \r\n  &quot;Instance ID: \\(.InstanceId)\\nTag Name: \\( .Tags | map(select(.Key == &quot;Name&quot;).Value) |join(&quot;,&quot;))&quot;&#39;\r\n```\r\n\r\nNote the inclusion of `\\n` character inside the interpolated string sequence which expands into the newline when printed in raw output mode.\r\n\r\n[jqplay demo - 1][1]\r\n\r\nIf you want to skip printing the Name field, in case if its empty, you need to add a bit more logic\r\n\r\n```\r\njq --raw-output &#39;.[] | \r\n  &quot;Instance ID: \\(.InstanceId)&quot; as $x | \r\n  ( .Tags | map(select(.Key == &quot;Name&quot;) ) ) as $y | \r\n  if ( $y | length ) &gt; 0 then \r\n    $x + &quot;\\nName: \\( $y | map(.Value) | join(&quot;,&quot;) )&quot; \r\n  else $x end&#39;\r\n```\r\n[jqplay demo - 2][2]\r\n\r\n\r\n  [1]: https://jqplay.org/s/V1WFuV9b8T\r\n  [2]: https://jqplay.org/s/hQ_TcVTJrG",
                "title": "How do I combine multiple attributes from different nodes of an AWS cli result?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1650276701,
        "creation_date": 1650273769,
        "question_id": 71909924,
        "body_markdown": "I have a JSON response from an AWS CLI command that looks like this:\r\n\r\n    [\r\n        {\r\n            &quot;AmiLaunchIndex&quot;: 0,\r\n            &quot;ImageId&quot;: &quot;ami-03ededff12e34e59e&quot;,\r\n            &quot;InstanceId&quot;: &quot;i-01e625ed10dadda91&quot;,\r\n            &quot;InstanceType&quot;: &quot;t2.micro&quot;,\r\n            &quot;LaunchTime&quot;: &quot;2022-04-18T02:35:03+00:00&quot;,\r\n            &quot;Monitoring&quot;: {\r\n                &quot;State&quot;: &quot;disabled&quot;\r\n            },\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Key&quot;: &quot;Name&quot;,\r\n                    &quot;Value&quot;: &quot;Some Server&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n\r\nHow do I extract the Instance ID and the Tag Name so that it prints like this:\r\n\r\n    Instance ID: i-01e625ed10dadda91\r\n    Name: Some Server\r\n    \r\nSo far I&#39;ve tried\r\n\r\n    jq &#39;.[] | &quot;Instance ID: \\(.InstanceId) \r\n    Tag Name: \\(.Tags[0].Value)&quot;&#39;\r\n\r\nBut it will break as soon as there are multiple tags or when the tag don&#39;t exist.",
        "link": "https://stackoverflow.com/questions/71909924/how-do-i-combine-multiple-attributes-from-different-nodes-of-an-aws-cli-result",
        "title": "How do I combine multiple attributes from different nodes of an AWS cli result?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1650411121,
                "last_edit_date": 1650411121,
                "creation_date": 1650334423,
                "answer_id": 71918908,
                "question_id": 71918146,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following, which assumes the input is a valid JSON array, will merge every .Text with at most one successor, but can easily be modified to merge multiple .Text values together as shown in Part 2 below.\r\n\r\n#### Part 1\r\n\r\n```\r\n# input and output: an array of {Text, Path, TextSize} objects.\r\n# Attempt to merge the .Text of the $i-th object with the .Text of a subsequent compatible object.\r\n# If a merge is successful, the subsequent object is removed.\r\ndef attempt_to_merge_next($i):\r\n  .[$i].TextSize as $class\r\n  | first( (range($i+1; length) as $j | select(.[$j].TextSize == $class) | $j) // null) as $j\r\n  | if $j then .[$i].Text += .[$j].Text | del(.[$j])\r\n    else .\r\n    end;\r\n\r\nreduce range(0; length) as $i (.;\r\n  if .[$i] == null then .\r\n  elif .[$i].Text|test(&quot;[,.?:;]\\\\s*$&quot;)|not\r\n  then attempt_to_merge_next($i)\r\n  else .\r\n  end)\r\n```  \r\n\r\n#### Part 2\r\nUsing the above `def`:\r\n```\r\ndef merge:\r\n  def m($i):\r\n    if $i &gt;= length then .\r\n      elif .[$i].Text|test(&quot;[,.?:;]\\\\s*$&quot;)|not\r\n      then attempt_to_merge_next($i) as $x\r\n      | if ($x|length) == length then m($i+1)\r\n        else $x|m($i)\r\n        end\r\n      else m($i+1)\r\n      end ;\r\n  m(0);\r\n\r\nmerge\r\n\r\n```",
                "title": "Concatenate values from non-adjacent objects based on multiple matching criteria"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1650411121,
        "creation_date": 1650325265,
        "last_edit_date": 1650360989,
        "question_id": 71918146,
        "body_markdown": "I [received help on a related question][1] previously on this forum and am wondering if there is a similarly straightforward way to resolve a more complex issue.\r\n\r\nGiven the following snippet, is there a way to merge the partial sentence (the one which does not end with a &quot;[punctuation mark][white space]&quot; pattern) with its remainder based on the matching TextSize? When I tried to adjust the answer from the related question I quickly ran into issues, but I am basically looking to translate a rule such as `if .Text !endswith(&quot;[punctuation mark][white space]&quot;) then .Text + next .Text where .TextSize matches`\r\n\r\n  \r\n\r\n      {\r\n        &quot;Text&quot;: &quot;Was it political will that established social democratic policies in the 1930s and &quot;,\r\n        &quot;Path&quot;: &quot;P&quot;,\r\n        &quot;TextSize&quot;: 9\r\n      },\r\n      {\r\n        &quot;Text&quot;: &quot;31 Lawrence Mishel and Jessica Schieder, Economic Policy Institute website, May 24, 2016 at (https://www.epi.org/publication/as-union-membership-has-fallen-the-top-10-percent-have-been-getting-a-larger-share-of-income/). &quot;,\r\n        &quot;Path&quot;: &quot;Footnote&quot;,\r\n        &quot;TextSize&quot;: 8\r\n      },\r\n      {\r\n        &quot;Text&quot;: &quot;Fig. 9.2 Higher union membership has been associated with a higher share of income to lower income brackets (the lower 90%) and a lower share of income to the top 10% of earners. &quot;,\r\n        &quot;Path&quot;: &quot;P&quot;,\r\n        &quot;TextSize&quot;: 8\r\n      },\r\n      {\r\n        &quot;Text&quot;: &quot;1940s, or that undermined them after the 1970s? Or was it abundant and cheap energy resources that enabled social democratic policies to work until the 1970s, and energy constraints that forced a restructuring of policy after the 1970s? &quot;,\r\n        &quot;Path&quot;: &quot;P&quot;,\r\n        &quot;TextSize&quot;: 9\r\n      },\r\n      {\r\n        &quot;Text&quot;: &quot;Recall that my economic modeling discussed in Chap. 6 shows that, even with no change in the assumption related to labor \\u201cbargaining power,\\u201d you can explain a shift from increasing to declining income equality (higher equality expressed as a higher wage share) by a corresponding shift from a period of rapidly increasing per capita resource consumption to one of constant per capita resource consumption. &quot;,\r\n        &quot;Path&quot;: &quot;P&quot;,\r\n        &quot;TextSize&quot;: 9\r\n      }\r\n\r\nThe result I&#39;m looking for would be as follows:\r\n\r\n      {\r\n        &quot;Text&quot;: &quot;Was it political will that established social democratic policies in the 1930s and 1940s, or that undermined them after the 1970s? Or was it abundant and cheap energy resources that enabled social democratic policies to work until the 1970s, and energy constraints that forced a restructuring of policy after the 1970s? &quot;,\r\n        &quot;Path&quot;: &quot;P&quot;,\r\n        &quot;TextSize&quot;: 9\r\n      },\r\n      {\r\n        &quot;Text&quot;: &quot;31 Lawrence Mishel and Jessica Schieder, Economic Policy Institute website, May 24, 2016 at (https://www.epi.org/publication/as-union-membership-has-fallen-the-top-10-percent-have-been-getting-a-larger-share-of-income/). &quot;,\r\n        &quot;Path&quot;: &quot;Footnote&quot;,\r\n        &quot;TextSize&quot;: 8\r\n      },\r\n      {\r\n        &quot;Text&quot;: &quot;Fig. 9.2 Higher union membership has been associated with a higher share of income to lower income brackets (the lower 90%) and a lower share of income to the top 10% of earners. &quot;,\r\n        &quot;Path&quot;: &quot;P&quot;,\r\n        &quot;TextSize&quot;: 8\r\n      },\r\n      {\r\n        &quot;Text&quot;: &quot;Recall that my economic modeling discussed in Chap. 6 shows that, even with no change in the assumption related to labor \\u201cbargaining power,\\u201d you can explain a shift from increasing to declining income equality (higher equality expressed as a higher wage share) by a corresponding shift from a period of rapidly increasing per capita resource consumption to one of constant per capita resource consumption. &quot;,\r\n        &quot;Path&quot;: &quot;P&quot;,\r\n        &quot;TextSize&quot;: 9\r\n      }\r\n\r\n  [1]: https://stackoverflow.com/questions/71865329/concatenate-values-from-adjacent-objects-using-jq",
        "link": "https://stackoverflow.com/questions/71918146/concatenate-values-from-non-adjacent-objects-based-on-multiple-matching-criteria",
        "title": "Concatenate values from non-adjacent objects based on multiple matching criteria"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 26377,
                    "reputation": 363501,
                    "user_id": 68587,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/7d9fd158e03cbde94f7e0b33b78222af?s=256&d=identicon&r=PG",
                    "display_name": "John Kugelman",
                    "link": "https://stackoverflow.com/users/68587/john-kugelman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650400827,
                "post_id": 71927585,
                "comment_id": 127105576,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1650401305,
                "post_id": 71927585,
                "comment_id": 127105697,
                "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": 1650401380,
                "post_id": 71927585,
                "comment_id": 127105727,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1650400333,
                "last_edit_date": 1650400333,
                "creation_date": 1650399934,
                "answer_id": 71930914,
                "question_id": 71927585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Hardcoded records to add:\r\n\r\n```sh\r\njq &#39;\r\n   . + [\r\n      {\r\n         &quot;entry&quot;: &quot;10.20.17.0/24&quot;,\r\n         &quot;comment&quot;: &quot;test ip3&quot;\r\n      },\r\n      {\r\n         &quot;entry&quot;: &quot;10.20.18.0/24&quot;,\r\n         &quot;comment&quot;: &quot;test ip4&quot;\r\n      }\r\n   ]\r\n&#39; file.json\r\n```\r\n\r\nRecords to add provided as an argument:\r\n\r\n```sh\r\njq --argjson to_add &#39;\r\n   [\r\n      {\r\n         &quot;entry&quot;: &quot;10.20.17.0/24&quot;,\r\n         &quot;comment&quot;: &quot;test ip3&quot;\r\n      },\r\n      {\r\n         &quot;entry&quot;: &quot;10.20.18.0/24&quot;,\r\n         &quot;comment&quot;: &quot;test ip4&quot;\r\n      }\r\n   ]\r\n&#39; &#39;. + $to_add&#39; file.json\r\n```\r\n\r\nRecords to add provided as a file:\r\n\r\n```sh\r\njq --argfile to_add to_add.json &#39;. + $to_add&#39; file.json\r\n```\r\n\r\nor\r\n\r\n```sh\r\njq --slurp add file.json to_add.json\r\n```\r\n",
                "title": "Dynamically add multiple key value pair in a json array in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1650401497,
        "creation_date": 1650382589,
        "last_edit_date": 1650400769,
        "question_id": 71927585,
        "body_markdown": "I am having the below json array and i wanted to append two additional key value pairs  in the json array using bash. This is need to add dynamically on my existing json array file. Can somebody share some ideas on fixing this?\r\n\r\njson array file :\r\n\r\n```\r\n[\r\n  {\r\n   &quot;entry&quot;: &quot;10.20.15.0/24&quot;,\r\n   &quot;comment&quot;: &quot;test ip1&quot;\r\n  },\r\n\r\n  {\r\n    &quot;entry&quot;: &quot;10.20.16.0/24&quot;,\r\n    &quot;comment&quot;: &quot;test ip2&quot;\r\n  }\r\n]\r\n```\r\n\r\nadditional key value pair I wanted to append,\r\n\r\n```\r\n {\r\n   &quot;entry&quot;: &quot;10.20.17.0/24&quot;,\r\n   &quot;comment&quot;: &quot;test ip3&quot;\r\n  },\r\n\r\n  {\r\n    &quot;entry&quot;: &quot;10.20.18.0/24&quot;,\r\n    &quot;comment&quot;: &quot;test ip4&quot;\r\n  }\r\n```\r\n\r\n\r\nso the final json array should  look like as below,\r\n\r\n```\r\n[\r\n  {\r\n   &quot;entry&quot;: &quot;10.20.15.0/24&quot;,\r\n   &quot;comment&quot;: &quot;test ip1&quot;\r\n  },\r\n\r\n  {\r\n    &quot;entry&quot;: &quot;10.20.16.0/24&quot;,\r\n    &quot;comment&quot;: &quot;test ip2&quot;\r\n  },\r\n\r\n  {\r\n   &quot;entry&quot;: &quot;10.20.17.0/24&quot;,\r\n   &quot;comment&quot;: &quot;test ip3&quot;\r\n  },\r\n\r\n  {\r\n    &quot;entry&quot;: &quot;10.20.18.0/24&quot;,\r\n    &quot;comment&quot;: &quot;test ip4&quot;\r\n  }\r\n\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/71927585/dynamically-add-multiple-key-value-pair-in-a-json-array-in-bash",
        "title": "Dynamically add multiple key value pair in a json array in bash"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1650463523,
                "creation_date": 1650463523,
                "answer_id": 71941128,
                "question_id": 71941009,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq --slurp &#39;.[0] * .[1]&#39; file1.json file2.json\r\n```\r\n\r\nCould be replaced with a [`reduce`][1] to match `n` files:\r\n```\r\njq &#39;reduce inputs as $i (.; . * $i)&#39; file1.json file2.json\r\n```\r\n\r\n\r\n----------\r\n\r\nTo test this, lets add `file3.json` with the following content:\r\n```json\r\n{\r\n  &quot;key7&quot;: {\r\n    &quot;key7.3&quot;: &quot;dingo&quot;\r\n  },\r\n  &quot;key8&quot;: {\r\n    &quot;key8.2&quot;: &quot;lorem&quot;\r\n  }\r\n}\r\n```\r\n\r\nChanging the command to include a wildcard (`*`) (lazy...):\r\n```\r\njq &#39;reduce inputs as $i (.; . * $i)&#39; file*.json\r\n```\r\n\r\nGives the following output:\r\n```json\r\n{\r\n  &quot;key1&quot;: {\r\n    &quot;key1.1&quot;: &quot;foo&quot;,\r\n    &quot;key1.2&quot;: &quot;bar&quot;,\r\n    &quot;key1.3&quot;: &quot;dingo&quot;\r\n  },\r\n  &quot;key2&quot;: {\r\n    &quot;key2.1&quot;: &quot;daz&quot;,\r\n    &quot;key2.2&quot;: &quot;lorem&quot;\r\n  },\r\n  &quot;key7&quot;: {\r\n    &quot;key7.3&quot;: &quot;dingo&quot;\r\n  },\r\n  &quot;key8&quot;: {\r\n    &quot;key8.2&quot;: &quot;lorem&quot;\r\n  }\r\n}\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Reduce",
                "title": "Merge n input objects in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1650463523,
        "creation_date": 1650462976,
        "question_id": 71941009,
        "body_markdown": "I have two JSON input files that I want to merge recursively:\r\n\r\n`file1.json`\r\n\r\n```json\r\n{\r\n  &quot;key1&quot;: {\r\n    &quot;key1.1&quot;: &quot;foo&quot;,\r\n    &quot;key1.2&quot;: &quot;bar&quot;\r\n  },\r\n  &quot;key2&quot;: {\r\n    &quot;key2.1&quot;: &quot;daz&quot;\r\n  }\r\n}\r\n```\r\n\r\n`file2.json`\r\n```json\r\n{\r\n  &quot;key1&quot;: {\r\n    &quot;key1.3&quot;: &quot;dingo&quot;\r\n  },\r\n  &quot;key2&quot;: {\r\n    &quot;key2.2&quot;: &quot;lorem&quot;\r\n  }\r\n}\r\n```\r\n\r\nI know I can combine these two with `--slurp` and the `*` operator:\r\n\r\n```shell\r\njq --slurp &#39;.[0] * .[1]&#39; file1.json file2.json\r\n```\r\n\r\n```json\r\n{\r\n  &quot;key1&quot;: {\r\n    &quot;key1.1&quot;: &quot;foo&quot;,\r\n    &quot;key1.2&quot;: &quot;bar&quot;,\r\n    &quot;key1.3&quot;: &quot;dingo&quot;\r\n  },\r\n  &quot;key2&quot;: {\r\n    &quot;key2.1&quot;: &quot;daz&quot;,\r\n    &quot;key2.2&quot;: &quot;lorem&quot;\r\n  }\r\n}\r\n```\r\n\r\nAnd of course I can do this with any number of files, as long as I know the exact number of input files. However, how can the `&#39;.[0] * .[1]&#39;` part be generalised to work with an arbitrary number of input files?\r\n\r\nFor the `+` operator I could do `&#39;. | add&#39;`, but `+` isn&#39;t what I want. Is there an equivalent to `add` for `*`? ",
        "link": "https://stackoverflow.com/questions/71941009/merge-n-input-objects-in-jq",
        "title": "Merge n input objects in jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1650469708,
                "last_edit_date": 1650469708,
                "creation_date": 1650469387,
                "answer_id": 71942561,
                "question_id": 71942506,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use [`to_entries`][1] so you can use `.value` to target the &#39;unknown&#39; key:\r\n```\r\njq &#39;.data | to_entries | first | .value.&quot;http_httpCode#HTTP Code&quot;&#39;\r\n```\r\n\r\n[Online demo](https://jqplay.org/s/pf6W0zDIUD)\r\n\r\n----------\r\n\r\nAnother approach by just &#39;looping over everything&#39; either with [`..`][2] or [`.[]`][3]:\r\n```jq\r\njq &#39;.data | .. | .&quot;http_httpCode#HTTP Code&quot;? // empty&#39;\r\n```\r\n[Online demo][4]\r\n```\r\njq &#39;.data | .[].&quot;http_httpCode#HTTP Code&quot;&#39;\r\n```\r\n[Online demo](https://jqplay.org/s/CfLgmlZJB7)\r\n\r\n\r\n----------\r\n\r\n\r\nThey all return `200`\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries\r\n  [2]: https://stedolan.github.io/jq/manual/#RecursiveDescent:..\r\n  [3]: https://stedolan.github.io/jq/manual/#Array/ObjectValueIterator:.[]\r\n  [4]: https://jqplay.org/s/-t_Y3zajz_",
                "title": "Bash jq with dynamic name"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1650469515,
                "creation_date": 1650469515,
                "answer_id": 71942587,
                "question_id": 71942506,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks I solved.\r\nThis is my solution:\r\n\r\n    jq -r &#39;.data | .[].&quot;http_httpCode#HTTP Code&quot;&#39;",
                "title": "Bash jq with dynamic name"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1650469708,
        "creation_date": 1650469138,
        "question_id": 71942506,
        "body_markdown": "I&#39;m trying to create a script to read the return code from a json from a curl command.\r\n\r\nmy curl command is:\r\n\r\n    curl -sk &#39;https://192.168.0.1/custom/getData.php?device=mydevice&amp;object=http--HTTP_v6_Global Index&amp;indicator=http_httpCode&amp;plugin=xxx&#39; | jq &#39;.&#39;\r\n\r\nThe json output is:\r\n\r\n    {\r\n      &quot;device&quot;: &quot;mydevice&quot;,\r\n      &quot;object&quot;: &quot;http--HTTP_v6_Global &quot;,\r\n      &quot;object_descr&quot;: &quot;HTTP download of http://192.168.0.1&quot;,\r\n      &quot;indicator&quot;: &quot;http_httpCode&quot;,\r\n      &quot;indicator_descr&quot;: null,\r\n      &quot;plugin&quot;: &quot;xxx&quot;,\r\n      &quot;starttime&quot;: 1650468121,\r\n      &quot;endtime&quot;: 1650468421,\r\n      &quot;data&quot;: {\r\n        &quot;1650468248&quot;: {\r\n          &quot;http_httpCode#HTTP Code&quot;: 200\r\n        }\r\n      }\r\n    }\r\n\r\nHow can read the value `&quot;http_httpCode#HTTP Code&quot;` if `1650468248` is a dynamic value?\r\n",
        "link": "https://stackoverflow.com/questions/71942506/bash-jq-with-dynamic-name",
        "title": "Bash jq with dynamic name"
    },
    {
        "tags": [
            "json",
            "linux",
            "vim",
            "jq",
            "unix-text-processing"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 262175,
                    "reputation": 198411,
                    "user_id": 546861,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/SIhsx.png?s=256",
                    "display_name": "romainl",
                    "link": "https://stackoverflow.com/users/546861/romainl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650480622,
                "post_id": 71944396,
                "comment_id": 127129487,
                "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": 1650480808,
                "post_id": 71944396,
                "comment_id": 127129554,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23954772,
                    "reputation": 93,
                    "user_id": 17945815,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/46e335579d40b1d6ed05c5e410ea739f?s=256&d=identicon&r=PG",
                    "display_name": "cg79",
                    "link": "https://stackoverflow.com/users/17945815/cg79"
                },
                "reply_to_user": {
                    "account_id": 262175,
                    "reputation": 198411,
                    "user_id": 546861,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/SIhsx.png?s=256",
                    "display_name": "romainl",
                    "link": "https://stackoverflow.com/users/546861/romainl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650481295,
                "post_id": 71944396,
                "comment_id": 127129735,
                "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": 1650488659,
                "post_id": 71944396,
                "comment_id": 127132019,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23954772,
                    "reputation": 93,
                    "user_id": 17945815,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/46e335579d40b1d6ed05c5e410ea739f?s=256&d=identicon&r=PG",
                    "display_name": "cg79",
                    "link": "https://stackoverflow.com/users/17945815/cg79"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650537538,
                "post_id": 71944396,
                "comment_id": 127143873,
                "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": 1662406255,
                "post_id": 71944396,
                "comment_id": 129994147,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 2,
        "last_activity_date": 1650482087,
        "creation_date": 1650478640,
        "last_edit_date": 1650482087,
        "question_id": 71944396,
        "body_markdown": "This question actually asks the &#39;inverse&#39; solution as the one [here][1], namely I would like to wrap the long column (column 4) on multiple lines. In effect, the output should look like:\r\n\r\n```\r\ncat test.csv | column -s&quot;,&quot; -t -c5 \r\n\r\ncol1 col2  col3  col4                col5\r\n1    2     3     longLineOfText      5\r\n                 ThatIWantTo\r\n                 InspectAndWould\r\n                 LikeToWrap\r\n```\r\n(excuse the u.u.o.c. duplicated over here :) ) \r\n\r\n----------------------------------------------------\r\n\r\nThe solution would _ideally_ :\r\n- make use of standard *nix text processing utilities (e.g. `column`, `paste`, `pr` which usually are present on any modern Linux machine nowadays, usually coming from the `core-utils` package);\r\n- avoid `jq` as it is not necessarily present on every (production) system;\r\n- don&#39;t overheat the brain: yes... am looking mainly at you `awk` &amp; co. gurus :). &quot;Normal&quot; `awk / perl / sed` is fine.\r\n- as a _special bonus_ , a solution using `vim` would be even more welcome (again, no brain smoke please), since that would allow for syntax-coloring as well. \r\n\r\n\r\nThe background: I want to be able to make sense of the output  of ```docker history```, so **as a last resort** even some ```Go``` *Template-magic* would suit,  as would using `jq`.\r\n\r\nIn extreme cases (if the benefits of ease-of-remembering-and-use outweigh the inconvenience of downloading a new utilty (preferably self-contained / static linked) utility on the server - is ok, or using `json` processing commands (in which case using `python`s json module would be preferred)\r\n\r\nThanks !  \r\n\r\n\r\n**LE:** \r\n**Please keep in mind, that `docker`s output has the columns separated with several *spaces*, which unfortunately confuses most commands :(** \r\n\r\n  [1]: https://stackoverflow.com/questions/42074839/column-width-parameter-not-working",
        "link": "https://stackoverflow.com/questions/71944396/formatting-wide-output-via-column-or-similar-commands",
        "title": "Formatting wide output via &#39;column&#39; (or similar) command(s)"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1650529796,
                "creation_date": 1650529796,
                "answer_id": 71951229,
                "question_id": 71950824,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution using `jq` with string interpolation and conversion to JSON using `tojson`:\r\n~~~sh\r\njq -Rr &#39;./&quot;|&quot; | &quot;\\(.[2]).\\(.[1])|\\({\r\n  &quot;myname1&quot;: .[0],\r\n  &quot;myname2&quot;: .[1],\r\n  &quot;myname3&quot;: .[2]\r\n} | tojson)&quot;&#39; file.txt\r\n~~~\r\n~~~json\r\nfield3.field2|{&quot;myname1&quot;:&quot;field1&quot;,&quot;myname2&quot;:&quot;field2&quot;,&quot;myname3&quot;:&quot;field3&quot;}\r\nfield3.field2|{&quot;myname1&quot;:&quot;field1&quot;,&quot;myname2&quot;:&quot;field2&quot;,&quot;myname3&quot;:&quot;field3&quot;}\r\nfield3.field2|{&quot;myname1&quot;:&quot;field1&quot;,&quot;myname2&quot;:&quot;field2&quot;,&quot;myname3&quot;:&quot;field3&quot;}\r\n~~~\r\n[Demo](https://jqplay.org/s/F2IZqdqtem)",
                "title": "jq (or alternatives) convert separated file into rows of json also prepending fields"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1650529796,
        "creation_date": 1650527912,
        "question_id": 71950824,
        "body_markdown": "I have a file (file.txt) like:\r\n```\r\nfield1|field2|field3 \r\nfield1|field2|field3 \r\nfield1|field2|field3 \r\n```\r\n(actually something like 83 fields, 200k rows)\r\nI need to convert it into something like:\r\n\r\n```\r\nfield3.field2|{&quot;myname1&quot;:&quot;field1&quot;,&quot;myname2&quot;:&quot;field2&quot;,&quot;myname3&quot;:&quot;field3&quot;}\r\nfield3.field2|{&quot;myname1&quot;:&quot;field1&quot;,&quot;myname2&quot;:&quot;field2&quot;,&quot;myname3&quot;:&quot;field3&quot;}\r\nfield3.field2|{&quot;myname1&quot;:&quot;field1&quot;,&quot;myname2&quot;:&quot;field2&quot;,&quot;myname3&quot;:&quot;field3&quot;}\r\n```\r\n\r\nI&#39;m currently doing it in several steps, but it takes ages:\r\n\r\n```\r\ncat file.txt |jq -nR &#39;[inputs | split(&quot;|&quot;) | {\r\n&quot;myname1&quot;: .[0],\r\n&quot;myname2&quot;: .[1],\r\n&quot;myname3&quot;: .[2]}]&#39; &gt; /var/tmp/tempfile.txt\r\n\r\ncat /var/tmp/tempfile.txt | jq -c &#39;.[]&#39; |while read row;do\r\nkey=$(echo &quot;$row&quot;|jq -r &#39;(.myname3)+&quot;.&quot;+(.myname2)&#39;)\r\necho &quot;$key|$row&quot;\r\ndone\r\n```\r\n\r\nis there a better way with jq or something else (under Linux) to achieve the same goal ?\r\n\r\nthanks",
        "link": "https://stackoverflow.com/questions/71950824/jq-or-alternatives-convert-separated-file-into-rows-of-json-also-prepending-fi",
        "title": "jq (or alternatives) convert separated file into rows of json also prepending fields"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1650534825,
                "last_edit_date": 1650534825,
                "creation_date": 1650534497,
                "answer_id": 71952349,
                "question_id": 71952200,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the splitting result with `map` to create the array under `.clusters[0].nodes`:\r\n~~~sh\r\nnodes=192.168.56.111,192.168.56.112,192.168.56.113\r\n\r\njq -R &#39;\r\n  {clusters: [{nodes: (./&quot;,&quot; | map({\r\n    node: {hostnames: {manage: [.], storage: [.]}, zone: 1},\r\n    devices: [{name: &quot;/dev/sdb&quot;, destroydata: false}]\r\n  }))}]}\r\n&#39; &lt;&lt;&lt; &quot;$nodes&quot;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;clusters&quot;: [\r\n    {\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;node&quot;: {\r\n            &quot;hostnames&quot;: {\r\n              &quot;manage&quot;: [\r\n                &quot;192.168.56.111&quot;\r\n              ],\r\n              &quot;storage&quot;: [\r\n                &quot;192.168.56.111&quot;\r\n              ]\r\n            },\r\n            &quot;zone&quot;: 1\r\n          },\r\n          &quot;devices&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;/dev/sdb&quot;,\r\n              &quot;destroydata&quot;: false\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;node&quot;: {\r\n            &quot;hostnames&quot;: {\r\n              &quot;manage&quot;: [\r\n                &quot;192.168.56.112&quot;\r\n              ],\r\n              &quot;storage&quot;: [\r\n                &quot;192.168.56.112&quot;\r\n              ]\r\n            },\r\n            &quot;zone&quot;: 1\r\n          },\r\n          &quot;devices&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;/dev/sdb&quot;,\r\n              &quot;destroydata&quot;: false\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;node&quot;: {\r\n            &quot;hostnames&quot;: {\r\n              &quot;manage&quot;: [\r\n                &quot;192.168.56.113&quot;\r\n              ],\r\n              &quot;storage&quot;: [\r\n                &quot;192.168.56.113&quot;\r\n              ]\r\n            },\r\n            &quot;zone&quot;: 1\r\n          },\r\n          &quot;devices&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;/dev/sdb&quot;,\r\n              &quot;destroydata&quot;: false\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/z3XQgY-K5g)\r\n",
                "title": "jq: convert comma seperated values into JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1650534825,
        "creation_date": 1650533904,
        "question_id": 71952200,
        "body_markdown": "I have a comma separated string of IP addresses (one or more)\r\n```Shell\r\nnodes=192.168.56.111,192.168.56.112,192.168.56.113\r\n```\r\nUsing `jq`, I would like to create a JSON document that looks like this:\r\n```JSON\r\n{\r\n  &quot;clusters&quot;: [\r\n    {\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;node&quot;: {\r\n            &quot;hostnames&quot;: {\r\n              &quot;manage&quot;: [\r\n                &quot;192.168.56.111&quot;\r\n              ],\r\n              &quot;storage&quot;: [\r\n                &quot;192.168.56.111&quot;\r\n              ]\r\n            },\r\n            &quot;zone&quot;: 1\r\n          },\r\n          &quot;devices&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;/dev/sdb&quot;,\r\n              &quot;destroydata&quot;: false\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;node&quot;: {\r\n            &quot;hostnames&quot;: {\r\n              &quot;manage&quot;: [\r\n                &quot;192.168.56.112&quot;\r\n              ],\r\n              &quot;storage&quot;: [\r\n                &quot;192.168.56.112&quot;\r\n              ]\r\n            },\r\n            &quot;zone&quot;: 1\r\n          },\r\n          &quot;devices&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;/dev/sdb&quot;,\r\n              &quot;destroydata&quot;: false\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;node&quot;: {\r\n            &quot;hostnames&quot;: {\r\n              &quot;manage&quot;: [\r\n                &quot;192.168.56.113&quot;\r\n              ],\r\n              &quot;storage&quot;: [\r\n                &quot;192.168.56.113&quot;\r\n              ]\r\n            },\r\n            &quot;zone&quot;: 1\r\n          },\r\n          &quot;devices&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;/dev/sdb&quot;,\r\n              &quot;destroydata&quot;: false\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nWhat I have so far:\r\n```Shell\r\nnodes=192.168.56.111,192.168.56.112,192.168.56.113\r\n\r\njq --arg ip &quot;$nodes&quot; &#39;.clusters[].nodes[].node.hostnames.manage |= ($ip | split(&quot;,&quot;))&#39; &lt;&lt;&lt;&#39;{&quot;clusters&quot;:[{&quot;nodes&quot;:[{&quot;node&quot;:{&quot;hostnames&quot;:{&quot;manage&quot;:[],&quot;storage&quot;:[]},&quot;zone&quot;:1},&quot;devices&quot;:[{&quot;name&quot;:&quot;/dev/sdb&quot;,&quot;destroydata&quot;:false}]}]}]}&#39;\r\n```\r\nthis has 2 problems:\r\n1) `.clusters[].nodes[].node` is not replicated.\r\n2) `.clusters[].nodes[].node.hostnames.storage` is missing.",
        "link": "https://stackoverflow.com/questions/71952200/jq-convert-comma-seperated-values-into-json",
        "title": "jq: convert comma seperated values into JSON"
    },
    {
        "tags": [
            "kubernetes",
            "jq",
            "jsonpath"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1650574861,
                "creation_date": 1650574861,
                "answer_id": 71960823,
                "question_id": 71953051,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can get json first and use `jq` to get desired result :\r\n\r\n```\r\nkubectl get pod -o json |\r\njq -r &#39;.items[]|select(any(.spec.volumes[];.hostPath.type==&quot;CharDevice&quot;)).metadata.name&#39;\r\n```",
                "title": "how to list the kubernetes pod which has CharDevice in it?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1650659193,
                "last_edit_date": 1650659193,
                "creation_date": 1650577220,
                "answer_id": 71961169,
                "question_id": 71953051,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think the filter/parsing you are expecting is not possible using `jsonpath` supplied with `Kubectl`. However, you can use `go-template` if you want to do it with `kubectl` only without using any other tool:\r\n\r\n    kubectl get pod -A -o  go-template=&#39;{{range $index, $element := .items}}{{range $key, $vol := .spec.volumes}}{{range $sk ,$sv := .hostPath}}{{if (eq $sv &quot;CharDevice&quot;) }}{{$element.metadata.name}}{{&quot;\\n&quot;}}{{end}}{{end}}{{end}}{{end}}&#39;\r\n\r\n\r\nFor readability:\r\n\r\nYou can use `{{-` to trim out the spaces on the left,`-}}`  to trim the spaces on the right. With this info, the same command as above can be transformed to:\r\n\r\n    kubectl get pod -A -o  go-template=&#39;{{- range $index, $element := .items -}}\r\n      {{- range $key, $vol := .spec.volumes -}}\r\n        {{- range $sk ,$sv := .hostPath -}}\r\n          {{- if (eq $sv &quot;CharDevice&quot;) -}}\r\n            {{- $element.metadata.name -}}{{&quot;\\n&quot;}}\r\n          {{- end -}}\r\n        {{- end -}}\r\n      {{- end -}}\r\n    {{- end -}}&#39;\r\n\r\n\r\n",
                "title": "how to list the kubernetes pod which has CharDevice in it?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1650659193,
        "creation_date": 1650537420,
        "question_id": 71953051,
        "body_markdown": "how to list the Kubernetes pod which has CharDevice in it ?\r\n\r\nI could able to get the pod with CharDevice, but need to print the pod name only\r\n\r\n    kubectl get pod -o jsonpath=&#39;{spec.volumes.hostPath.type==&quot;CharDevice&quot;}&#39;",
        "link": "https://stackoverflow.com/questions/71953051/how-to-list-the-kubernetes-pod-which-has-chardevice-in-it",
        "title": "how to list the kubernetes pod which has CharDevice in it?"
    },
    {
        "tags": [
            "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": 1650538160,
                "post_id": 71953173,
                "comment_id": 127144093,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23240363,
                    "reputation": 27,
                    "user_id": 17329770,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/567bc99033cd005b76c5e5b673c8eadd?s=256&d=identicon&r=PG",
                    "display_name": "mifogon",
                    "link": "https://stackoverflow.com/users/17329770/mifogon"
                },
                "reply_to_user": {
                    "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": 1650538660,
                "post_id": 71953173,
                "comment_id": 127144267,
                "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"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650542716,
                "post_id": 71953173,
                "comment_id": 127145720,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23240363,
                    "reputation": 27,
                    "user_id": 17329770,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/567bc99033cd005b76c5e5b673c8eadd?s=256&d=identicon&r=PG",
                    "display_name": "mifogon",
                    "link": "https://stackoverflow.com/users/17329770/mifogon"
                },
                "reply_to_user": {
                    "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": 1650544516,
                "post_id": 71953173,
                "comment_id": 127146417,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1650538867,
                "creation_date": 1650538867,
                "answer_id": 71953351,
                "question_id": 71953173,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The failing json gives the following error:\r\n\r\n&gt; parse error: Expected another key-value pair at line 7, column 3\r\n\r\nThis is caused by the trailing comma found here:\r\n```json\r\n&quot;metadata&quot;: {\r\n    &quot;name&quot;: &quot;denylation&quot;,\r\n    &quot;namespace&quot;: &quot;what&quot;,\r\n},\r\n```\r\n\r\n----------\r\n\r\nRemoving that comma, the following error is thrown:\r\n&gt; jq: error (at &lt;stdin&gt;:44): Cannot iterate over null (null)\r\n\r\nThis is caused by the missing `any` key inside the `match` object.\r\n\r\nWe can &#39;catch&#39; that error using a `?` ([docs][1]):\r\n\r\n```\r\n(.spec.rules[0].match.any[]?.resources.kinds[] / &quot;/&quot;) \r\n                           ^\r\n```\r\n\r\nBut due to the missing key, the filter does not find anything and the output is empty.\r\n\r\n\r\n----------\r\n\r\n##### [Updated jqPlay](https://jqplay.org/s/c7iD0kWlqw)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#.[]?",
                "title": "jq error cannot iterate over null but need to make a different choice"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1650547488,
                "creation_date": 1650547488,
                "answer_id": 71955280,
                "question_id": 71953173,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should work :\r\n\r\n```\r\n.metadata.namespace as $ns |\r\n((.spec.rules[0].match | .. | (objects | .resources.kinds[]?)) / &quot;/&quot;) |\r\n[select(.[1])[0] // null, select(.[2])[1] // null, last] as [$version,$group,$kind] |\r\n{namespace: $ns, kind: $kind, group: $version, version: $group} |\r\nwith_entries(select(.value!=null))\r\n```",
                "title": "jq error cannot iterate over null but need to make a different choice"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1650547488,
        "creation_date": 1650538057,
        "last_edit_date": 1650541119,
        "question_id": 71953173,
        "body_markdown": "I have a jq filter that selects the rows I need. But sometimes these lines can be empty, and then everything breaks and the rule does not work. I tried to use the if-then-else construct but to no avail.\r\n\r\nA rule that works if you process the following json:\r\n\r\n```.metadata.namespace as $ns | (.spec.rules[0].match.any[].resources.kinds[] / &quot;/&quot;) | [select(.[1])[0] // null, select(.[2])[1] // null, last] as [$version,$group,$kind] | {namespace: $ns, kind: $kind, group: $version, version: $group} | with_entries(select(.value!=null))```\r\n\r\nsuitable json:\r\n\r\n```json\r\n{\r\n  &quot;apiVersion&quot;: &quot;kyverno.io/v1&quot;,\r\n  &quot;kind&quot;: &quot;posdfsdf&quot;,\r\n  &quot;metadata&quot;: {\r\n    &quot;name&quot;: &quot;e-eion&quot;,\r\n    &quot;namespace&quot;: &quot;kke&quot;,\r\n    &quot;annotations&quot;: {\r\n      &quot;policies.kyverno.io/title&quot;: &quot;Dation&quot;,\r\n      &quot;policies.kyverno.io/category&quot;: &quot;Pod Security Standards (Restricted)&quot;,\r\n      &quot;policies.kyverno.io/severity&quot;: &quot;medium&quot;,\r\n      &quot;policies.kyverno.io/subject&quot;: &quot;Pod&quot;,\r\n      &quot;kyverno.io/kyverno-version&quot;: &quot;1.6.0&quot;,\r\n      &quot;kyverno.io/kubernetes-version&quot;: &quot;1.22-1.23&quot;,\r\n      &quot;policies.kyverno.io/description&quot;: &quot;se`.      &quot;\r\n    }\r\n  },\r\n  &quot;spec&quot;: {\r\n    &quot;validationFailureAction&quot;: &quot;audit&quot;,\r\n    &quot;background&quot;: true,\r\n    &quot;rules&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;tion&quot;,\r\n        &quot;match&quot;: {\r\n          &quot;any&quot;: [\r\n            {\r\n              &quot;resources&quot;: {\r\n                &quot;kinds&quot;: [\r\n                  &quot;Pod&quot;\r\n                ]\r\n              }\r\n            }\r\n          ]\r\n        },\r\n        &quot;validate&quot;: {\r\n          &quot;message&quot;: &quot;Prisd&quot;,\r\n          &quot;pattern&quot;: {\r\n            &quot;spec&quot;: {\r\n              &quot;=(eners)&quot;: [\r\n                {\r\n                  &quot;secxt&quot;: {\r\n                    &quot;altion&quot;: &quot;false&quot;\r\n                  }\r\n                }\r\n              ],\r\n              &quot;=(i)&quot;: [\r\n                {\r\n                  &quot;sext&quot;: {\r\n                    &quot;alcalation&quot;: &quot;false&quot;\r\n                  }\r\n                }\r\n              ],\r\n              &quot;containers&quot;: [\r\n                {\r\n                  &quot;setext&quot;: {\r\n                    &quot;an&quot;: &quot;false&quot;\r\n                  }\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nexample on which the rule stops working:\r\n```json\r\n{\r\n  &quot;apiVersion&quot;: &quot;k/v1&quot;,\r\n  &quot;kind&quot;: &quot;Picy&quot;,\r\n  &quot;metadata&quot;: {\r\n    &quot;name&quot;: &quot;denylation&quot;,\r\n    &quot;namespace&quot;: &quot;what&quot;,\r\n  },\r\n  &quot;spec&quot;: {\r\n    &quot;validationFailureAction&quot;: &quot;audit&quot;,\r\n    &quot;background&quot;: true,\r\n    &quot;rules&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;deny-privilege-escalation&quot;,\r\n        &quot;match&quot;: {\r\n          &quot;resources&quot;: {\r\n            &quot;kinds&quot;: [\r\n              &quot;Pod&quot;\r\n            ]\r\n          }\r\n        },\r\n        &quot;validate&quot;: {\r\n          &quot;message&quot;: &quot;Priviles[*].securityContext.allowPrind spec.initContalse`.&quot;,\r\n          &quot;pattern&quot;: {\r\n            &quot;spec&quot;: {\r\n              &quot;=(iners)&quot;: [\r\n                {\r\n                  &quot;=(seext)&quot;: {\r\n                    &quot;=(aln)&quot;: &quot;false&quot;\r\n                  }\r\n                }\r\n              ],\r\n              &quot;containers&quot;: [\r\n                {\r\n                  &quot;=(stext)&quot;: {\r\n                    &quot;=(al)&quot;: &quot;false&quot;\r\n                  }\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\nhow can this be fixed? I need the rule to work out in any cases and give output",
        "link": "https://stackoverflow.com/questions/71953173/jq-error-cannot-iterate-over-null-but-need-to-make-a-different-choice",
        "title": "jq error cannot iterate over null but need to make a different choice"
    },
    {
        "tags": [
            "bash",
            "jq",
            "kubectl"
        ],
        "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": 1650545838,
                "post_id": 71954738,
                "comment_id": 127146961,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25036244,
                    "reputation": 11,
                    "user_id": 18893607,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0ca09c868cb84729a590c25bb9ccc7d2?s=256&d=identicon&r=PG",
                    "display_name": "skipskap7",
                    "link": "https://stackoverflow.com/users/18893607/skipskap7"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1650548110,
                "post_id": 71954738,
                "comment_id": 127147989,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25036244,
                    "reputation": 11,
                    "user_id": 18893607,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0ca09c868cb84729a590c25bb9ccc7d2?s=256&d=identicon&r=PG",
                    "display_name": "skipskap7",
                    "link": "https://stackoverflow.com/users/18893607/skipskap7"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1650548737,
                "post_id": 71954738,
                "comment_id": 127148256,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1650548669,
                "creation_date": 1650548669,
                "answer_id": 71955561,
                "question_id": 71954738,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks to @Fravadona, it was just a matter of parentheses. I had tried it at some point and made some mistake or other, but a working solution for my case is\r\n```\r\njq -r &#39;{message: .status | (.conditions? // []) | map(select(has(&quot;message&quot;)).message)[0]?}&#39;\r\n```\r\n",
                "title": "How can I use jq &#39;try-catch&#39; inside of an object construction"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1650548669,
        "creation_date": 1650545207,
        "question_id": 71954738,
        "body_markdown": "The general problem statement is that I have some json data with fields that may or may not exist. Patterns like `try .foo catch &quot;bar&quot;` or `.foo? // &quot;bar&quot;` work just fine on their own, but not inside of an object construction `cat myfile.json | jq -r &#39;{foo: try .foo catch &quot;bar&quot;}&#39;`. Using an object construction is important for my use case, where I need to pass the same input through many filters and format the data nicely for later functions.\r\n\r\nThe data I&#39;m working with is the output of `kubectl get pods xxxxx -o json`, and the part I&#39;m trying to parse looks like this\r\n```\r\n{\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;status&quot;: {\r\n        &quot;conditions&quot;: [\r\n          {\r\n            &quot;type&quot;: &quot;Initialized&quot;,\r\n            &quot;message&quot;: &quot;foo&quot;\r\n          },\r\n          {\r\n            &quot;type&quot;: &quot;Ready&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;status&quot;: {\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\nFor each item, if it has `.status.conditions`, I want the message from the first element in `.status.conditions` that has a message. The filter I used looks like this\r\n```\r\njq -r &#39;.items[] | {message: .status.conditions?|map(select(has(&quot;message&quot;)).message)[0]?}&#39;\r\n```\r\nThe problem is that when it gets to an item that doesn&#39;t have a `.status.conditions`, It returns the error `Cannot iterate over null (null)`. This makes sense given that `.status.conditions?` passes `null` to the next filter, `map` which needs to iterate over a list. My attempted solution was to use various ways of `try-catch` to pass an empty list to map instead of null\r\n```\r\njq -r &#39;.items[] | {message: .status | try .conditions catch [] |map(select(has(&quot;message&quot;)).message)[0]?}&#39;\r\njq -r &#39;.items[] | {message: .status.conditions? // []|map(select(has(&quot;message&quot;)).message)[0]?}&#39;\r\n```\r\nor to use a `?` that includes the `map` call\r\n```\r\njq -r &#39;.items[] | {message: (.status.conditions?|map(select(has(&quot;message&quot;)).message)[0])?}&#39;\r\njq -r &#39;.items[] | {message: .status.conditions?|(map(select(has(&quot;message&quot;)).message)[0])?}&#39;\r\n```\r\nAll of these attempts return `1 compile error` when written inside of an object constructor as shown, and work as expected when written on their own without an object constructor (e.g. `&#39;.items[] | .status.conditions?|(map(select(has(&quot;message&quot;)).message)[0])?&#39;`)\r\n\r\nThe jq man page doesn&#39;t give any warnings (that I noticed) about how object construction changes the syntax requirements of what&#39;s inside, nor how `try-catch` can be affected by being inside an object construction. Any ideas?",
        "link": "https://stackoverflow.com/questions/71954738/how-can-i-use-jq-try-catch-inside-of-an-object-construction",
        "title": "How can I use jq &#39;try-catch&#39; inside of an object construction"
    },
    {
        "tags": [
            "json",
            "jq",
            "powerdns"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1650565418,
                "creation_date": 1650565418,
                "answer_id": 71959231,
                "question_id": 71957944,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can convert numeric strings to numbers using:\r\n\r\n    if type == &quot;string&quot; then . as $in | try tonumber catch $in else . end\r\n\r\nAs a post-processing step, you could use `walk` as a wrapper:\r\n\r\n    walk(if type == &quot;string&quot; then . as $in | try tonumber catch $in else . end)",
                "title": "Reduce nested json (PowerDNS stats)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1650575430,
                "creation_date": 1650575430,
                "answer_id": 71960916,
                "question_id": 71957944,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To transform this input :\r\n\r\n```\r\n{\r\n  &quot;x-ourtime8-16&quot;: &quot;0&quot;,\r\n  &quot;zone-disallowed-notify&quot;: &quot;0&quot;,\r\n  &quot;response-by-qtype&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;A&quot;,\r\n      &quot;value&quot;: &quot;8958&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;NS&quot;,\r\n      &quot;value&quot;: &quot;6&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nYou can run :\r\n\r\n```\r\njq &#39; to_entries |\r\n     map(if (.value | type) == &quot;string&quot;\r\n         then .value |= tonumber\r\n         else .key as $key | .value[] |\r\n              .name  |= $key+&quot;.&quot;+. |\r\n              .value |= tonumber\r\n         end\r\n     ) | from_entries\r\n&#39; input.json\r\n```\r\n\r\nto get :\r\n\r\n```\r\n{\r\n  &quot;x-ourtime8-16&quot;: 0,\r\n  &quot;zone-disallowed-notify&quot;: 0,\r\n  &quot;response-by-qtype.A&quot;: 8958,\r\n  &quot;response-by-qtype.NS&quot;: 6\r\n}\r\n```",
                "title": "Reduce nested json (PowerDNS stats)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1650575430,
        "creation_date": 1650558996,
        "question_id": 71957944,
        "body_markdown": "I&#39;m trying to improve on a jq reduce, but finding that some of the returned data is nested and the code I&#39;m using breaks on that.\r\n\r\nThis is where I&#39;ve got the jq code from: https://github.com/influxdata/telegraf/tree/master/plugins/inputs/powerdns_recursor\r\n\r\nTaking `tonumber` off I get the following clipped output:\r\n\r\n```\r\n[...]\r\n  &quot;x-ourtime8-16&quot;: &quot;0&quot;,\r\n  &quot;zone-disallowed-notify&quot;: &quot;0&quot;,\r\n  &quot;response-by-qtype&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;A&quot;,\r\n      &quot;value&quot;: &quot;8958&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;NS&quot;,\r\n      &quot;value&quot;: &quot;6&quot;\r\n    },\r\n[...]\r\n```\r\n\r\nThe original code, with `tonumber` left in:\r\n\r\n`curl -s -H &#39;X-API-Key: &lt;key&gt;&#39; http://127.0.0.1:8082/api/v1/servers/localhost/statistics | jq &#39;reduce .[] as $item ({}; . + { ($item.name): ($item.value|tonumber)})&#39;`\r\n\r\nThe output I&#39;m after:\r\n\r\n```\r\n[...]\r\n  &quot;x-ourtime8-16&quot;: 0,\r\n  &quot;zone-disallowed-notify&quot;: 0,\r\n  &quot;response-by-qtype.A&quot;: 8958,\r\n  &quot;response-by-qtype.NS&quot;: 6,\r\n[...]\r\n```\r\n\r\nI&#39;ve spent some time Googling jq and nested input, but I don&#39;t want the index numbers this gave me in the names. I&#39;m hoping a small tweak will do the trick.",
        "link": "https://stackoverflow.com/questions/71957944/reduce-nested-json-powerdns-stats",
        "title": "Reduce nested json (PowerDNS stats)"
    },
    {
        "tags": [
            "yaml",
            "jq",
            "yq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650576705,
                "post_id": 71960890,
                "comment_id": 127158163,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1650581554,
                "last_edit_date": 1650581554,
                "creation_date": 1650578199,
                "answer_id": 71961326,
                "question_id": 71960890,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I am assuming from the syntax that you are using [kislyuk yq][kyq].\r\n\r\n[kyq]: https://github.com/kislyuk/yq\r\n\r\n`del` is not the right tool for this job. `del` takes in a stream of N values and returns a stream of N modified values. In your case it takes in a stream of three values and returns a stream of three values. You observe that it leaves the first and last objects unchanged, but replaces the second with `null`. For each value it inputs, it evaluates its argument filter to decide how to change that value - every location emitted by that filter will be removed. You have provided as its argument a `select` filter. A select filter takes in a stream of values, and emits a stream of _some_ of those values unmodified, while discarding others, depending on its filter argument. (Actually, it&#39;s a little more complicated than that - if you pass it a filter that returns multiple values, it can actually emit more values than it received, but that&#39;s not relevant here.)\r\n\r\nIn this case, your `select` filter returns nothing for the first object, because it doesn&#39;t match, so the `del` changes nothing. For the second object, the `select` filter _does_ match the object, so the `del` filter is equivalent to `del(.)`. The docs aren&#39;t terribly clear about what to expect when the filter you pass to `del` doesn&#39;t pick a key (or index) in the object (or array), but instead the whole thing, but clearly the behaviour in practice is that it replaces it with `null`.\r\n\r\nIf you followed along with that explanation, you may see where this is going. `select` is already the tool you want! There is no need for `del` here at all. `select` is the mechanism to keep only _some_ of a stream of objects. Try:\r\n\r\n```\r\n$ cat ~/scratch/test.yaml | yq -y &#39;select(.kind != &quot;Namespace&quot; or .metadata.name != &quot;bar&quot;)&#39;\r\napiVersion: v1\r\nkind: Namespace\r\nmetadata:\r\n  name: foo\r\nspec: {}\r\nstatus: {}\r\n---\r\napiVersion: v1\r\nkind: Namespace\r\nmetadata:\r\n  name: baz\r\nspec: {}\r\nstatus: {}\r\n```",
                "title": "How to delete a Kubernetes resource entirely with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1650579723,
                "creation_date": 1650579723,
                "answer_id": 71961497,
                "question_id": 71960890,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use [gojq][1], the Go implementation of jq:\r\n```\r\ngojq --yaml-input --yaml-output &#39;select(.metadata.name != &quot;bar&quot;)&#39; test.yaml\r\n```\r\n\r\n\r\n  [1]: https://github.com/itchyny/gojq",
                "title": "How to delete a Kubernetes resource entirely with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1650597343,
        "creation_date": 1650575281,
        "last_edit_date": 1650597343,
        "question_id": 71960890,
        "body_markdown": "I&#39;m trying to use `jq` (and yq) to delete a single Kubernetes resource.\r\nI thought I could do with this with `del` but it is leaving behind a `null`.\r\n\r\n```\r\n$ cat test.yaml | yq -y &#39;. | del(select(.kind == &quot;Namespace&quot; and .metadata.name == &quot;bar&quot;))&#39; \r\napiVersion: v1\r\nkind: Namespace\r\nmetadata:\r\n  name: foo\r\nspec: {}\r\nstatus: {}\r\n--- null\r\n---\r\napiVersion: v1\r\nkind: Namespace\r\nmetadata:\r\n  name: baz\r\nspec: {}\r\nstatus: {}\r\n\r\n```\r\n\r\nMy test data:\r\n\r\n```\r\n$ cat test.yaml \r\napiVersion: v1\r\nkind: Namespace\r\nmetadata:\r\n  name: foo\r\nspec: {}\r\nstatus: {}\r\n---\r\napiVersion: v1\r\nkind: Namespace\r\nmetadata:\r\n  name: bar\r\nspec: {}\r\nstatus: {}\r\n---\r\napiVersion: v1\r\nkind: Namespace\r\nmetadata:\r\n  name: baz\r\nspec: {}\r\nstatus: {}\r\n```\r\n\r\nHow do I get this output?\r\n```\r\napiVersion: v1\r\nkind: Namespace\r\nmetadata:\r\n  name: foo\r\nspec: {}\r\nstatus: {}\r\n---\r\napiVersion: v1\r\nkind: Namespace\r\nmetadata:\r\n  name: baz\r\nspec: {}\r\nstatus: {}\r\n```",
        "link": "https://stackoverflow.com/questions/71960890/how-to-delete-a-kubernetes-resource-entirely-with-jq",
        "title": "How to delete a Kubernetes resource entirely with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "object",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15788230,
                    "reputation": 44188,
                    "user_id": 11392290,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xTF1b.jpg?s=256",
                    "display_name": "Serge",
                    "link": "https://stackoverflow.com/users/11392290/serge"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650580511,
                "post_id": 71961428,
                "comment_id": 127158925,
                "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"
                },
                "reply_to_user": {
                    "account_id": 15788230,
                    "reputation": 44188,
                    "user_id": 11392290,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xTF1b.jpg?s=256",
                    "display_name": "Serge",
                    "link": "https://stackoverflow.com/users/11392290/serge"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1650581655,
                "post_id": 71961428,
                "comment_id": 127159091,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1650585915,
                "last_edit_date": 1650585915,
                "creation_date": 1650581465,
                "answer_id": 71961671,
                "question_id": 71961428,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `/=` to update by splitting, `startswith` to match at the beginnning of a string, and `to_entries` and `with_entries` to manipulate entries involving the key name:\r\n\r\n~~~sh\r\njq &#39;\r\n  .flag /= &quot; &quot;\r\n  | .tests = (to_entries | map(.key | select(startswith(&quot;test &quot;))[5:]))\r\n  | with_entries(select(.key | startswith(&quot;test &quot;) | not))\r\n&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/_9jFrSXXA3)\r\n\r\n---\r\n\r\nAnother, maybe more efficient implementation which loops just once through the object using `reduce` could be:\r\n~~~sh\r\njq &#39;\r\n  reduce to_entries[] as {$key, $value} (null;\r\n    if   $key == &quot;flag&quot;             then .flag = $value / &quot; &quot;\r\n    elif $key | startswith(&quot;test &quot;) then .tests += [$key[5:]]\r\n    else                                 .[$key] = $value end\r\n  )\r\n&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/NY-xEfFekT)\r\n\r\n---\r\nGiven the sample data, both produce:\r\n~~~json\r\n{\r\n  &quot;one&quot;: &quot;1&quot;,\r\n  &quot;two&quot;: &quot;2&quot;,\r\n  &quot;flag&quot;: [\r\n    &quot;f1&quot;,\r\n    &quot;f2&quot;,\r\n    &quot;f3&quot;\r\n  ],\r\n  &quot;tests&quot;: [\r\n    &quot;one&quot;,\r\n    &quot;two&quot;,\r\n    &quot;three&quot;\r\n  ]\r\n}\r\n~~~",
                "title": "Transform specific fields into array(s) using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1650585915,
        "creation_date": 1650579049,
        "question_id": 71961428,
        "body_markdown": "Given the following JSON:\r\n```json\r\n{\r\n  &quot;one&quot;: &quot;1&quot;,\r\n  &quot;two&quot;: &quot;2&quot;,\r\n  &quot;flag&quot;: &quot;f1 f2 f3&quot;,\r\n  &quot;test one&quot;: &quot;&quot;,\r\n  &quot;test two&quot;: &quot;&quot;,\r\n  &quot;test three&quot;: &quot;&quot;\r\n}\r\n```\r\n\r\nIs it possible to obtain the following result using _jq_?\r\n\r\n```json\r\n{\r\n  &quot;one&quot;: &quot;1&quot;,\r\n  &quot;two&quot;: &quot;2&quot;,\r\n  &quot;flags&quot;: [&quot;f1&quot;, &quot;f2&quot;, &quot;f3&quot;],\r\n  &quot;tests&quot;: [&quot;one&quot;, &quot;two&quot;, &quot;three&quot;]\r\n}\r\n```\r\n\r\nThree points are crucial:\r\n\r\n1. Leave unchanged any field that is not `flag` or starts with `test `\r\n\r\n1. Transform `flag` (space separated values) into an array\r\n\r\n1. Any field that starts with `test ` is added to an array (`tests`) where the value is the remaining part of the field&#39;s name",
        "link": "https://stackoverflow.com/questions/71961428/transform-specific-fields-into-arrays-using-jq",
        "title": "Transform specific fields into array(s) using jq"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 14,
                "is_accepted": true,
                "score": 14,
                "last_activity_date": 1650609346,
                "creation_date": 1650609346,
                "answer_id": 71964370,
                "question_id": 71963736,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `.[].name + &quot; &quot; + .[].id&#39;` you iterate twice over the array. Iterate once and extract your data in one go:\r\n~~~sh\r\ncurl … | jq -r &#39;.data[] | .name + &quot; &quot; + .id&#39;\r\n~~~\r\n~~~none\r\nNetbank734113 8a70803f8045722601804f62d54c5d9d\r\nNetbank734112 8a70801c804568ae01804f625a923f8d\r\n~~~\r\n[Demo](https://jqplay.org/s/ZJ2MpA4D9q)\r\n\r\n---\r\nYou might also be interested in using string interpolation:\r\n~~~sh\r\ncurl … | jq -r &#39;.data[] | &quot;\\(.name) \\(.id)&quot;&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/jEE9mmCmg7)",
                "title": "how to get multiple values from a json array/object using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1705064073,
                "creation_date": 1705064073,
                "answer_id": 77806714,
                "question_id": 71963736,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "you could take the output of jq and use the unix shell to de-duplicate the output ...\r\n\r\ncommand_output | sort | uniq\r\n",
                "title": "how to get multiple values from a json array/object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 8,
        "last_activity_date": 1705064073,
        "creation_date": 1650604519,
        "last_edit_date": 1650610537,
        "question_id": 71963736,
        "body_markdown": " how to get multiple values from a JSON array/object using jq in a single line?\r\n\r\nhere curl request and its response\r\n\r\n```\r\ncurl -s -k --location --request GET &quot;https://${HOSTNAME}/api/v1/projects/myProjects?page=1&amp;pageSize=2&quot; --header &quot;Authorization: Bearer &quot;$token&quot;&quot; | jq -r &#39;.[&quot;data&quot;]&#39;\r\n\r\n\r\n# Response\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;8a70803f8045722601804f62d54c5d9d&quot;,\r\n    &quot;createdBy&quot;: &quot;8a70802980325cdc0180326b5fe60006&quot;,\r\n    &quot;createdDate&quot;: &quot;2022-04-22T03:48:38.860+0000&quot;,\r\n    &quot;modifiedBy&quot;: &quot;8a70802980325cdc0180326b5fe60006&quot;,\r\n    &quot;modifiedDate&quot;: &quot;2022-04-22T03:48:38.860+0000&quot;,\r\n    &quot;version&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;name&quot;: &quot;Netbank734113&quot;,\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;8a70801c804568ae01804f625a923f8d&quot;,\r\n    &quot;createdBy&quot;: &quot;8a70802980325cdc0180326b5fe60006&quot;,\r\n    &quot;createdDate&quot;: &quot;2022-04-22T03:48:07.442+0000&quot;,\r\n    &quot;modifiedBy&quot;: &quot;8a70802980325cdc0180326b5fe60006&quot;,\r\n    &quot;modifiedDate&quot;: &quot;2022-04-22T03:48:07.442+0000&quot;,\r\n    &quot;version&quot;: null,\r\n    &quot;inactive&quot;: false,\r\n    &quot;name&quot;: &quot;Netbank734112&quot;,\r\n  }\r\n]\r\n\r\n```\r\n\r\nNow try the below command to get the id and name in one line but duplicate results are coming.\r\n\r\n```\r\nresult=$(curl -s -k --location --request GET &quot;https://${HOSTNAME}/api/v1/projects/myProjects?page=1&amp;pageSize=2&quot; --header &quot;Authorization: Bearer &quot;$token&quot;&quot; | jq -r &#39;.[&quot;data&quot;]|.[].name +&quot; &quot;+  .[].id&#39;)\r\n\r\necho &quot;$result&quot;\r\n\r\n# response\r\nNetbank734113 8a70803f8045722601804f62d54c5d9d\r\nNetbank734112 8a70803f8045722601804f62d54c5d9d\r\nNetbank734113 8a70801c804568ae01804f625a923f8d\r\nNetbank734112 8a70801c804568ae01804f625a923f8d\r\n\r\n```\r\n\r\nhow do I get rid of those duplicated values and basically get the below response?\r\n\r\n```\r\nNetbank734113 8a70803f8045722601804f62d54c5d9d\r\nNetbank734112 8a70801c804568ae01804f625a923f8d\r\n\r\n```\r\n\r\n\r\nTried this command with your inputs getting the below errors, how do I modify this curl command to get desired results.\r\n\r\n```\r\nresult=$(curl -s -k --location --request GET &quot;https://${HOSTNAME}/api/v1/projects/myProjects?page=1&amp;pageSize=2&quot; --header &quot;Authorization: Bearer &quot;$token&quot;&quot; | jq -r &#39;[&quot;data&quot;]|.[].unique_by(.name, .id) | map([.name, .id])[] | @tsv&#39;)\r\n\r\n# error response\r\n\r\njq: error: syntax error, unexpected &#39;(&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n[&quot;data&quot;]|.[].unique_by(.name, .id) | map([.name, .id])[] | @tsv                      \r\njq: 1 compile error\r\n \r\n# This one worked\r\nresult=$(curl -s -k --location --request GET &quot;https://${HOSTNAME}/api/v1/projects/myProjects?page=1&amp;pageSize=2&quot; --header &quot;Authorization: Bearer &quot;$token&quot;&quot; | jq -r &#39;.[&quot;data&quot;]|.[]|.| .name + &quot; &quot; + .id&#39;)\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/71963736/how-to-get-multiple-values-from-a-json-array-object-using-jq",
        "title": "how to get multiple values from a json array/object using jq"
    },
    {
        "tags": [
            "json",
            "variables",
            "hash",
            "arguments",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1650645529,
                "last_edit_date": 1650645529,
                "creation_date": 1650645076,
                "answer_id": 71971950,
                "question_id": 71971599,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can follow the steps as you had indicated, which should work. Create the base64 content, store it in a variable and pass it to `jq`\r\n\r\n```bash\r\n#!/usr/bin/env bash\r\n# Bash script to construct a base64 of a JSON content and passing\r\n# it to an another command\r\n\r\n# Create the base64\r\nbase=$(jq -c . input.json | base64)\r\n\r\n# Create the JSON that stores the above hash\r\njson=$(jq -cn --arg b64 &quot;$base&quot; &#39;{&quot;input&quot;: $b64, &quot;option1&quot;: &quot;value1&quot;, &quot;option2&quot;: &quot;value2&quot; }&#39;)\r\n\r\n# If you want the JSON to be a literal string, use the &#39;@text&#39; filter\r\n# with &#39;jq&#39;\r\njsonString=$(jq -cn --arg b64 &quot;$base&quot; &#39;{&quot;input&quot;: $b64, &quot;option1&quot;: &quot;value1&quot;, &quot;option2&quot;: &quot;value2&quot; } | @text&#39;)\r\n\r\n# Pass the contents of either &#39;json&#39; or &#39;jsonString&#39;, depending on \r\n# how your executable parses the command line argument\r\n```\r\n",
                "title": "Reference a json file and pass it as json hash into a json input for a command argument"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1650645529,
        "creation_date": 1650643268,
        "question_id": 71971599,
        "body_markdown": "I have a json file named &quot;input.json&quot;:\r\n```\r\n{\r\n  &quot;item1&quot;: &quot;banana&quot;,\r\n  &quot;item2&quot;: false\r\n}\r\n```\r\nand I have a bash command that takes in a json input, which then takes in the hash of the above file content as the value for the &quot;input&quot; key:\r\n```\r\nexecutable &#39;{&quot;input&quot;: {&quot;item1&quot;: &quot;banana&quot;, &quot;item2&quot;: false}, &quot;option1&quot;: &quot;value1&quot;, &quot;option2&quot;: &quot;value2&quot; }&#39;\r\n```\r\n\r\nHow can I pass the json content from input.json file into the command? I have tried:\r\n- create the one-line json hash from the input.json with `jq -c . input.json` and pass the hash to a variable, then reference that variable in the command - it did not work (value expected is missing - likely because of the single quote that messed up the reference).\r\n\r\nAny help or pointer is appreciated.",
        "link": "https://stackoverflow.com/questions/71971599/reference-a-json-file-and-pass-it-as-json-hash-into-a-json-input-for-a-command-a",
        "title": "Reference a json file and pass it as json hash into a json input for a command argument"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "summarize"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650648951,
                "post_id": 71971940,
                "comment_id": 127177473,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1695929,
                    "reputation": 1839,
                    "user_id": 1557306,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://i.sstatic.net/7cDGa.jpg?s=256",
                    "display_name": "Leevi L",
                    "link": "https://stackoverflow.com/users/1557306/leevi-l"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650652305,
                "post_id": 71971940,
                "comment_id": 127178454,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1650658684,
                "last_edit_date": 1650658684,
                "creation_date": 1650649447,
                "answer_id": 71972743,
                "question_id": 71971940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will do it:\r\n```\r\ndef compress:\r\n  if type == &quot;array&quot;\r\n  then (if    all(.[]; type == &quot;string&quot;) then &quot;[string]&quot;\r\n        elif  all(.[]; type == &quot;number&quot;) then &quot;[number]&quot;\r\n        elif  all(.[]; type == &quot;boolean&quot;) then &quot;[boolean]&quot;\r\n\t    else .\r\n\t    end)\r\n  else .\r\n  end;\r\n\r\nwalk(compress)\r\n```\r\n\r\nWith your sample input, the result would be:\r\n```\r\n{\r\n  &quot;version&quot;: &quot;[string]&quot;,\r\n  &quot;walltime_seconds&quot;: &quot;[number]&quot;\r\n}\r\n```\r\n\r\n--- \r\nTo include the length and handle arrays of `null`:\r\n```\r\ndef compress:\r\n  def check($t):\r\n    if all(.[]; type == $t) then &quot;[\\($t)[\\(length)]]&quot; else empty end;\r\n  if type == &quot;array&quot;\r\n  then check(&quot;string&quot;) // check(&quot;number&quot;) // check(&quot;boolean&quot;) // check(&quot;null&quot;) // .\r\n  else .\r\n  end;\r\n```",
                "title": "How to compress output of arrays of primitive type?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1650696152,
        "creation_date": 1650645032,
        "last_edit_date": 1650696152,
        "question_id": 71971940,
        "body_markdown": "My json file contains arrays of ints and strings and objects. Is there a way of compressing the output of arrays that contain only ints or strings?\r\n- either do not display elements of these arrays, or\r\n- show type of elements and count\r\n\r\nThis is what it looks like now:\r\n\r\n```\r\n$ jq &quot;.&quot; foo.json\r\n{\r\n    &quot;version&quot;: [\r\n            &quot;2.53.0&quot;,\r\n            &quot;2.53.0&quot;,\r\n            &quot;2.53.0&quot;,\r\n            &quot;2.53.0&quot;,\r\n            &quot;2.53.0&quot;,\r\n            &quot;2.53.3&quot;,\r\n            &quot;2.53.3&quot;,\r\n            &quot;2.53.0&quot;,\r\n            &quot;2.53.0&quot;,\r\n            &quot;2.53.3&quot;,\r\n            &quot;2.53.0&quot;,\r\n            &quot;2.53.0&quot;,\r\n            &quot;2.53.3&quot;,\r\n            &quot;2.53.0&quot;,\r\n            &quot;2.53.0&quot;,\r\n            &quot;2.53.0&quot;,\r\n            &quot;2.53.0&quot;,\r\n            &quot;2.53.0&quot;,\r\n            &quot;2.53.3&quot;,\r\n            &quot;2.53.0&quot;\r\n          ],\r\n    &quot;walltime_seconds&quot;: [\r\n            0.165,\r\n            0.199,\r\n            0.415,\r\n            0.193,\r\n            12.114,\r\n            0.227,\r\n            12.341,\r\n            12.145,\r\n            0.135,\r\n            0.326,\r\n            0.293,\r\n            0.19,\r\n            0.271,\r\n            0.103,\r\n            0.196,\r\n            0.18,\r\n            0.177,\r\n            0.166,\r\n            0.506,\r\n            0.568\r\n          ]\r\n}\r\n```\r\n\r\nThis is what I would like:\r\n\r\n```\r\n{\r\n    &quot;version&quot;: &quot;[..]&quot;,\r\n    &quot;walltime_seconds&quot;: &quot;[..]&quot;,\r\n\r\n}\r\n```\r\n\r\nor this\r\n\r\n```\r\n{\r\n    &quot;version&quot;: &quot;Array(str, 20)&quot;,\r\n    &quot;walltime_seconds&quot;: &quot;Array(float, 20)&quot;,\r\n\r\n}\r\n```\r\n\r\nOf course the compression should happen anywhere in the json tree and it should only be done for int, str, float and not for objects.",
        "link": "https://stackoverflow.com/questions/71971940/how-to-compress-output-of-arrays-of-primitive-type",
        "title": "How to compress output of arrays of primitive type?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1650659976,
                "creation_date": 1650659976,
                "answer_id": 71974389,
                "question_id": 71974388,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The solution is:\r\n\r\n    .|{ one: (.[]|select(.key==&quot;1&quot;).value), two: (.[]|select(.key==&quot;2&quot;).value) }\r\n\r\nThe array needed to be sent through as one stream.  Using `.[]|` caused two separate streams one for each element of the array.\r\n\r\nThis is clear by doing:\r\n\r\n    .[]|{ single: .key }\r\n\r\nWhich produced:\r\n\r\n    {\r\n      &quot;single&quot;: &quot;1&quot;\r\n    }\r\n    {\r\n      &quot;single&quot;: &quot;2&quot;\r\n    }\r\n\r\nSince each individual stream did not have the criteria to meet both attributes (`key==&quot;1&quot;` and `key==&quot;2&quot;`), each one got eliminated from each stream.  Sending the array through as a whole (`.|`) instead of as individual elements (`.[]|`) allowed both `select()`&#39;s to behave as intended.",
                "title": "Two select()s in jq seem to throw off current pointer"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1650661566,
                "creation_date": 1650661566,
                "answer_id": 71974630,
                "question_id": 71974388,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this :\r\n\r\n```\r\njq &#39;from_entries as $mapping |\r\n    {one:&quot;1&quot;, two:&quot;2&quot;}       |\r\n    map_values($mapping[.])&#39; input.json\r\n```\r\n\r\nThis way, you can add more easily `three`, `four`,...",
                "title": "Two select()s in jq seem to throw off current pointer"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1650683347,
                "creation_date": 1650683347,
                "answer_id": 71976520,
                "question_id": 71974388,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The *correct way* in this case is:\r\n```\r\nfrom_entries | {one: .&quot;1&quot;, two: .&quot;2&quot;}\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/Vq6hWRzdo8)&lt;/sup&gt;",
                "title": "Two select()s in jq seem to throw off current pointer"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1664702684,
        "creation_date": 1650659976,
        "last_edit_date": 1664702684,
        "question_id": 71974388,
        "body_markdown": "With JSON:\r\n\r\n    [\r\n        {\r\n            &quot;key&quot;: &quot;1&quot;,\r\n            &quot;value&quot;: &quot;one&quot;\r\n        },\r\n        {\r\n            &quot;key&quot;: &quot;2&quot;,\r\n            &quot;value&quot;: &quot;two&quot;\r\n        }\r\n    ]\r\n\r\nAnd `jq`:\r\n\r\n    .[]|{ one: select(.key==&quot;1&quot;).value }\r\n\r\nI get expected result:\r\n\r\n    {\r\n      &quot;one&quot;: &quot;one&quot;\r\n    }\r\n\r\nIf I add a second attribute, it ends up empty:\r\n\r\n    .[]|{ one: select(.key==&quot;1&quot;).value, two: select(.key==&quot;2&quot;).value }\r\n\r\nIf I make the `two` attribute just to be `.`, it shows `.` has become the node selected by `select()`:\r\n\r\n    .[]|{ one: (select(.key==&quot;1&quot;).value), two: . }\r\n\r\nProduces:\r\n\r\n    {\r\n      &quot;one&quot;: &quot;one&quot;,\r\n      &quot;two&quot;: {\r\n        &quot;key&quot;: &quot;1&quot;,\r\n        &quot;value&quot;: &quot;one&quot;\r\n      }\r\n    }\r\n\r\nHow do I use `select()` in a way that doesn&#39;t affect `.` ?  Or better put, what is the correct way to accomplish what I am looking for:\r\n\r\n    {\r\n      &quot;one&quot;: &quot;one&quot;,\r\n      &quot;two&quot;: &quot;two&quot;\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/71974388/two-selects-in-jq-seem-to-throw-off-current-pointer",
        "title": "Two select()s in jq seem to throw off current pointer"
    },
    {
        "tags": [
            "jenkins",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 374049,
                    "reputation": 15207,
                    "user_id": 724039,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NsCwt.png?s=256",
                    "display_name": "Luuk",
                    "link": "https://stackoverflow.com/users/724039/luuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650709858,
                "post_id": 71978606,
                "comment_id": 127187658,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14586701,
                    "reputation": 109,
                    "user_id": 11014052,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-YuEfYOHJTu4/AAAAAAAAAAI/AAAAAAAAAAA/ABtNlbAB--k5aGVapj7x7YldjLqliW9eOQ/mo/s256-rj/photo.jpg",
                    "display_name": "Sandesh Sawant",
                    "link": "https://stackoverflow.com/users/11014052/sandesh-sawant"
                },
                "reply_to_user": {
                    "account_id": 374049,
                    "reputation": 15207,
                    "user_id": 724039,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NsCwt.png?s=256",
                    "display_name": "Luuk",
                    "link": "https://stackoverflow.com/users/724039/luuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650710139,
                "post_id": 71978606,
                "comment_id": 127187713,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1650710977,
                "last_edit_date": 1650710977,
                "creation_date": 1650709803,
                "answer_id": 71978840,
                "question_id": 71978606,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would use a simple batch script to check if Jenkins is started.\r\n\r\n```\r\n@echo off\r\n\r\nset checks=3\r\n\r\n:again\r\njenkins.exe status | find &quot;Started&quot; &gt;nul\r\nif errorlevel 1 (\r\n   timeout /t 1 1&gt;nul\r\n   echo %checks%\r\n   set /a checks=checks-1\r\n   if not &quot;%checks%&quot;==&quot;0&quot; goto :again\r\n   goto :error\r\n)\r\n\r\necho Jenkins is started\r\ngoto :eof\r\n\r\n:error\r\necho Jenkins is NOT started\r\n```\r\n\r\n\r\nEDIT: Checking for `message` can be done in mostly the same way as above where &quot;Started&quot; is checked.\r\n\r\n```\r\ntype jenkins.json | jq -r &quot;.value.message&quot; | find &quot;Selenium Grid ready.&quot;\r\n```\r\n\r\nAfter this the errorlevel will be 1 when the text &quot;Selenium Grid ready.&quot; is not found, and 0 when it is found.\r\n\r\n",
                "title": "Windows batch command to get the Jenkins Selenium Grid status"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1650710977,
        "creation_date": 1650707448,
        "question_id": 71978606,
        "body_markdown": "I want to execute the tests in Selenium Grid using Jenkins and before running the tests, I want to ensure that Selenium grid is up and ready by using the curl and jq command in Windows batch.\r\n\r\nI tried running the below command:\r\n\r\n    curl http://localhost:4444/wd/hub/status\r\n\r\nBelow is the sample of the entire output:\r\n\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;ready&quot;: true,\r\n        &quot;message&quot;: &quot;Selenium Grid ready.&quot;,\r\n        &quot;nodes&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;5150c3b9-9bc2-45ad-9605-21c1c4ed90e4&quot;,\r\n            &quot;uri&quot;: &quot;http:\\u002f\\u002f172.27.0.3:5555&quot;,\r\n            &quot;maxSessions&quot;: 4,\r\n            &quot;osInfo&quot;: {\r\n              &quot;arch&quot;: &quot;amd64&quot;,\r\n              &quot;name&quot;: &quot;Linux&quot;,\r\n              &quot;version&quot;: &quot;5.10.16.3-microsoft-standard-WSL2&quot;\r\n            },\r\n            &quot;heartbeatPeriod&quot;: 60000,\r\n            &quot;availability&quot;: &quot;UP&quot;,\r\n            &quot;version&quot;: &quot;4.1.3 (revision 7b1ebf28ef)&quot;,\r\n\r\nNow I want to get the value of the ready and the message object from the above response and loop it until the value of ready is true.\r\n\r\nCan anyone please help here ?",
        "link": "https://stackoverflow.com/questions/71978606/windows-batch-command-to-get-the-jenkins-selenium-grid-status",
        "title": "Windows batch command to get the Jenkins Selenium Grid status"
    },
    {
        "tags": [
            "bash",
            "jq",
            "aws-cli"
        ],
        "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": 2,
                "creation_date": 1650816654,
                "post_id": 71990152,
                "comment_id": 127206614,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1650842103,
                "creation_date": 1650842103,
                "answer_id": 71993092,
                "question_id": 71990152,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. Use the -c option.\r\n2. Use a query of the form `select(any(Tags[]; CONDITION))`\r\ne.g.  select(any(Tags[]; .Key == &quot;Name&quot;))\r\n3. You can abbreviate expressions of the form {foo: .foo} to just {foo}\r\n\r\nSo, depending on your exact requirements, your invocation of jq could look like:\r\n```\r\njq -c &#39;.Volumes[] | {State, VolumeId, Tags} | select(any(.Tags[]; .Key == &quot;Name&quot;))&#39;\r\n```\r\n",
                "title": "How I can edit my response to 1 row + add condition to jq function"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1650842103,
        "creation_date": 1650816480,
        "question_id": 71990152,
        "body_markdown": "Hey I am using the next command \r\n\r\n    aws ec2 describe-volumes  --filters Name=status,Values=available | jq &#39;.Volumes[] | { State: .State, VolumeId: .VolumeId, Tags: .Tags}&#39;\r\n\r\n\r\n\r\nI get the next response:\r\n\r\n    {\r\n     &quot;State&quot;: &quot;available&quot;,\r\n    &quot;VolumeId&quot;: &quot;vol-03449dadd29f2067f&quot;,\r\n    &quot;Tags&quot;: [\r\n    {\r\n      &quot;Key&quot;: &quot;sre&quot;,\r\n      &quot;Value&quot;: &quot;test&quot;\r\n    }\r\n    ]}\r\n\r\n1.I want my response will be in 1 row regarding each volume.\r\n2. I want to check if the volume has the tag &quot;Name&quot; if so I want the value, otherwise the tags are not interest me. How can I manipulate it ?",
        "link": "https://stackoverflow.com/questions/71990152/how-i-can-edit-my-response-to-1-row-add-condition-to-jq-function",
        "title": "How I can edit my response to 1 row + add condition to jq function"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "microsoft-teams"
        ],
        "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": 1650816850,
                "post_id": 71990182,
                "comment_id": 127206663,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15639969,
                    "reputation": 980,
                    "user_id": 11283638,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/tXCrp.jpg?s=256",
                    "display_name": "Ashutosh Patole",
                    "link": "https://stackoverflow.com/users/11283638/ashutosh-patole"
                },
                "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": 1650817216,
                "post_id": 71990182,
                "comment_id": 127206752,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1650818254,
                "last_edit_date": 1650818254,
                "creation_date": 1650817952,
                "answer_id": 71990346,
                "question_id": 71990182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First issue: If you have an empty array, then set a value at index `2` (as with `.body[2].inlines[2]`), the previous ones (namely index `0` and `1`) will be set to `null`.\r\n\r\nSecond issue: You always modify the same item (namely `.body[2].inlines[2]`). `+=` in this case will append the new object to the existing one, but as it&#39;s using the same keys, they will be overwritten.\r\n\r\nSolution: Use `+=` on the array, and wrap the new item in brackets (making it another array of one item). This way you can successively populate the existing array.\r\n~~~\r\n.body[2].inlines += [{&quot;type&quot;: &quot;TextRun&quot;,&quot;text&quot;: &quot;Error: Failed Event in Activity Log $c&quot;}]\r\n~~~\r\n[Demo](https://jqplay.org/s/opWpad0fRD)\r\n\r\nYou also may want to put your operations into just one `jq` call. Either use the pipe `|` to concatenate the single operations, or, especially in this case, add all items at once as you are adding arrays anyways.\r\n~~~sh\r\ncluster=&quot;live&quot;\r\njq --arg c &quot;$cluster&quot; &#39;\r\n  .body[2].inlines += [{&quot;type&quot;: &quot;TextRun&quot;,&quot;text&quot;: &quot;Error: Failed Event in Activity Log $c&quot;}]\r\n  | .body[2].inlines += [{&quot;type&quot;: &quot;TextRun&quot;,&quot;text&quot;: &quot;VMs are in running state&quot;}]\r\n  | .body[2].inlines += [{&quot;type&quot;: &quot;TextRun&quot;,&quot;text&quot;: &quot;VMs are  NOT in running state&quot;}]\r\n  | .body[2].inlines += [{&quot;type&quot;: &quot;TextRun&quot;,&quot;text&quot;: &quot;VMs are OFCOURSE in running state&quot;}]\r\n&#39; data.json\r\n~~~\r\n[Demo](https://jqplay.org/s/re1KbXo_nC)\r\n\r\n~~~sh\r\ncluster=&quot;live&quot;\r\njq --arg c &quot;$cluster&quot; &#39;\r\n  .body[2].inlines += [\r\n    {&quot;type&quot;: &quot;TextRun&quot;,&quot;text&quot;: &quot;Error: Failed Event in Activity Log $c&quot;},\r\n    {&quot;type&quot;: &quot;TextRun&quot;,&quot;text&quot;: &quot;VMs are in running state&quot;},\r\n    {&quot;type&quot;: &quot;TextRun&quot;,&quot;text&quot;: &quot;VMs are  NOT in running state&quot;},\r\n    {&quot;type&quot;: &quot;TextRun&quot;,&quot;text&quot;: &quot;VMs are OFCOURSE in running state&quot;}\r\n  ]\r\n&#39; data.json\r\n~~~\r\n[Demo](https://jqplay.org/s/RIHuu1U2dX)\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;type&quot;: &quot;AdaptiveCard&quot;,\r\n  &quot;body&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;TextBlock&quot;,\r\n      &quot;text&quot;: &quot;Monitoring&quot;,\r\n      &quot;wrap&quot;: true,\r\n      &quot;weight&quot;: &quot;bolder&quot;,\r\n      &quot;size&quot;: &quot;large&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;TextBlock&quot;,\r\n      &quot;text&quot;: &quot;23-04-2022 20:00&quot;,\r\n      &quot;wrap&quot;: true,\r\n      &quot;size&quot;: &quot;Small&quot;,\r\n      &quot;isSubtle&quot;: true\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;RichTextBlock&quot;,\r\n      &quot;inlines&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;TextRun&quot;,\r\n          &quot;text&quot;: &quot;Error: Failed Event in Activity Log $c&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;TextRun&quot;,\r\n          &quot;text&quot;: &quot;VMs are in running state&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;TextRun&quot;,\r\n          &quot;text&quot;: &quot;VMs are  NOT in running state&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;TextRun&quot;,\r\n          &quot;text&quot;: &quot;VMs are OFCOURSE in running state&quot;\r\n        }\r\n      ]\r\n    }\r\n  ],\r\n  &quot;&quot;: &quot;http://adaptivecards.io/schemas/adaptive-card.json&quot;,\r\n  &quot;version&quot;: &quot;1.5&quot;\r\n}\r\n~~~\r\n",
                "title": "Getting null values in jq bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1651397700,
        "creation_date": 1650816684,
        "last_edit_date": 1651397700,
        "question_id": 71990182,
        "body_markdown": "I have data.json which looks like this\r\n\r\n```json\r\n{\r\n  &quot;type&quot;: &quot;AdaptiveCard&quot;,\r\n  &quot;body&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;TextBlock&quot;,\r\n      &quot;text&quot;: &quot;Monitoring&quot;,\r\n      &quot;wrap&quot;: true,\r\n      &quot;weight&quot;: &quot;bolder&quot;,\r\n      &quot;size&quot;: &quot;large&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;TextBlock&quot;,\r\n      &quot;text&quot;: &quot;23-04-2022 20:00&quot;,\r\n      &quot;wrap&quot;: true,\r\n      &quot;size&quot;: &quot;Small&quot;,\r\n      &quot;isSubtle&quot;: true\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;RichTextBlock&quot;,\r\n      &quot;inlines&quot;: [\r\n      ]\r\n    }\r\n  ],\r\n  &quot;&quot;: &quot;http://adaptivecards.io/schemas/adaptive-card.json&quot;,\r\n  &quot;version&quot;: &quot;1.5&quot;\r\n}\r\n```\r\nAnd I&#39;m trying to add values dynamically to the inlines array\r\n\r\nsample script\r\n```bash\r\n#!/bin/bash\r\n\r\ncluster=&quot;live&quot;\r\n\r\necho &quot;$(jq --arg c &quot;$cluster&quot; &#39;.body[2].inlines[2] += {&quot;type&quot;: &quot;TextRun&quot;,&quot;text&quot;: &quot;Error: Failed Event in Activity Log $c&quot; }&#39; data.json)&quot; &gt; data.json\r\necho &quot;$(jq &#39;.body[2].inlines[2] += {&quot;type&quot;: &quot;TextRun&quot;,&quot;text&quot;: &quot;VMs are in running state&quot; }&#39; data.json)&quot;  &gt; data.json\r\necho &quot;$(jq &#39;.body[2].inlines[2] += {&quot;type&quot;: &quot;TextRun&quot;,&quot;text&quot;: &quot;VMs are  NOT in running state&quot; }&#39; data.json)&quot; &gt; data.json\r\necho &quot;$(jq &#39;.body[2].inlines[2] += {&quot;type&quot;: &quot;TextRun&quot;,&quot;text&quot;: &quot;VMs are OFCOURSE in running state&quot; }&#39; data.json)&quot; &gt; data.json\r\n```\r\n\r\nI have got 2 problems.\r\n\r\nfirst: I have tried finding solution to use dynamic values in the array but it doesn&#39;t expands it.\r\n\r\nsecond: Only the last value is inserted, the previous value somehow becomes null\r\n\r\n```\r\n{\r\n  &quot;type&quot;: &quot;AdaptiveCard&quot;,\r\n  &quot;body&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;TextBlock&quot;,\r\n      &quot;text&quot;: &quot;OU Monitoring&quot;,\r\n      &quot;wrap&quot;: true,\r\n      &quot;weight&quot;: &quot;bolder&quot;,\r\n      &quot;size&quot;: &quot;large&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;TextBlock&quot;,\r\n      &quot;text&quot;: &quot;23-04-2022 20:00&quot;,\r\n      &quot;wrap&quot;: true,\r\n      &quot;size&quot;: &quot;Small&quot;,\r\n      &quot;isSubtle&quot;: true\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;RichTextBlock&quot;,\r\n      &quot;inlines&quot;: [\r\n        null,                                 &lt;== \r\n        null,                                 &lt;==\r\n        { \r\n          &quot;type&quot;: &quot;TextRun&quot;,\r\n          &quot;text&quot;: &quot;VMs are OFCOURSE in running state&quot;\r\n        }\r\n      ]\r\n    }\r\n  ],\r\n  &quot;&quot;: &quot;http://adaptivecards.io/schemas/adaptive-card.json&quot;,\r\n  &quot;version&quot;: &quot;1.5&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/71990182/getting-null-values-in-jq-bash",
        "title": "Getting null values in jq bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1650867215,
                "creation_date": 1650867215,
                "answer_id": 71995151,
                "question_id": 71993824,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Blindly using .name as the basis of the filename might not be a great idea,\r\nso please adapt the following to your needs.\r\n\r\nAssuming the input has the form as in the previous question, i.e.\r\n\r\n`{ &quot;item1&quot;: { &quot;name&quot;: &quot;Bob Smith&quot;, ...}, ...}`\r\n\r\nyou could use the following pipeline:\r\n\r\n```\r\njq -cr &#39;.[] | &quot;\\(.name)\\t\\(.)&quot;&#39; input.json |\r\n  awk -F\\\\t &#39;{ print $2 &gt;&gt; &quot;/tmp/&quot; $1 &quot;.json&quot; }&#39; \r\n```",
                "title": "How to use data from a JQ key to name a new JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1650867215,
        "creation_date": 1650852449,
        "last_edit_date": 1650853908,
        "question_id": 71993824,
        "body_markdown": "I have been trying to modify the accepted code provided by @peak in this thread: https://stackoverflow.com/questions/28744361/split-a-json-file-into-separate-files. I&#39;m very grateful for this answer, as it saved me many hours.\r\n\r\nBoth of the solutions provided in that thread produce exactly the results I expect and want *within* the resulting split files. However, the output files are named &quot;$key.json&quot;. I would like the file name to be the data contained in the first field of the output file.\r\n\r\nEach output file looks something like this:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Bob Smith&quot;,\r\n      &quot;description&quot;: &quot;(some descriptive text)&quot;,\r\n      &quot;image&quot;: &quot;(link to an image file)&quot;,\r\n      ...\r\n    }\r\n\r\nI have spent several hours trying to figure out how to get the output file names to be &quot;Bob Smith.json&quot;, &quot;Jane Doe.json&quot; etc., instead of &quot;0.json&quot;, &quot;1.json&quot;, etc. I have tried many different ways of modifying the output parameters `printf &quot;%s\\n&quot; &quot;$item&quot; &gt; &quot;/tmp/$key.json&quot;` and `&#39;{ print $2 &gt; &quot;/tmp/&quot; $1 &quot;.json&quot; }&#39;` without any success. I am completely new to JQ, so I suspect that the solution may be very simple. But, without spending many more hours learning JQ, I don&#39;t think I will be able to find it on my own.\r\n\r\nFor your convenience, here are the solutions from the previous thread:\r\n\r\n       jq -cr &#39;keys[] as $k | &quot;\\($k)\\n\\(.[$k])&quot;&#39; input.json |\r\n      while read -r key ; do\r\n        read -r item\r\n        printf &quot;%s\\n&quot; &quot;$item&quot; &gt; &quot;/tmp/$key.json&quot;\r\n      done\r\n\r\nand\r\n\r\n    jq -cr &#39;keys[] as $k | &quot;\\($k)\\t\\(.[$k])&quot;&#39; input.json |\r\n      awk -F\\\\t &#39;{ print $2 &gt; &quot;/tmp/&quot; $1 &quot;.json&quot; }&#39;\r\n\r\nCan someone who is proficient in JQ please give me a hint? Thank you.",
        "link": "https://stackoverflow.com/questions/71993824/how-to-use-data-from-a-jq-key-to-name-a-new-json-file",
        "title": "How to use data from a JQ key to name a new JSON file"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650891212,
                "post_id": 71999637,
                "comment_id": 127223187,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13783684,
                    "reputation": 73,
                    "user_id": 9948191,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-LsX6TJz4zWo/AAAAAAAAAAI/AAAAAAAAAAA/AB6qoq1O9ZPq4DqcMTGRbVZJ6W3Y9RQrug/mo/s256-rj/photo.jpg",
                    "display_name": "Nitro Boy",
                    "link": "https://stackoverflow.com/users/9948191/nitro-boy"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650898816,
                "post_id": 71999637,
                "comment_id": 127226317,
                "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": 1650903959,
                "post_id": 71999637,
                "comment_id": 127228414,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1650891381,
                "creation_date": 1650891381,
                "answer_id": 71999903,
                "question_id": 71999637,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Simply add the root path with the `.Tags` and delete it afterwards. You could use a temporary variable as well i.e. `.Tags as $v | del(.Tags) | . + $v`\r\n\r\n```none\r\njq &#39;. + .Tags | del(.Tags)&#39;\r\n```",
                "title": "Merge nested dict to root jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1650903962,
                "creation_date": 1650903962,
                "answer_id": 72002749,
                "question_id": 71999637,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest solution would be\r\n~~~sh\r\njq &#39;del(.Tags) + .Tags&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;Id&quot;: &quot;i-0e27418e091ea97a7&quot;,\r\n  &quot;Name&quot;: &quot;php&quot;\r\n}\r\n{\r\n  &quot;Id&quot;: &quot;i-0b0a0cb6223701cb5&quot;,\r\n  &quot;Name&quot;: &quot;Main&quot;,\r\n  &quot;q&quot;: &quot;ngix&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/PfGihF44GT)\r\n\r\nThe major difference to other solutions like `. + .Tags | del(.Tags)` is that this deletes from the unaltered source, not the populated result, which does affect content in `.Tags.Tags`, if present. Example:\r\n~~~json\r\n{\r\n  &quot;Id&quot;: &quot;123&quot;,\r\n  &quot;Tags&quot;: {\r\n    &quot;Name&quot;: &quot;What about nested Tags?&quot;,\r\n    &quot;Tags&quot;: &quot;Should they be deleted?&quot;\r\n  }\r\n}\r\n~~~\r\n~~~sh\r\njq &#39;(          . + .Tags | del(.Tags) ),\r\n    ( del(.Tags) + .Tags              )&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;Id&quot;: &quot;123&quot;,\r\n  &quot;Name&quot;: &quot;What about nested Tags?&quot;\r\n}\r\n{\r\n  &quot;Id&quot;: &quot;123&quot;,\r\n  &quot;Name&quot;: &quot;What about nested Tags?&quot;,\r\n  &quot;Tags&quot;: &quot;Should they be deleted?&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/Nb0NE1h7aN)",
                "title": "Merge nested dict to root jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1650903962,
        "creation_date": 1650890161,
        "question_id": 71999637,
        "body_markdown": "I am trying to create something like table with instance ID and theirs tags and another details, and that step where i got stuck it&#39;s move EC2 tags that placed in nested Array as Dict objects. Here is already transormed &quot;Tags&quot; dict, just need to put it together with another data.\r\n\r\n\r\n    {\r\n      &quot;Id&quot;: &quot;i-0e27418e091ea97a7&quot;,\r\n      &quot;Name&quot;: &quot;php&quot;\r\n    }\r\n    {\r\n      &quot;Id&quot;: &quot;i-0b0a0cb6223701cb5&quot;,\r\n      &quot;Name&quot;: &quot;Logics-SF-Migration&quot;,\r\n      &quot;q&quot;: &quot;ngix&quot;\r\n    }\r\n\r\nAbove desired result, down is source json.\r\n\r\n    {\r\n      &quot;Id&quot;: &quot;i-0e27418e091ea97a7&quot;,\r\n      &quot;Tags&quot;: {\r\n        &quot;Name&quot;: &quot;php&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;Id&quot;: &quot;i-0b0a0cb6223701cb5&quot;,\r\n      &quot;Tags&quot;: {\r\n        &quot;Name&quot;: &quot;Main,\r\n        &quot;q&quot;: &quot;ngix&quot;\r\n      }\r\n    }",
        "link": "https://stackoverflow.com/questions/71999637/merge-nested-dict-to-root-jq",
        "title": "Merge nested dict to root jq"
    },
    {
        "tags": [
            "json",
            "azure-devops",
            "terraform",
            "azure-pipelines",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 105668,
                    "reputation": 75987,
                    "user_id": 281848,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/w7nJW.jpg?s=256",
                    "display_name": "Martin Atkins",
                    "link": "https://stackoverflow.com/users/281848/martin-atkins"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1650906689,
                "post_id": 72002210,
                "comment_id": 127229398,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13460317,
                    "reputation": 89,
                    "user_id": 9712595,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1ea0325823c5f73e6e29d8e759b9aed2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Vetements",
                    "link": "https://stackoverflow.com/users/9712595/vetements"
                },
                "reply_to_user": {
                    "account_id": 105668,
                    "reputation": 75987,
                    "user_id": 281848,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/w7nJW.jpg?s=256",
                    "display_name": "Martin Atkins",
                    "link": "https://stackoverflow.com/users/281848/martin-atkins"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650907495,
                "post_id": 72002210,
                "comment_id": 127229684,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1650981494,
                "creation_date": 1650981494,
                "answer_id": 72015271,
                "question_id": 72002210,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Under the output format, there is a list called `resource_changes`. Each change has an `address` field. To meet your requirement, each address should start with `module`. This makes the developer responsible only for the modules that they are changing with this terraform plan.\r\n\r\nAssuming you already have output.json in place, you could do it like this:\r\n\r\n    LIST=$(cat output.json| jq -r &quot;.resource_changes[].address&quot;)\r\n\r\n    for ADDRESS in $LIST\r\n    do\r\n        if [[ $ADDRESS != &quot;module.&quot;* ]]; then\r\n            echo &quot;$ADDRESS is outside of a module&quot;\r\n            exit 1\r\n        fi\r\n    done\r\n\r\n",
                "title": "Parsing terraform plan output to check for module vs resource block usage"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1650981494,
        "creation_date": 1650901416,
        "question_id": 72002210,
        "body_markdown": "I wanted to add a check to an existing terraform build and deployment pipeline to check that the configuration being written by devs is properly formatted and in line with company syntax\r\n\r\n**Specifically I want to check to make sure they are not using plain resource blocks in thier config as opposed to module blocks**\r\n\r\nFor example I want to I want to make sure they are using \r\n\r\n```\r\nModule “eks_dev_wus2_app_cluster”\r\n```\r\n\r\nAnd not\r\n\r\n```\r\nResource “aws_kubernetes_cluster” “eks_dev_wus2_App_cluster”\r\n```\r\n\r\nCurrent approach\r\n-----------------\r\n\r\nAs I understand it I would need to first convert to json to parse through it\r\n\r\n```\r\nterraform show -no-color -json output.tfplan &gt; output.json\r\n```\r\n\r\nThen I should use the jq tool to parse through the output per this article\r\nhttps://linuxconfig.org/how-to-parse-a-json-file-from-linux-command-line-using-jq\r\n\r\nA little fuzzy on how I would go about specifically checking the blocks in the terraform config to confirm whether or not they are resource or module.\r\n\r\nCan anyone point me in the right direction?\r\n\r\nIs there a better way to get output values? Don’t need an entire solution, just looking to clarify some of the fogginess of approaching this problem ",
        "link": "https://stackoverflow.com/questions/72002210/parsing-terraform-plan-output-to-check-for-module-vs-resource-block-usage",
        "title": "Parsing terraform plan output to check for module vs resource block usage"
    },
    {
        "tags": [
            "bash",
            "jq",
            "associative-array"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1650905589,
                "last_edit_date": 1650905589,
                "creation_date": 1650903195,
                "answer_id": 72002599,
                "question_id": 72002421,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re trying to access a shell var from jq.\r\n\r\nFixed:\r\n\r\n```sh\r\nssm_map=&#39;\r\n   {\r\n      &quot;some_great_key&quot;: &quot;theGreatKEYAlias&quot;,\r\n      &quot;api_magic&quot;:      &quot;apiKey&quot;\r\n   }\r\n&#39;\r\n\r\njq -r --argjson ssm_map &quot;$ssm_map&quot; &#39;\r\n   .Parameters[] |\r\n   &quot;ssm_\\( $ssm_map[ .Name ] ): \\&quot;\\( .Value )\\&quot;&quot;\r\n&#39;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/TAZv5Bswm6) on jqplay\r\n\r\nYou could convert the variable you describe into JSON with varying levels of difficulty (depending on what limitations, if any, you&#39;re willing to accept). But since you&#39;re building the variable from the output of `yq`, should could simply have it output JSON directly.",
                "title": "How to use(read) value from associative array during jq map?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1650914079,
                "creation_date": 1650914079,
                "answer_id": 72004624,
                "question_id": 72002421,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using [mikefarah/yq](https://github.com/mikefarah/yq) or [kislyuk/yq](https://github.com/kislyuk/yq) or [itchyny/gojq](https://github.com/itchyny/gojq) is definitely the better approach if your actual task is to convert from YAML and to process as JSON.\r\n\r\nHowever, to accomplish the task you have described in the original question, one could add the keys and values of the bash associative array using the `--args` option and access them within `jq` via the `$ARGS.positional` array (requires `jq` version 1.6), then restore the association by `transpose`ing both halves of that array, and create an `INDEX` using the key from the first half, which can then be used with `JOIN` to create the desired text lines, which are output as raw text using the `-r` option.\r\n~~~sh\r\njq -r &#39;\r\n  JOIN(\r\n    $ARGS.positional | [.[:length/2], .[length/2:]] | transpose | INDEX(.[0]);\r\n    .Parameters[];\r\n    .Name;\r\n    &quot;ssm_\\(.[1][1] // .[0].Name): \\(.[0].Value)&quot;\r\n  )\r\n&#39; example.json --args &quot;${!ssmMap[@]}&quot; &quot;${ssmMap[@]}&quot;\r\n~~~\r\n~~~none\r\nssm_theGreatKEYAlias: magicvaluenotrelevant\r\nssm_apiKey: blabla\r\n~~~\r\nThe fallback `// .[0].Name` is unnecessary for the sample file, but was added to use the original key in case there&#39;s an input key not covered by the bash array.",
                "title": "How to use(read) value from associative array during jq map?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1650914079,
        "creation_date": 1650902473,
        "last_edit_date": 1650903764,
        "question_id": 72002421,
        "body_markdown": "I am reading aws ssm parameters via jq with json, and want to put them into a `yaml` file after some processing and alias mapping.\r\n\r\n\r\nI have one associative array of mapping parameter name to some internal name (see process.sh)\r\n\r\nMy simplified example.json is\r\n\r\n```\r\n{\r\n  &quot;Parameters&quot;: [\r\n    {\r\n      &quot;Name&quot;: &quot;/dev/applications/web/some_great_key&quot;,\r\n      &quot;Value&quot;: &quot;magicvaluenotrelevant&quot;\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;/dev/applications/web/api_magic&quot;,\r\n      &quot;Value&quot;: &quot;blabla&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nMy bash script `process.sh` is\r\n```\r\n#!/usr/bin/env bash\r\n\r\ndeclare -A ssmMap\r\nssmMap[/dev/applications/web/some_great_key]=theGreatKEYAlias\r\nssmMap[/dev/applications/web/api_magic]=apiKey\r\n\r\njq -r &#39;\r\n  .Parameters\r\n  | map({\r\n        Name: .Name,\r\n        parameterValue: .Value\r\n    })\r\n  | map((${!ssmMap[.Name]} + &quot;: \\&quot;&quot; + .parameterValue + &quot;\\&quot;&quot;))\r\n  | join(&quot;\\n&quot;)\r\n&#39; &lt; example.json;\r\n\r\n```\r\n\r\nI want/expected the output to be:\r\n```\r\nssm_theGreatKEYAlias: &quot;magicvaluenotrelevant&quot;\r\nssm_apiKey: &quot;singleblabla&quot;\r\n```\r\n\r\nWith the process.sh script that I provided I get error because cannot find a way to use the associative array `sshMap` inside jq map, to transform the parameter name from json into the mapped alias from sshMap.\r\n\r\nAny idea how that can be achieved ?\r\n\r\nIf I change the line 13 of `process.sh` into \r\n```\r\n  | map((.Name + &quot;: \\&quot;&quot; + .parameterValue + &quot;\\&quot;&quot;))\r\n```\r\n\r\n it works fine but without mapping, uses original parameter name as comes from json file.",
        "link": "https://stackoverflow.com/questions/72002421/how-to-useread-value-from-associative-array-during-jq-map",
        "title": "How to use(read) value from associative array during jq map?"
    },
    {
        "tags": [
            "python",
            "json",
            "pyspark",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4094210,
                    "reputation": 7258,
                    "user_id": 3361462,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ed5fe4ce9c6baef0f49fce12f6448fc9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kosciej16",
                    "link": "https://stackoverflow.com/users/3361462/kosciej16"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650909654,
                "post_id": 72003765,
                "comment_id": 127230351,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6883697,
                    "reputation": 1406,
                    "user_id": 5289570,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/tYhmf.jpg?s=256",
                    "display_name": "Wassadamo",
                    "link": "https://stackoverflow.com/users/5289570/wassadamo"
                },
                "reply_to_user": {
                    "account_id": 4094210,
                    "reputation": 7258,
                    "user_id": 3361462,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ed5fe4ce9c6baef0f49fce12f6448fc9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kosciej16",
                    "link": "https://stackoverflow.com/users/3361462/kosciej16"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650915204,
                "post_id": 72003765,
                "comment_id": 127232000,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1650909967,
                "creation_date": 1650909967,
                "answer_id": 72003878,
                "question_id": 72003765,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `jq`, read in the whole file as raw text using the `-R` option, receive it as one long string using the `-s` option, wrap that string in brackets and use `fromjson` to decode it from JSON. You should now have a valid array.\r\n~~~sh\r\njq -Rs &#39;&quot;[\\(.)]&quot; | fromjson&#39; myfile.json\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;01&quot;,\r\n    &quot;Variables&quot;: [\r\n      {\r\n        &quot;Name&quot;: &quot;myvar&quot;,\r\n        &quot;Value&quot;: &quot;15&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;01&quot;,\r\n    &quot;Variables&quot;: [\r\n      {\r\n        &quot;Name&quot;: &quot;myvar&quot;,\r\n        &quot;Value&quot;: &quot;15&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/5UZll8AOja)\r\n\r\nUse `.[]` to have individual items (without commas in between):\r\n~~~sh\r\njq -Rs &#39;&quot;[\\(.)]&quot; | fromjson[]&#39; myfile.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;id&quot;: &quot;01&quot;,\r\n  &quot;Variables&quot;: [\r\n    {\r\n      &quot;Name&quot;: &quot;myvar&quot;,\r\n      &quot;Value&quot;: &quot;15&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;id&quot;: &quot;01&quot;,\r\n  &quot;Variables&quot;: [\r\n    {\r\n      &quot;Name&quot;: &quot;myvar&quot;,\r\n      &quot;Value&quot;: &quot;15&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/ZEgaItRpzu)\r\n",
                "title": "Process multi-line json with trailing commas"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1650915076,
        "creation_date": 1650909377,
        "last_edit_date": 1650915076,
        "question_id": 72003765,
        "body_markdown": "I have JSON in files with text contents like:\r\n\r\n```\r\n{\r\n    &quot;id&quot;: &quot;01&quot;,\r\n    &quot;Variables&quot;: [\r\n        {\r\n            &quot;Name&quot;: &quot;myvar&quot;,\r\n            &quot;Value&quot;: &quot;15&quot;\r\n        }\r\n    ]\r\n},\r\n{\r\n    &quot;id&quot;: &quot;01&quot;,\r\n    &quot;Variables&quot;: [\r\n        {\r\n            &quot;Name&quot;: &quot;myvar&quot;,\r\n            &quot;Value&quot;: &quot;15&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\nNote this example has 2 records, each split over multiple lines with a comma between each.\r\n\r\nThis comma-delimiter between records makes it difficult to process e.g. with jq:\r\n\r\n```\r\n$ cat myfile.json | jq -s\r\n```\r\nparse error: Expected value before &#39;,&#39; at line 9...\r\n\r\nOr with python:\r\n\r\n```\r\nimport json\r\nwith open(&quot;alert_feedback_20220424.json&quot;, &quot;r&quot;) as f:\r\n    j = json.load(f)\r\n```\r\njson.decoder.JSONDecodeError: Extra data: line 9...\r\n\r\nUltimately I actually want to read this data with spark:\r\n\r\n```\r\nspark.read.option(\r\n    &#39;sep&#39;, &#39;,&#39;\r\n).option(\r\n    &#39;header&#39;, False\r\n).option(\r\n    &#39;multiLine&#39;, True\r\n).csv(\r\n    &#39;file://my/project/data/myfile.json&#39;\r\n)\r\n```\r\nBut this doesn&#39;t seem to have parsed the json correctly. I&#39;ll add details when I have time on request.\r\n\r\nLinks to solutions tried:\r\n\r\n - https://stackoverflow.com/questions/64457685/parse-error-expected-value-before-at-line-71-column-2\r\n - https://stackoverflow.com/questions/63398199/python-change-multi-line-json-string-to-single-line\r\n - https://stackoverflow.com/questions/53201028/remove-trailing-json-comma-with-command-line-tools\r\n\r\n\r\nHow can I programmatically remove this comma after each JSON record, or otherwise format this json to be parsed correctly?\r\n",
        "link": "https://stackoverflow.com/questions/72003765/process-multi-line-json-with-trailing-commas",
        "title": "Process multi-line json with trailing commas"
    },
    {
        "tags": [
            "bash",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8340816,
                    "reputation": 1,
                    "user_id": 6266192,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/94cb40bd8ab263ab93628c8823a54ded?s=256&d=identicon&r=PG",
                    "display_name": "Dudi Boy",
                    "link": "https://stackoverflow.com/users/6266192/dudi-boy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650917871,
                "post_id": 72005130,
                "comment_id": 127232714,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3188632,
                    "reputation": 565,
                    "user_id": 2693541,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://i.sstatic.net/1SjZt.jpg?s=256",
                    "display_name": "Pawan",
                    "link": "https://stackoverflow.com/users/2693541/pawan"
                },
                "reply_to_user": {
                    "account_id": 8340816,
                    "reputation": 1,
                    "user_id": 6266192,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/94cb40bd8ab263ab93628c8823a54ded?s=256&d=identicon&r=PG",
                    "display_name": "Dudi Boy",
                    "link": "https://stackoverflow.com/users/6266192/dudi-boy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650918059,
                "post_id": 72005130,
                "comment_id": 127232764,
                "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": 1,
                "creation_date": 1650919581,
                "post_id": 72005130,
                "comment_id": 127233199,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3188632,
                    "reputation": 565,
                    "user_id": 2693541,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://i.sstatic.net/1SjZt.jpg?s=256",
                    "display_name": "Pawan",
                    "link": "https://stackoverflow.com/users/2693541/pawan"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1650919987,
                "post_id": 72005130,
                "comment_id": 127233306,
                "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": 0,
                "creation_date": 1650920274,
                "post_id": 72005130,
                "comment_id": 127233383,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3188632,
                    "reputation": 565,
                    "user_id": 2693541,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://i.sstatic.net/1SjZt.jpg?s=256",
                    "display_name": "Pawan",
                    "link": "https://stackoverflow.com/users/2693541/pawan"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1650920691,
                "post_id": 72005130,
                "comment_id": 127233506,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3188632,
                    "reputation": 565,
                    "user_id": 2693541,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://i.sstatic.net/1SjZt.jpg?s=256",
                    "display_name": "Pawan",
                    "link": "https://stackoverflow.com/users/2693541/pawan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650922392,
                "post_id": 72005130,
                "comment_id": 127233903,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3188632,
                    "reputation": 565,
                    "user_id": 2693541,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://i.sstatic.net/1SjZt.jpg?s=256",
                    "display_name": "Pawan",
                    "link": "https://stackoverflow.com/users/2693541/pawan"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1650922455,
                "post_id": 72005130,
                "comment_id": 127233916,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1652180768,
                "last_edit_date": 1652180768,
                "creation_date": 1650923578,
                "answer_id": 72006095,
                "question_id": 72005130,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "##### Given the input files and desired output:\r\n\r\n* line.csv\r\n```csv\r\n22,Test1\r\n3389,Test2\r\n10,Test3\r\n```\r\n* linescan.json\r\n```json\r\n{\r\n  &quot;scan&quot;: {\r\n    &quot;line&quot;: 3389,\r\n    &quot;service&quot;: &quot;Linetest&quot;,\r\n    &quot;comment_1&quot;: &quot;Line is tested1&quot;,\r\n    &quot;comment_2&quot;: &quot;Line is tested2&quot;,\r\n    &quot;comment_3&quot;: &quot;Line is tested3&quot;\r\n  }\r\n}\r\n```\r\n* desired output:\r\n```txt\r\nTest2 | 3389 | Linetest | Line is tested1 | Line is tested2 | Line is tested3\r\n```\r\n\r\n---\r\n\r\n##### Here&#39;s a solution with `jq`:\r\n\r\nThis is a shot in the dark, as you didn&#39;t specify what your output should look like:\r\n\r\n```sh\r\njq -sr --rawfile lineArr line.csv &#39;\r\n    (\r\n        $lineArr | split(&quot;\\n&quot;) | del(.[-1]) | .[] | split(&quot;,&quot;)\r\n    ) as [$lineNum,$prefix] |\r\n    .[] | select(.scan.line == ($lineNum | tonumber)) |\r\n    [\r\n        $prefix,\r\n        .scan.line,\r\n        .scan.service,\r\n        .scan.comment_1,\r\n        .scan.comment_2,\r\n        .scan.comment_3\r\n    ] |\r\n    join(&quot; | &quot;)\r\n&#39; linescan.json\r\n```\r\n---\r\n\r\n##### Update: with jq 1.5:\r\n\r\n```\r\n#!/bin/bash\r\n\r\njq -sr --slurpfile lineArr &lt;(jq -R &#39;split(&quot;,&quot;)&#39; line.csv) &#39;\r\n    ($lineArr | .[]) as [$lineNum,$prefix] |\r\n    .[] | select(.scan.line == ($lineNum | tonumber)) |\r\n    [\r\n        $prefix,\r\n        (.scan.line | tostring),\r\n        .scan.service,\r\n        .scan.comment_1,\r\n        .scan.comment_2,\r\n        .scan.comment_3\r\n    ] |\r\n    join(&quot; | &quot;)\r\n&#39; linescan.json\r\n",
                "title": "How to read each cell of a column in csv and take each as input for jq in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1666626527,
        "creation_date": 1650916798,
        "last_edit_date": 1666626527,
        "question_id": 72005130,
        "body_markdown": "I am trying to read each cell of CSV and treat it as an input for the JQ command. Below is my code:\r\n\r\n**line.csv**\r\n\r\n    | Line |\r\n    |:---- |\r\n    | 11   |\r\n    | 22   |\r\n    | 33   |\r\n     \r\n\r\n**Code to read CSV:**\r\n\r\n    while read line\r\n    \r\n    do\r\n    \r\n       echo &quot;Line is : $line&quot;\r\n    \r\n    done &lt; line.csv\r\n\r\nOutput:\r\n\r\n    Line is 11\r\n    Line is 22\r\n\r\n**jq Command**\r\n\r\n    jq &#39;select(.scan.line == &#39;&quot;$1&quot;&#39;) | .scan.line,&quot;|&quot;, .scan.service,&quot;|&quot;, .scan.comment_1,&quot;|&quot;, .scan.comment_2,&quot;|&quot;, .scan.comment_3&#39; linescan.json | xargs\r\n\r\n\r\nI have a linescan.json which have values for line, service, comment_1, comment_2, comment_3\r\n\r\nI want to read each value of csv and treat the input in jq query where $1 is mentioned.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72005130/how-to-read-each-cell-of-a-column-in-csv-and-take-each-as-input-for-jq-in-bash",
        "title": "How to read each cell of a column in csv and take each as input for jq in bash"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1650926858,
                "last_edit_date": 1650926858,
                "creation_date": 1650925557,
                "answer_id": 72006338,
                "question_id": 72006256,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `jq`, `keys_unsorted[0]` will give you the first key, and `--arg` lets you import values from outside. Using `bash`, you could loop linewise using `while`.\r\n~~~sh\r\njq -r &#39;keys_unsorted[0]&#39; input.json | while read -r animalVariableHere\r\ndo curl &#39;https://urlHere&#39;&quot;${animalVariableHere}&quot; \\\r\n  | jq --arg id &quot;${animalVariableHere}&quot; -r &#39;@csv &quot;\\([$id]): \\(.info)&quot;&#39;\r\ndone &gt; output.txt\r\n~~~\r\nThis assumes, the `curl` output is valid JSON, i.e. it looks more like `{&quot;type&quot;:&quot;animal&quot;,&quot;info&quot;:[&quot;house pet&quot;,&quot;furry&quot;,&quot;brown&quot;]}`.\r\n",
                "title": "How to get first word from each line in file into a variable, curl it and append the output to a new file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1650926013,
                "creation_date": 1650926013,
                "answer_id": 72006386,
                "question_id": 72006256,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;ll need a tool that can parse JSON.\r\n\r\n###### example with `jq`\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\nwhile IFS=&#39;&#39; read -r animal\r\ndo\r\n    curl &quot;https://urlHere=$animal&quot; |\r\n    jq --arg a &quot;$animal&quot; &#39;$a + &quot;: &quot; + (.info | join(&quot;, &quot;))&#39;\r\ndone &lt; &lt;(jq -r &#39;keys[0]&#39; file.json) &gt; output.json\r\n```",
                "title": "How to get first word from each line in file into a variable, curl it and append the output to a new file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1650926858,
        "creation_date": 1650924869,
        "question_id": 72006256,
        "body_markdown": "I have a file which is formatted like this:\r\n\r\n    {&quot;cat&quot;:[&quot;bat&quot;,&quot;mat&quot;,&quot;hat&quot;]}\r\n    \r\n    {&quot;dog&quot;:[&quot;frog&quot;,&quot;clog&quot;]}\r\n    \r\n    {&quot;mouse&quot;:[&quot;house&quot;]}\r\n\r\n..and so on and so forth with many more (~50 more) lines like this.\r\n\r\nI want to get the first word in each line (e.g. cat) and then run a curl on a URL with that word (e.g. curl https://urlHere=&#39;&quot;${animalVariableHere}&quot;) so the first word is from each line should be put into the URL where is says &quot;${animalVariableHere}&quot;. Once curl is run on that URL, I then want to get that output (curling the URL gives a single line in JSON - e.g. {&quot;type&quot;:&quot;animal,&quot;info&quot;:{&quot;house pet&quot;,&quot;furry&quot;,&quot;brown&quot;}}), particularly just the &quot;info&quot; part, into a new file that similar to this:\r\n\r\n    &quot;cat&quot;: &quot;house pet&quot;,&quot;furry&quot;,&quot;brown&quot;\r\n\r\nso as a result, the final output using the 3 input lines above will be:\r\n\r\n    &quot;cat&quot;: &quot;house pet&quot;,&quot;furry&quot;,&quot;tabby&quot;\r\n    \r\n    &quot;dog&quot;: &quot;house pet&quot;,&quot;furry&quot;,&quot;golden retriever&quot;\r\n    \r\n    &quot;mouse&quot;: &quot;house pet&quot;,&quot;tail&quot;,&quot;pygmy&quot;\r\n\r\nSo far I&#39;ve tried to see whether I can use the &#39;awk&#39; command to get the first word within each line, but it hasn&#39;t worked at all/ I&#39;m not entirely sure how as I&#39;m just learning to shell script. But once with each word, I was just thinking of piping it, i.e:\r\n\r\n    &lt;first word&gt; | curl &#39;https://urlHere&#39;&quot;${animalVariableHere}&quot; | jq -r &#39;.info&#39; | tee -a outputFile\r\n\r\nI also wasn&#39;t sure how to match the animal variable to the output of info. Any help would be appreciated, thank you",
        "link": "https://stackoverflow.com/questions/72006256/how-to-get-first-word-from-each-line-in-file-into-a-variable-curl-it-and-append",
        "title": "How to get first word from each line in file into a variable, curl it and append the output to a new file"
    },
    {
        "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": 2,
                "creation_date": 1650936815,
                "post_id": 72007371,
                "comment_id": 127236282,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1774617,
                    "reputation": 7467,
                    "user_id": 1618630,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/0OfVn.jpg?s=256",
                    "display_name": "Mike Q",
                    "link": "https://stackoverflow.com/users/1618630/mike-q"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1650937529,
                "post_id": 72007371,
                "comment_id": 127236403,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1650936451,
        "creation_date": 1650936451,
        "question_id": 72007371,
        "body_markdown": "I&#39;m parsing below `JSON` using `jq` in my shell script, but I&#39;m getting `null` while parsing this field `config.subtype`. And I want to check if `config.subtype` value is `mobile`, I want to update the value as `1000` for this field `config.price` and print the complete JSON. What I&#39;m doing wrong here and how to update the existing JSON field value.\r\n\r\nAppreciated your help in advance! Thanks!\r\n\r\nPlease find my code below:\r\n\r\n**test.json**\r\n\r\n    {\r\n        &quot;name&quot;: &quot;myapp&quot;,\r\n        &quot;product&quot;: {\r\n            &quot;config.type&quot;: &quot;electronics&quot;,\r\n            &quot;config.count&quot;: &quot;5&quot;,\r\n            &quot;config.subtype&quot;: &quot;mobile&quot;,\r\n            &quot;config.price&quot;: &quot;&quot;\r\n        }\r\n    }\r\n\r\n**test.sh**\r\n\r\n    #!/bin/bash\r\n    #\r\n    \r\n        result=$(cat test.json| jq &#39;.product.config.type&#39;)\r\n        echo $result",
        "link": "https://stackoverflow.com/questions/72007371/getting-null-while-parsing-json-using-jq-in-shell-script",
        "title": "Getting null while parsing JSON using jq in shell script"
    },
    {
        "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": 1663853391,
                "post_id": 72013618,
                "comment_id": 130340712,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1650974889,
                "creation_date": 1650974889,
                "answer_id": 72013670,
                "question_id": 72013618,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can enclose it in `()` to use the pipe sign:\r\n```none\r\n.players[] | [.firstName, .lastName, .tid, .pid, (.ratings[] | .spd, .jmp)] | join(&quot;, &quot;)\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\n##### [Try it online](https://jqplay.org/s/y-e07l0cbb)",
                "title": "jq pipe operator in nested array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663854924,
                "creation_date": 1663854924,
                "answer_id": 73815925,
                "question_id": 72013618,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You didn&#39;t specify the expected output, so it is not clear if your proposed solution gives you the output you want.\r\n\r\nGiven the following input:\r\n\r\n```json\r\n{\r\n  &quot;players&quot;: [\r\n    {\r\n      &quot;firstName&quot;: &quot;fname1&quot;,\r\n      &quot;lastName&quot;: &quot;lname1&quot;,\r\n      &quot;tid&quot;: &quot;tid1&quot;,\r\n      &quot;pid&quot;: &quot;pid1&quot;,\r\n      &quot;ratings&quot;: [\r\n        {\r\n          &quot;spd&quot;: &quot;spd1-1&quot;,\r\n          &quot;jmp&quot;: &quot;jmp1-1&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;firstName&quot;: &quot;fname2&quot;,\r\n      &quot;lastName&quot;: &quot;lname2&quot;,\r\n      &quot;tid&quot;: &quot;tid2&quot;,\r\n      &quot;pid&quot;: &quot;pid2&quot;,\r\n      &quot;ratings&quot;: [\r\n        {\r\n          &quot;spd&quot;: &quot;spd2-1&quot;,\r\n          &quot;jmp&quot;: &quot;jmp2-1&quot;\r\n        },\r\n        {\r\n          &quot;spd&quot;: &quot;spd2-2&quot;,\r\n          &quot;jmp&quot;: &quot;jmp2-2&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;firstName&quot;: &quot;fname3&quot;,\r\n      &quot;lastName&quot;: &quot;lname3&quot;,\r\n      &quot;tid&quot;: &quot;tid3&quot;,\r\n      &quot;pid&quot;: &quot;pid3&quot;,\r\n      &quot;ratings&quot;: [\r\n        {\r\n          &quot;spd&quot;: &quot;spd3-1&quot;,\r\n          &quot;jmp&quot;: &quot;jmp3-2&quot;\r\n        },\r\n        {\r\n          &quot;spd&quot;: &quot;spd3-2&quot;,\r\n          &quot;jmp&quot;: &quot;jmp3-2&quot;\r\n        },\r\n        {\r\n          &quot;spd&quot;: &quot;spd3-3&quot;,\r\n          &quot;jmp&quot;: &quot;jmp3-3&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nYour solution and the [answer from 0ston0](https://stackoverflow.com/a/72013670/112968) will give you 1 line per player, but a different number of columns per line:\r\n\r\n```\r\n.players[] | [.firstName,.lastName,.tid,.pid,(.ratings[]|.spd,.jmp)] | join(&quot;, &quot;)\r\n```\r\n\r\ngenerates:\r\n\r\n```\r\nfname1, lname1, tid1, pid1, spd1-1, jmp1-1\r\nfname2, lname2, tid2, pid2, spd2-1, jmp2-1, spd2-2, jmp2-2\r\nfname3, lname3, tid3, pid3, spd3-1, jmp3-2, spd3-2, jmp3-2, spd3-3, jmp3-3\r\n```\r\n\r\nThis might or might not be what want your result to look like.\r\n\r\nA different solution will print one line per rating, but duplicate the players&#39; names. Running:\r\n\r\n```\r\n.players[] | [.firstName,.lastName,.tid,.pid] + (.ratings[]|[.spd,.jmp]) | join(&quot;, &quot;)\r\n```\r\n\r\nwill result in:\r\n\r\n```\r\nfname1, lname1, tid1, pid1, spd1-1, jmp1-1\r\nfname2, lname2, tid2, pid2, spd2-1, jmp2-1\r\nfname2, lname2, tid2, pid2, spd2-2, jmp2-2\r\nfname3, lname3, tid3, pid3, spd3-1, jmp3-2\r\nfname3, lname3, tid3, pid3, spd3-2, jmp3-2\r\nfname3, lname3, tid3, pid3, spd3-3, jmp3-3\r\n```\r\n\r\nBoth solutions are valid for different use cases and depending on how you are going to subsequently process the data.",
                "title": "jq pipe operator in nested array"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1663854924,
        "creation_date": 1650974633,
        "last_edit_date": 1650982539,
        "question_id": 72013618,
        "body_markdown": "Using code below to pull data from a local json file.  \r\n\r\nThe file is very large and is nested with objects and arrays.  There are multiple objects in the `.ratings[]` that I would like to extract.  \r\n\r\nHow can I use the pipe operator in the `.ratings[]` array so that I don&#39;t have to retype `.ratings[]` for each piece of data that I would like to pull? \r\n\r\n```none\r\njq -r &#39;.players[] | [.firstName,.lastName,.tid,.pid,.ratings[].spd,.ratings[].jmp] | join(&quot;, &quot;)&#39;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/72013618/jq-pipe-operator-in-nested-array",
        "title": "jq pipe operator in nested array"
    },
    {
        "tags": [
            "json",
            "parsing",
            "filter",
            "stream",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651085182,
                "last_edit_date": 1651085182,
                "creation_date": 1651026329,
                "answer_id": 72022583,
                "question_id": 72018324,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are several separate tasks involved here, and some are underspecified, but hopefully the following will help you through the thicket:\r\n```\r\njq -rn --stream &#39;\r\n  fromstream(1|truncate_stream(inputs))\r\n  | select( .languages == [&quot;de&quot;] ) \r\n  | [._id, .time, .body[0], .region[].percentage,\r\n     .reach.lower_bound, .reach.upper_bound, .languages[0]]\r\n  | @csv \r\n&#39;\r\n```\r\n",
                "title": "Using jq to stream, filter large json file and save output as csv"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1652564475,
        "creation_date": 1650995107,
        "last_edit_date": 1652564475,
        "question_id": 72018324,
        "body_markdown": "I have a very large json file I would like to stream (using `--stream`) and filter with jq, then save it as a csv.\r\n\r\nThis is the sample data with two objects:\r\n```\r\n[{&quot;_id&quot;:&quot;1&quot;,&quot;time&quot;:&quot;2021-07-22&quot;,&quot;body&quot;:[&quot;text1&quot;],&quot;region&quot;:[{&quot;percentage&quot;:&quot;0.1&quot;,&quot;region&quot;:&quot;region1&quot;},{&quot;percentage&quot;:&quot;0.9&quot;,&quot;region&quot;:&quot;region2&quot;}],&quot;reach&quot;:{&quot;lower_bound&quot;:&quot;100&quot;,&quot;upper_bound&quot;:&quot;200&quot;},&quot;languages&quot;:[&quot;de&quot;]},\r\n{&quot;_id&quot;:&quot;2&quot;,&quot;time&quot;:&quot;2021-07-23&quot;,&quot;body&quot;:[&quot;text2&quot;],&quot;region&quot;:[{&quot;percentage&quot;:&quot;0.3&quot;,&quot;region&quot;:&quot;region1&quot;},{&quot;percentage&quot;:&quot;0.7&quot;,&quot;region&quot;:&quot;region2&quot;}],&quot;reach&quot;:{&quot;lower_bound&quot;:&quot;10&quot;,&quot;upper_bound&quot;:&quot;20&quot;},&quot;languages&quot;:[&quot;en&quot;]}]\r\n```\r\n\r\nI want to filter on the `&quot;languages&quot;` field in jq stream so I only retain objects where `languages==[“de”]`, then save it as a new csv file titled `largefile.csv` such that the new csv file looks like the following:\r\n\r\n```\r\n_id,time,body,percentage_region1,percentage_region2,reach_lower_bound,reach_upper_bound,languages\r\n&quot;1&quot;,&quot;2021-07-22&quot;,&quot;text1&quot;,&quot;0.1&quot;,&quot;0.9&quot;,&quot;100&quot;,&quot;200&quot;,&quot;de&quot;\r\n```\r\n\r\nI have the following code so far but it doesn’t seem to work: \r\n```\r\ncat largefile.json -r | jq -cn --stream &#39;fromstream(1|truncate_stream(inputs | select(.))) | with_entries(select(.value.languages==[“de”])) | @csv\r\n```\r\n\r\nAny help would be much appreciated!\r\n",
        "link": "https://stackoverflow.com/questions/72018324/using-jq-to-stream-filter-large-json-file-and-save-output-as-csv",
        "title": "Using jq to stream, filter large json file and save output as csv"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651002295,
                "creation_date": 1651002295,
                "answer_id": 72019684,
                "question_id": 72019546,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When `jq` is fed with a stream, just like `[1,2] [3,4]` with two inputs, it executes the filter independently for each. That&#39;s why `jq &#39;[. | add]&#39;` will produce two results; each addition will separately be wrapped into an array.\r\n\r\nWhen `jq` is given the `--slurp` option, it combines the stream to an array, rendering it just one input. Therefore `jq -s &#39;[.[] | add]&#39;` will have one result only; the multiple additions will be caught by the array constructor, which is executed just once. ",
                "title": "jq: Why do two expressions which produce identical output produce different output when surrounded by an array operator?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1651002295,
        "creation_date": 1651001455,
        "question_id": 72019546,
        "body_markdown": "I have been trying to understand `jq`, and the following piuzzle is giving me a headache: I can construct two expressions, `A` and `B`, which seem to produce the same output. And yet, when I surround them with `[]` array construction braces (as in `[A]` and `[B]`), they produce different output. In this case, the expressions are:\r\n\r\n```\r\nA := jq  &#39;. | add&#39;\r\nB := jq -s `.[] | add`\r\n```\r\n\r\nConcretely:\r\n```\r\n$ echo &#39;[1,2] [3,4]&#39; | jq  &#39;.&#39;\r\n[1,2]\r\n[3,4]\r\n$ echo &#39;[1,2] [3,4]&#39; | jq  &#39;. | add&#39;\r\n3\r\n7\r\n# Now surround with array construction and we get two values:\r\n$ echo &#39;[1,2] [3,4]&#39; | jq &#39;[. | add]&#39;\r\n[3]\r\n[7]\r\n\r\n$ echo &#39;[1,2] [3,4]&#39; | jq -s &#39;.[]&#39;\r\n[1,2]\r\n[3,4]\r\n$ echo &#39;[1,2] [3,4]&#39; | jq -s &#39;.[] | add&#39;\r\n3\r\n7\r\n# Now surround with array construction and we get only one value:\r\n$ echo &#39;[1,2] [3,4]&#39; | jq -s &#39;[.[] | add]&#39;\r\n[3,7]\r\n```\r\n\r\nWhat is going on here? Why is it that the `B` expression, which applies the `--slurp` setting but appears to produce identical intermediate output to the `A` expression, produces different output when surrounded with `[]` array construction brackets?",
        "link": "https://stackoverflow.com/questions/72019546/jq-why-do-two-expressions-which-produce-identical-output-produce-different-outp",
        "title": "jq: Why do two expressions which produce identical output produce different output when surrounded by an array operator?"
    },
    {
        "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": 0,
                "creation_date": 1651011536,
                "post_id": 72021075,
                "comment_id": 127259400,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1651011457,
                "creation_date": 1651011457,
                "answer_id": 72021127,
                "question_id": 72021075,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `select` to filter, and `has` to check the keys:\r\n~~~sh\r\njq &#39;map(select(has(&quot;k3&quot;) and (.k3 | has(&quot;sk2&quot;) | not)))&#39; file.json\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;k1&quot;: &quot;b&quot;,\r\n    &quot;k2&quot;: &quot;ba&quot;,\r\n    &quot;k3&quot;: {\r\n      &quot;sk1&quot;: &quot;a&quot;,\r\n      &quot;sk3&quot;: &quot;cc&quot;\r\n    },\r\n    &quot;k4&quot;: {\r\n      &quot;sk6&quot;: &quot;zs&quot;,\r\n      &quot;sk8&quot;: &quot;we&quot;\r\n    }\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/DYaJSwIhLS)",
                "title": "selecting json entries that dont contain subkey"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1651011457,
        "creation_date": 1651011061,
        "question_id": 72021075,
        "body_markdown": "I am new to jq. I have a json file that looks like this\r\n\r\n    [\r\n    {\r\n    &quot;k1&quot;:&quot;a&quot;,\r\n    &quot;k2&quot;:&quot;aa&quot;,\r\n    &quot;k3&quot;:[&quot;sk1&quot;:&quot;a&quot;,&quot;sk2&quot;:&quot;cc&quot;,&quot;sk3&quot;:&quot;cc&quot;],\r\n    &quot;k4&quot;:[&quot;sk6&quot;:&quot;zs&quot;,&quot;sk8&quot;:&quot;we&quot;,...],\r\n    ...\r\n    },\r\n    {\r\n    &quot;k1&quot;:&quot;b&quot;,\r\n    &quot;k2&quot;:&quot;ba&quot;,\r\n    &quot;k3&quot;:[&quot;sk1&quot;:&quot;a&quot;,&quot;sk3&quot;:&quot;cc&quot;,...],\r\n    &quot;k4&quot;:[&quot;sk6&quot;:&quot;zs&quot;,&quot;sk8&quot;:&quot;we&quot;,...],\r\n    ...\r\n    },\r\n    {\r\n    &quot;k1&quot;:&quot;b&quot;,\r\n    &quot;k2&quot;:&quot;ba&quot;,\r\n    &quot;k4&quot;:[&quot;sk6&quot;:&quot;zs&quot;,&quot;sk8&quot;:&quot;we&quot;,...],\r\n    ...\r\n    }\r\n    ...\r\n    ]\r\n\r\nI would like to get all the entries in the array such that the key 3 (&quot;`k3`&quot;) doesnt have the subkey &quot;`sk2`&quot;. Note that some of the elements of the array dont have &quot;`k3`&quot; (so I would like to remove those) and then those that have &quot;`k3`&quot; sometimes dont have &quot;`sk2`&quot; (thats the ones I want).\r\n\r\nHow to accomplish this in jq?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72021075/selecting-json-entries-that-dont-contain-subkey",
        "title": "selecting json entries that dont contain subkey"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651035159,
                "last_edit_date": 1651035159,
                "creation_date": 1651034459,
                "answer_id": 72023370,
                "question_id": 72022313,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the raw input mode along with null input mode `-n`, so that you can get the whole input by `[inputs]` and further split by a regular expression indicating one or more whitespace characters.\r\n\r\nThe `split()` method can take a second argument to indicate any possible flags to provide.\r\n\r\nAlso inside the object formation, use `(..)` to generate key names.\r\n\r\n```none\r\njq -nR &#39;[inputs] | map(split(&quot;\\\\s+&quot;; &quot;&quot;)) | map({(.[0]): .[1]}) | add&#39;\r\n```\r\n\r\nIf you want the values in numeric form, rather than as strings use `(.[1] | tonumber)` instead of just `.[1]`\r\n\r\n[jqplay demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/Q_b9ZM9fil",
                "title": "Using jq to transform lines of key-values to json"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1651054044,
                "creation_date": 1651054044,
                "answer_id": 72026921,
                "question_id": 72022313,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here are some more approaches which all work well with jq 1.5:\r\n\r\n- using `capture` and `from_entries`\r\n~~~sh\r\njq -Rn &#39;[inputs | capture(&quot;(?&lt;key&gt;\\\\S+)\\\\s+(?&lt;value&gt;.+)&quot;)] | from_entries&#39; \r\n~~~\r\n[Demo](https://jqplay.org/s/I4CAfutmbu)\r\n\r\n- using `splits` and `reduce`\r\n~~~sh\r\njq -Rn &#39;reduce (inputs | [splits(&quot;\\\\s+&quot;)]) as [$k,$v] ({}; .[$k] = $v)&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/cGIxzBdimS)\r\n\r\n- using `splits` and `add`\r\n~~~sh\r\njq -Rn &#39;[inputs | [splits(&quot;\\\\s+&quot;)] as [$k, $v] | {($k): $v}] | add&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/HiZU4J10mA)\r\n\r\n",
                "title": "Using jq to transform lines of key-values to json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1651054044,
        "creation_date": 1651022990,
        "last_edit_date": 1651034616,
        "question_id": 72022313,
        "body_markdown": "I am looking to transform a set of rows that are `key value` (space seperated) to JSON. I am hoping to use `jq-1.5` for this:\r\n\r\n```\r\nlocal.location.altitude   3.0\r\nlocal.location.latitude   40.025495\r\nlocal.location.longitude  -74.312501\r\nlocal.orientation.pitch   0.0\r\nlocal.orientation.roll    0.0\r\nlocal.orientation.yaw     0.0\r\nlocal.velocity.azimuth    0.0\r\nlocal.velocity.elevation  0.0\r\nlocal.velocity.magnitude  0.0\r\n```\r\n\r\nTo\r\n```.json\r\n{\r\n  &quot;local.location.altitude&quot;: &quot;3.0&quot;,\r\n  &quot;local.location.latitude&quot;: &quot;40.025495&quot;,\r\n  &quot;local.location.longitude&quot;: &quot;-74.312501&quot;,\r\n  &quot;local.orientation.pitch&quot;: &quot;0.0&quot;,\r\n  &quot;local.orientation.roll&quot;: &quot;0.0&quot;,\r\n  &quot;local.orientation.yaw&quot;: &quot;0.0&quot;,\r\n  &quot;local.velocity.azimuth&quot;: &quot;0.0&quot;,\r\n  &quot;local.velocity.elevation&quot;: &quot;0.0&quot;,\r\n  &quot;local.velocity.magnitude&quot;: &quot;0.0&quot;\r\n}\r\n```\r\n\r\nI am trying commands like:\r\n```.sh\r\n./get-data | jq -R &#39;splits(&quot;\\\\s+&quot;)&#39;\r\n./get-data | jq -R &#39;splits(&quot;\\\\s+&quot;)|{ a : .[0], b : .[1] }\r\n```\r\n\r\nBut unable to make it work. I feel I am close. Anyone know how to go from `{{key}} {{val}}` to `{&quot;key&quot;: &quot;value&quot;}`?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72022313/using-jq-to-transform-lines-of-key-values-to-json",
        "title": "Using jq to transform lines of key-values to json"
    },
    {
        "tags": [
            "bash",
            "amazon-ec2",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651058905,
                "creation_date": 1651058905,
                "answer_id": 72027932,
                "question_id": 72026184,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you can live with `&quot;Tags&quot;: []` holding an empty array while still being present, a simple `map(select(.Key == &quot;Name&quot;))` will do:\r\n~~~sh\r\njq -c &#39;.Volumes[] | {State, VolumeId, Tags: (.Tags | map(select(.Key == &quot;Name&quot;)))}&#39;\r\n~~~\r\n~~~json\r\n{&quot;State&quot;:&quot;available&quot;,&quot;VolumeId&quot;:&quot;vol-094c79bc5e641bd7e&quot;,&quot;Tags&quot;:[{&quot;Key&quot;:&quot;Name&quot;,&quot;Value&quot;:&quot;Adi&quot;}]}\r\n{&quot;State&quot;:&quot;available&quot;,&quot;VolumeId&quot;:&quot;vol-041485dd7394bbdd7&quot;,&quot;Tags&quot;:[]}\r\n~~~\r\n[Demo](https://jqplay.org/s/_pPnpzzbzI)\r\n\r\nOtherwise you need to distinguish separately whether the field should be added or not. This can be achieved using an `if` statement:\r\n~~~sh\r\njq -c &#39;.Volumes[] | {State, VolumeId} + (\r\n  {Tags: (.Tags | map(select(.Key == &quot;Name&quot;)))} | if .Tags == [] then {} else . end\r\n)&#39;\r\n~~~\r\n~~~json\r\n{&quot;State&quot;:&quot;available&quot;,&quot;VolumeId&quot;:&quot;vol-094c79bc5e641bd7e&quot;,&quot;Tags&quot;:[{&quot;Key&quot;:&quot;Name&quot;,&quot;Value&quot;:&quot;Adi&quot;}]}\r\n{&quot;State&quot;:&quot;available&quot;,&quot;VolumeId&quot;:&quot;vol-041485dd7394bbdd7&quot;}\r\n~~~\r\n[Demo](https://jqplay.org/s/n9K2bneAkK)",
                "title": "How can I add conditions on my jq response in bash?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1651058905,
        "creation_date": 1651050694,
        "last_edit_date": 1651051501,
        "question_id": 72026184,
        "body_markdown": "I want write a script which is giving me the volumeId,instanceId and tags. But in tags just the &quot;Name&quot; is interest me.\r\nI will elaborate.\r\ntoday I am running with the next call\r\n\r\n     aws ec2 describe-volumes  --filters Name=status,Values=available | jq -c &#39;.Volumes[] | {State: .State, VolumeId: .VolumeId, Tags: .Tags}&#39;\r\n\r\n   1. `&quot;State&quot;:&quot;available&quot;,&quot;VolumeId&quot;:&quot;vol-094c79bc5e641bd7e&quot;,&quot;Tags&quot;:[{&quot;Key&quot;:&quot;Name&quot;,&quot;Value&quot;:&quot;Adi&quot;},{&quot;Key&quot;:&quot;Team&quot;,&quot;Value&quot;:&quot;SRE&quot;}]}`\r\n\r\n2.`{&quot;State&quot;:&quot;available&quot;,&quot;VolumeId&quot;:&quot;vol-041485dd7394bbdd7&quot;,&quot;Tags&quot;:[{&quot;Key&quot;:&quot;Team&quot;,&quot;Value&quot;:&quot;SRE&quot;}]}`\r\n\r\nI want my response will include the just the tag `&quot;Name&quot;` and it&#39;s value. \r\nIf the tag &quot;Name&quot; does not exist , I want in my response just the `&quot;State&quot;`,`&quot;VolumeId&quot;`.\r\n\r\nFor 1.`State&quot;:&quot;available&quot;,&quot;VolumeId&quot;:&quot;vol-094c79bc5e641bd7e&quot;,&quot;Tags&quot;:[{&quot;Key&quot;:&quot;Name&quot;,&quot;Value&quot;:&quot;Adi&quot;}`\r\nFor 2. `{&quot;State&quot;:&quot;available&quot;,&quot;VolumeId&quot;:&quot;vol-041485dd7394bbdd7&quot;`}\r\n\r\n\r\n\r\n                             ",
        "link": "https://stackoverflow.com/questions/72026184/how-can-i-add-conditions-on-my-jq-response-in-bash",
        "title": "How can I add conditions on my jq response in bash?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2649221,
                    "reputation": 6719,
                    "user_id": 2291328,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/0NFMw.jpg?s=256",
                    "display_name": "Ron",
                    "link": "https://stackoverflow.com/users/2291328/ron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1651051317,
                "post_id": 72026254,
                "comment_id": 127268030,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1651052716,
                "post_id": 72026254,
                "comment_id": 127268576,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22585781,
                    "reputation": 29,
                    "user_id": 16769769,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9306962004499cdfa06c36fe4eca7148?s=256&d=identicon&r=PG",
                    "display_name": "DesNet",
                    "link": "https://stackoverflow.com/users/16769769/desnet"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1651054712,
                "post_id": 72026254,
                "comment_id": 127269360,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1651056943,
                "post_id": 72026254,
                "comment_id": 127270159,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22585781,
                    "reputation": 29,
                    "user_id": 16769769,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9306962004499cdfa06c36fe4eca7148?s=256&d=identicon&r=PG",
                    "display_name": "DesNet",
                    "link": "https://stackoverflow.com/users/16769769/desnet"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1651058695,
                "post_id": 72026254,
                "comment_id": 127270775,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651060769,
                "creation_date": 1651060769,
                "answer_id": 72028333,
                "question_id": 72026254,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `envsubst` to replace the string `${stuff}` for exported variables.\r\n\r\n    age=&quot;$age&quot; envsubst &lt;&lt;&lt;&quot;${message}&quot;",
                "title": "Is there way, to use bash variable stored in json?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651065072,
                "creation_date": 1651065072,
                "answer_id": 72029381,
                "question_id": 72026254,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do with a single call to `jq` :\r\n\r\n```\r\njq -r &#39;.age as $age|.message|sub(&quot;\\\\${age}&quot;;$age)&#39; input.json\r\n```",
                "title": "Is there way, to use bash variable stored in json?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1651065072,
        "creation_date": 1651051019,
        "last_edit_date": 1651060986,
        "question_id": 72026254,
        "body_markdown": "I&#39;ve got two simple files, bash script and json file:\r\n``` json\r\n{\r\n  &quot;age&quot;: &quot;22&quot;,\r\n  &quot;message&quot;: &quot;You are ${age} years old&quot;\r\n}\r\n```\r\n``` shell\r\nage=$(jq -r .age file.json)\r\nmessage=$(jq -r .message file.json)\r\necho ${message}\r\n```\r\nWhen echoing message, as output I&#39;ve got\r\n```\r\nYou are ${age} years old\r\n```\r\nnot\r\n```\r\nYou are 22 years old\r\n```\r\nIs there some way in this scenario, to replace `${age}` with variable (for bash to know, that there&#39;s variable in there, not just plain string)? \r\nI could probably use `sed`, to manually replace it, but that&#39;s not what I&#39;m asking about.",
        "link": "https://stackoverflow.com/questions/72026254/is-there-way-to-use-bash-variable-stored-in-json",
        "title": "Is there way, to use bash variable stored in json?"
    },
    {
        "tags": [
            "bash",
            "csv",
            "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": 1651056346,
                "post_id": 72027372,
                "comment_id": 127269960,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19088969,
                    "reputation": 41,
                    "user_id": 13939622,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14Gi2HDInAAL2VcpHyi12nL02e9J-TFaQAqfPdnKu=k-s256",
                    "display_name": "ram prasad",
                    "link": "https://stackoverflow.com/users/13939622/ram-prasad"
                },
                "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": 1651145198,
                "post_id": 72027372,
                "comment_id": 127296454,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651110493,
                "creation_date": 1651110493,
                "answer_id": 72037092,
                "question_id": 72027372,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "this may depend on the api endpoint, but you could just request for CSV when calling your API. `curl -X GET -H &quot;Content-Type: text/csv&quot; &#39;https://some.api.endpoint.com/api/request.csv&#39;` so you get the CSV response instead of having to convert it yourself.",
                "title": "How to write json output to a CSV file using jq in a bash script?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1651110493,
        "creation_date": 1651056064,
        "last_edit_date": 1651062956,
        "question_id": 72027372,
        "body_markdown": "I have a JSON response from a API call as below and would like to write this to CSV file through a shell script.\r\n\r\n**JSON response:**\r\n```json\r\n{\r\n  &quot;maxResults&quot;: 50,\r\n  &quot;startAt&quot;: 0,\r\n  &quot;isLast&quot;: true,\r\n  &quot;values&quot;: [\r\n    {\r\n      &quot;id&quot;: 1986,\r\n      &quot;startDate&quot;: &quot;2020-01-27T20:15:30.094Z&quot;,\r\n      &quot;endDate&quot;: &quot;2020-02-24T20:15:00.000Z&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 1987,\r\n      &quot;startDate&quot;: &quot;2020-02-24T20:48:40.618Z&quot;,\r\n      &quot;endDate&quot;: &quot;2020-03-15T20:48:00.000Z&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 1988,\r\n      &quot;startDate&quot;: &quot;2020-03-16T17:46:16.846Z&quot;,\r\n      &quot;endDate&quot;: &quot;2020-04-24T17:46:00.000Z&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 1989,\r\n      &quot;startDate&quot;: &quot;2020-04-20T17:59:30.920Z&quot;,\r\n      &quot;endDate&quot;: &quot;2020-06-10T17:59:00.000Z&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nthe CSV file should look something like below\r\n\r\n```none\r\n1986,2020-01-27T20:15:30:094Z,2020-02-24T20:15:00:000Z\r\n1987,2020-02-24T20:48:40.618Z,2020-03-15T20:48:00.000Z\r\n1988,2020-03-16T17:46:16.846Z,2020-04-24T17:46:00.000Z\r\n1989,2020-04-20T17:59:30.920Z,2020-06-10T17:59:00.000Z\r\n```\r\n\r\nI have tried using jq but unable to figure out the correct way to write to csv\r\n\r\n    curl -X GET \\\r\n        --header &#39;Authorization: Basic &lt;token&gt;&#39;  \\\r\n        --header &#39;Content-Type: application/json&#39;\\\r\n         &quot;$url&quot; | jq -r &#39;[.values[].id, .values[].startDate, .values[].endDate] | @csv &#39; &gt;&gt; dates.csv\r\n\r\nAny inputs would be helpful.\r\n",
        "link": "https://stackoverflow.com/questions/72027372/how-to-write-json-output-to-a-csv-file-using-jq-in-a-bash-script",
        "title": "How to write json output to a CSV file using jq in a bash script?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1651066515,
                "creation_date": 1651066515,
                "answer_id": 72029765,
                "question_id": 72029655,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a task for `INDEX`, `JOIN` and `add`:\r\n~~~sh\r\njq &#39;[JOIN(INDEX(.networkId); input[]; .networkId; add)]&#39; file1.json file2.json\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;a&quot;,\r\n    &quot;networkId&quot;: &quot;L_653021545945744804&quot;,\r\n    &quot;customerId&quot;: &quot;id1&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;b&quot;,\r\n    &quot;networkId&quot;: &quot;L_655051945958724557&quot;,\r\n    &quot;customerId&quot;: &quot;id3&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/hdBL13XInA)\r\n",
                "title": "Bash match 2 json files based on common id"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1651066515,
        "creation_date": 1651066099,
        "question_id": 72029655,
        "body_markdown": "I wish to match 2 json files based on common id\r\nI&#39;ve tried using awk, jq and the npm json package in quite a lot of different ways but nothing have gotten close to working.\r\nThe 2 json files are not sorted and do not contain all the same entries. they contain the common networkId, I only want the output to contain the entries from file2.\r\nHope somebody can help!\r\nHere&#39;s an example.\r\n\r\nfile1.json:\r\n```\r\n[\r\n  {\r\n    &quot;customerId&quot;: &quot;id1&quot;,\r\n    &quot;networkId&quot;: &quot;L_653021545945744804&quot;\r\n  },\r\n  {\r\n    &quot;customerId&quot;: &quot;id2&quot;,\r\n    &quot;networkId&quot;: &quot;L_653021545955724805&quot;\r\n  },\r\n  {\r\n    &quot;customerId&quot;: &quot;id3&quot;,\r\n    &quot;networkId&quot;: &quot;L_655051945958724557&quot;\r\n  },\r\n  {\r\n    &quot;customerId&quot;: &quot;id4&quot;,\r\n    &quot;networkId&quot;: &quot;L_655567989968735408&quot;\r\n  }\r\n]\r\n```\r\n\r\nfile2.json:\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;a&quot;,\r\n    &quot;networkId&quot;: &quot;L_653021545945744804&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;b&quot;,\r\n    &quot;networkId&quot;: &quot;L_655051945958724557&quot;\r\n  }\r\n]\r\n```\r\n\r\nWanted output:\r\n```\r\n[\r\n  {\r\n    &quot;customerId&quot;: &quot;id1&quot;,\r\n    &quot;name&quot;: &quot;a&quot;,\r\n    &quot;networkId&quot;: &quot;L_653021545945744804&quot;\r\n  },\r\n  {\r\n    &quot;customerId&quot;: &quot;id3&quot;,\r\n    &quot;name&quot;: &quot;b&quot;,\r\n    &quot;networkId&quot;: &quot;L_655051945958724557&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/72029655/bash-match-2-json-files-based-on-common-id",
        "title": "Bash match 2 json files based on common id"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1651068735,
                "creation_date": 1651068735,
                "answer_id": 72030331,
                "question_id": 72030231,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It seems you want:\r\n\r\n    jq -r &#39;.[0].ipv4[]&#39;\r\n\r\nor perhaps:\r\n\r\n    jq -r &#39;.[].ipv4[]&#39;",
                "title": "Grab n item in nested array jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1651068735,
        "creation_date": 1651068386,
        "question_id": 72030231,
        "body_markdown": "I am trying to grab &#39;n&#39; item from a nested json array. The scenario is that I need to get the IP addresses from newly created cloud instances from my cloud provider so I can perform automation task with ansible. Here is a sample of the json output from the api that my cloud provider gives. (details obscured for privacy and security reasons)\r\n\r\n~~~\r\n[\r\n  {\r\n    &quot;alerts&quot;: {\r\n      &quot;cpu&quot;: 180,\r\n      &quot;io&quot;: 10000,\r\n      &quot;network_in&quot;: 10,\r\n      &quot;network_out&quot;: 10,\r\n      &quot;transfer_quota&quot;: 80\r\n    },\r\n    &quot;backups&quot;: {\r\n      &quot;enabled&quot;: false,\r\n      &quot;last_successful&quot;: null,\r\n      &quot;schedule&quot;: {\r\n        &quot;day&quot;: null,\r\n        &quot;window&quot;: null\r\n      }\r\n    },\r\n    &quot;created&quot;: &quot;2022-04&quot;,\r\n    &quot;group&quot;: &quot;&quot;,\r\n    &quot;hypervisor&quot;: &quot;kvm&quot;,\r\n    &quot;id&quot;: 36084613,\r\n    &quot;image&quot;: &quot;ubuntu20.04&quot;,\r\n    &quot;ipv4&quot;: [\r\n      &quot;12.34.56.78&quot;,     #&lt;--- Need to grab this public address\r\n      &quot;192.168.x.x&quot;      #&lt;--- and this private address\r\n    ],\r\n    &quot;ipv6&quot;: &quot;0000::0000/128&quot;,\r\n    &quot;label&quot;: &quot;node-1&quot;,\r\n    &quot;region&quot;: &quot;us&quot;,\r\n    &quot;specs&quot;: {\r\n      &quot;disk&quot;: 81920,\r\n      &quot;memory&quot;: 4096,\r\n      &quot;transfer&quot;: 4000,\r\n      &quot;vcpus&quot;: 2\r\n    },\r\n    &quot;status&quot;: &quot;running&quot;,\r\n    &quot;tags&quot;: [],\r\n    &quot;type&quot;: &quot;standard&quot;,\r\n    &quot;updated&quot;: &quot;2022-04&quot;,\r\n    &quot;watchdog_enabled&quot;: true\r\n  }\r\n]\r\n~~~\r\n\r\nI need to get the public IP address to I can add the node to an inventory file. So far, I have managed to get the following:\r\n```\r\n$ cat json.json | jq -r &#39;.[0].ipv4&#39;\r\n[\r\n  &quot;12.34.56.78&quot;,\r\n  &quot;192.168.x.x&quot;\r\n]\r\n```\r\nI can get what I want by repiping into jq, but I feel there has to be a more elegant way to do so.\r\n```\r\n$ cat json.json | jq -r &#39;.[0].ipv4&#39; | jq -r &#39;.[0]&#39;\r\n12.34.56.78\r\n\r\n$ cat json.json | jq -r &#39;.[0].ipv4&#39; | jq -r &#39;.[1]&#39;\r\n192.168.x.x\r\n```\r\n\r\n\r\nNew to posting on StackOverflow so I apologize in advance if someone already answered this on another thread. I looked around and couldn&#39;t find what I was looking for. Thanks! &#128512;",
        "link": "https://stackoverflow.com/questions/72030231/grab-n-item-in-nested-array-jq",
        "title": "Grab n item in nested array jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651089489,
                "creation_date": 1651089489,
                "answer_id": 72034604,
                "question_id": 72034333,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can always read a raw file using the `--rawfile VAR FILENAME` command-line option. ",
                "title": "read two files, one raw and the other json"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1651089489,
        "creation_date": 1651087887,
        "question_id": 72034333,
        "body_markdown": "I have two files.  The first is a dnsmasq.leases file, text only.  I can read this file using the -R switch.  I have another file, macs.json, this file contains a json dictionary with mac address information in it.  What I&#39;d like to do is read these two files from jq cli using\r\n\r\n    jq -s raw:dnsmasq.leases macs.json\r\n\r\nI can decompose it, and do it in stages, like:\r\n\r\n    jq -Rs &#39;.|split(&quot;\\n&quot;)&#39; dnsmasq.leases | jq -s &#39;.[0] as $macs|.[1] as $leases|etc&#39; macs.json -\r\n\r\nbut I wondered if there was a way to read one raw and the other json at the same time?\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72034333/read-two-files-one-raw-and-the-other-json",
        "title": "read two files, one raw and the other json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651090762,
                "last_edit_date": 1651090762,
                "creation_date": 1651090359,
                "answer_id": 72034747,
                "question_id": 72034427,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Some aspects are underspecified. For instance, you don&#39;t specify how deep the aggregation should go for the array items. Is it always two levels deep, or is it the whole tree but the last level?\r\n\r\nHere&#39;s one way how you would go two levels deep with the keys sorted alphabetically:\r\n~~~sh\r\njq &#39;.items | .[] |= [keys[] as $k | $k + &quot;.&quot; + (.[$k] | keys[])]&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/wKtYzSmsr0)\r\n\r\nHere&#39;s another way how to go down until the second-to-last level:\r\n~~~sh\r\njq &#39;.items | .[] |= ([path(.. | scalars)[:-1] | join(&quot;.&quot;)] | unique)&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/tDvRm_ZSp5)\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;item1&quot;: [\r\n    &quot;part1.a&quot;,\r\n    &quot;part1.b&quot;,\r\n    &quot;part2.c&quot;,\r\n    &quot;part2.d&quot;\r\n  ],\r\n  &quot;item2&quot;: [\r\n    &quot;part3.e&quot;,\r\n    &quot;part3.f&quot;,\r\n    &quot;part4.g&quot;,\r\n    &quot;part4.h&quot;\r\n  ]\r\n}\r\n~~~\r\n",
                "title": "Use jq to parse key path for each each leaf"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1651091159,
                "creation_date": 1651091159,
                "answer_id": 72034903,
                "question_id": 72034427,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this:\r\n```\r\n.items | map_values([path(.[][]) | join(&quot;.&quot;)])\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/8UchU9XCXp)&lt;/sup&gt;\r\n\r\nEach output path will contain as many path components as the number of `[]`s in the `.[][]` part; in other words, if you change `.[][]` to `.[][][]`, for example, you&#39;ll see `part1.a.key1`, `part1.a.key2`, etc.",
                "title": "Use jq to parse key path for each each leaf"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651091174,
                "creation_date": 1651091174,
                "answer_id": 72034910,
                "question_id": 72034427,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This would do it:\r\n\r\n```\r\n# Output: a stream\r\ndef keyKey:\r\n  keys_unsorted[] as $k | $k + &quot;.&quot; + (.[$k] | keys_unsorted[]);\r\n\r\n.items | map_values([keyKey])\r\n```",
                "title": "Use jq to parse key path for each each leaf"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1652326196,
                "creation_date": 1652326196,
                "answer_id": 72209829,
                "question_id": 72034427,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "the unique sequence of `jq` paths of &#39;keys&#39; to each and every leaf\r\nis returned from `json2jqpath.jq` \r\n\r\n``` jq\r\n json2jqpath.jq dat.json \r\n.\r\n.items\r\n.items|.item1\r\n.items|.item1|.part1\r\n.items|.item1|.part1|.a\r\n.items|.item1|.part1|.a|.key1\r\n.items|.item1|.part1|.a|.key2\r\n.items|.item1|.part1|.b\r\n.items|.item1|.part1|.b|.key1\r\n.items|.item1|.part1|.b|.key2\r\n.items|.item1|.part2\r\n.items|.item1|.part2|.c\r\n.items|.item1|.part2|.c|.key1\r\n.items|.item1|.part2|.c|.key2\r\n.items|.item1|.part2|.d\r\n.items|.item1|.part2|.d|.key1\r\n.items|.item1|.part2|.d|.key2\r\n.items|.item2\r\n.items|.item2|.part3\r\n.items|.item2|.part3|.e\r\n.items|.item2|.part3|.e|.key1\r\n.items|.item2|.part3|.e|.key2\r\n.items|.item2|.part3|.f\r\n.items|.item2|.part3|.f|.key1\r\n.items|.item2|.part3|.f|.key2\r\n.items|.item2|.part4\r\n.items|.item2|.part4|.g\r\n.items|.item2|.part4|.g|.key1\r\n.items|.item2|.part4|.g|.key2\r\n.items|.item2|.part4|.h\r\n.items|.item2|.part4|.h|.key1\r\n.items|.item2|.part4|.h|.key2\r\n```\r\n\r\nIt is not the output you asked for but as another noted, your question may be somewhat under specified. starting from a preprocessed structure such as this has the advantage of reducing _every_ json file to its set of paths to start fiddling with.\r\n\r\n[json2jqpath](https://github.com/TomConlin/json_to_paths)",
                "title": "Use jq to parse key path for each each leaf"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1652326196,
        "creation_date": 1651088478,
        "last_edit_date": 1651411047,
        "question_id": 72034427,
        "body_markdown": "(I’m not sure the technical terms to use but can update the question if someone can clarify the terminology I’m lacking for what I&#39;m trying to do. It might help someone find this answer in the future.)\r\n\r\nGiven the input JSON, how would I use jq to produce the expected output?\r\n\r\nInput:\r\n\r\n```\r\n{\r\n    &quot;items&quot;: {\r\n        &quot;item1&quot;: {\r\n            &quot;part1&quot;: {\r\n                &quot;a&quot;: {\r\n                    &quot;key1&quot;: &quot;value&quot;,\r\n                    &quot;key2&quot;: &quot;value&quot;\r\n                },\r\n\t\t\t\t&quot;b&quot;: {\r\n                    &quot;key1&quot;: &quot;value&quot;,\r\n                    &quot;key2&quot;: &quot;value&quot;\r\n                }\r\n\t\t\t},\r\n\t\t\t&quot;part2&quot;: {\r\n                &quot;c&quot;: {\r\n                    &quot;key1&quot;: &quot;value&quot;,\r\n                    &quot;key2&quot;: &quot;value&quot;\r\n                },\r\n\t\t\t\t&quot;d&quot;: {\r\n                    &quot;key1&quot;: &quot;value&quot;,\r\n                    &quot;key2&quot;: &quot;value&quot;\r\n                }\r\n\t\t\t}\r\n\t\t},\r\n\t\t&quot;item2&quot;: {\r\n            &quot;part3&quot;: {\r\n                &quot;e&quot;: {\r\n                    &quot;key1&quot;: &quot;value&quot;,\r\n                    &quot;key2&quot;: &quot;value&quot;\r\n                },\r\n\t\t\t\t&quot;f&quot;: {\r\n                    &quot;key1&quot;: &quot;value&quot;,\r\n                    &quot;key2&quot;: &quot;value&quot;\r\n                }\r\n\t\t\t},\r\n\t\t\t&quot;part4&quot;: {\r\n                &quot;g&quot;: {\r\n                    &quot;key1&quot;: &quot;value&quot;,\r\n                    &quot;key2&quot;: &quot;value&quot;\r\n                },\r\n\t\t\t\t&quot;h&quot;: {\r\n                    &quot;key1&quot;: &quot;value&quot;,\r\n                    &quot;key2&quot;: &quot;value&quot;\r\n                }\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n```\r\n\r\nExpected output:\r\n```\r\n{\r\n    &quot;item1&quot;: [\r\n\t\t&quot;part1.a&quot;,\r\n\t\t&quot;part1.b&quot;,\r\n\t\t&quot;part2.c&quot;,\r\n\t\t&quot;part2.d&quot;\r\n\t]\r\n\t&quot;item2&quot;: [\r\n\t\t&quot;part3.e&quot;,\r\n\t\t&quot;part3.f&quot;\r\n\t\t&quot;part4.g&quot;,\r\n\t\t&quot;part4.h&quot;\r\n\t]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/72034427/use-jq-to-parse-key-path-for-each-each-leaf",
        "title": "Use jq to parse key path for each each leaf"
    },
    {
        "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": 1651094460,
                "post_id": 72035054,
                "comment_id": 127283966,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1651095805,
                "last_edit_date": 1651095805,
                "creation_date": 1651093961,
                "answer_id": 72035346,
                "question_id": 72035054,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Filter using `select` and `has`, adjust the output using `map`.\r\n~~~sh\r\njq &#39;map(\r\n  select(has(&quot;k2&quot;) and any(.k2[]; has(&quot;a2&quot;)))\r\n  | .k2 |= map(select(has(&quot;a2&quot;) | not))\r\n)&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;k1&quot;: &quot;n1&quot;,\r\n    &quot;k2&quot;: [\r\n      {\r\n        &quot;a1&quot;: &quot;v12&quot;,\r\n        &quot;a3&quot;: &quot;v32&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/LhRZiz7FVy)",
                "title": "getting array elements missing a key with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1651095805,
        "creation_date": 1651092076,
        "last_edit_date": 1651092564,
        "question_id": 72035054,
        "body_markdown": "I have the following json array\r\n\r\n    [\r\n    {\r\n    &quot;k1&quot;:&quot;n1&quot;,\r\n    &quot;k2&quot;:[\r\n          {&quot;a1&quot;:&quot;v1&quot;,\r\n           &quot;a2&quot;:[{&quot;b1&quot;:&quot;v11&quot;},...],\r\n            &quot;a3&quot;:&quot;v3&quot;,...},\r\n           {&quot;a1&quot;:&quot;v12&quot;,\r\n            &quot;a3&quot;:&quot;v32&quot;,...},\r\n           \r\n         ],\r\n         ...\r\n    },\r\n    {\r\n    &quot;k1&quot;:&quot;n2&quot;,\r\n     &quot;k2&quot;:[\r\n          {&quot;a1&quot;:&quot;v1&quot;,\r\n            &quot;a3&quot;:&quot;v3&quot;,...}\r\n         ],\r\n    ...\r\n    },\r\n    {\r\n    &quot;k1&quot;:&quot;n2&quot;,\r\n     &quot;k3&quot;:[\r\n          {&quot;s1&quot;:&quot;v1&quot;,\r\n            &quot;s3&quot;:&quot;v3&quot;,...},\r\n          ...\r\n       ]\r\n    },\r\n    ...\r\n    ]\r\n\r\nI would like to use jq to get all the elements where the key `k2` exists and just return the array elements of `k2` that dont have the subkey `&quot;a2&quot;`. So for the example above I would like to return\r\n\r\n    [\r\n    {\r\n    &quot;k1&quot;:&quot;n1&quot;,\r\n    &quot;k2&quot;:[         \r\n           {&quot;a1&quot;:&quot;v12&quot;,\r\n            &quot;a3&quot;:&quot;v32&quot;,...},\r\n           \r\n         ],\r\n    },\r\n    ...\r\n    ]\r\n\r\n(in the first element, only the first element of k2 has the subkey a2 so thats the only one I removed, the 2nd element has `k2` but k2 doesnt have any elements with `a2` and the 3rd element doesnt have `k2`)",
        "link": "https://stackoverflow.com/questions/72035054/getting-array-elements-missing-a-key-with-jq",
        "title": "getting array elements missing a key with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1652519464,
                "creation_date": 1652519464,
                "answer_id": 72238797,
                "question_id": 72047013,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given your input file as `input.json` and the following JQ script as `transform.jq`:\r\n\r\n```\r\ndef stddate:\r\n\t._seconds | todate;\r\n\r\n.task\r\n| map_values(\r\n\t.dueDate |= stddate\r\n\t| .datePosted |= stddate\r\n)\r\n```\r\n\r\nThis command\r\n\r\n    jq -f transform.jq input.json\r\n\r\nreturns this output:\r\n\r\n```\r\n{\r\n  &quot;id1&quot;: {\r\n    &quot;completed&quot;: true,\r\n    &quot;title&quot;: &quot;Testing&quot;,\r\n    &quot;desc&quot;: &quot;short desc&quot;,\r\n    &quot;status&quot;: &quot;completed&quot;,\r\n    &quot;dueDate&quot;: &quot;2021-06-02T04:15:10Z&quot;,\r\n    &quot;citizenID&quot;: &quot;Uvr0vZqIPON5UZsgJsMYPe2Qfsi2&quot;,\r\n    &quot;datePosted&quot;: &quot;2021-06-02T04:16:48Z&quot;,\r\n    &quot;genre&quot;: &quot;Errands&quot;\r\n  },\r\n  &quot;id2&quot;: {\r\n    &quot;completed&quot;: true,\r\n    &quot;title&quot;: &quot;Testing 2&quot;,\r\n    &quot;status&quot;: &quot;completed&quot;,\r\n    &quot;dueDate&quot;: &quot;2021-06-02T04:36:16Z&quot;,\r\n    &quot;citizenID&quot;: &quot;Uvr0vZqIPON5UZsgJsMYPe2Qfsi2&quot;,\r\n    &quot;datePosted&quot;: &quot;2021-06-02T04:36:32Z&quot;,\r\n    &quot;genre&quot;: &quot;Errands&quot;,\r\n    &quot;latLng&quot;: null\r\n  }\r\n}\r\n```\r\n\r\nOf course you can squeeze the complete script into one command line argument.\r\n\r\nMissing things:\r\n\r\n- The `_nanoseconds` are ignored. You can readup the [date/time handling of JQ](https://stedolan.github.io/jq/manual/v1.6/#Dates) and follow the links to the used C functions.\r\n\r\n- The unnecessary `task` level is missing. If you really need it, replace `.task |` with `.task |=` to get it back.\r\n\r\n- Whatever &quot;consistent keys&quot; mean to you can be done inside `map_values`.\r\n",
                "title": "How to check JSON and add/remove key"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1652519464,
        "creation_date": 1651162328,
        "last_edit_date": 1652314229,
        "question_id": 72047013,
        "body_markdown": "I have a JSON file as an export of a nosql database, the sample below is 2 of 1xxx records.\r\n\r\n    {\r\n        &quot;task&quot;: {\r\n            &quot;id1&quot;: {\r\n                &quot;completed&quot;: true,\r\n                &quot;title&quot;: &quot;Testing&quot;,\r\n                &quot;desc&quot;: &quot;short desc&quot;,\r\n                &quot;status&quot;: &quot;completed&quot;,\r\n                &quot;dueDate&quot;: {\r\n                    &quot;_seconds&quot;: 1622607310,\r\n                    &quot;_nanoseconds&quot;: 867000000\r\n                },\r\n                &quot;citizenID&quot;: &quot;Uvr0vZqIPON5UZsgJsMYPe2Qfsi2&quot;,\r\n                &quot;datePosted&quot;: {\r\n                    &quot;_seconds&quot;: 1622607408,\r\n                    &quot;_nanoseconds&quot;: 365000000\r\n                },\r\n                &quot;genre&quot;: &quot;Errands&quot;\r\n            },\r\n            &quot;id2&quot;: {\r\n                &quot;completed&quot;: true,\r\n                &quot;title&quot;: &quot;Testing 2&quot;,\r\n                &quot;status&quot;: &quot;completed&quot;,\r\n                &quot;dueDate&quot;: {\r\n                    &quot;_seconds&quot;: 1622608576,\r\n                    &quot;_nanoseconds&quot;: 476999000\r\n                },\r\n                &quot;citizenID&quot;: &quot;Uvr0vZqIPON5UZsgJsMYPe2Qfsi2&quot;,\r\n                &quot;datePosted&quot;: {\r\n                    &quot;_seconds&quot;: 1622608592,\r\n                    &quot;_nanoseconds&quot;: 628999000\r\n                },\r\n                &quot;genre&quot;: &quot;Errands&quot;,\r\n                &quot;latLng&quot;: null\r\n            }\r\n        }\r\n    }\r\n\r\n\r\nAs the keys inside id1 and id2 are not consistent, im trying to find a way/tool to make sure that the keys are consistant before i use them. also, as the export push the date to as in seconds, im also trying to convert it to a timestamp/string \r\n\r\nThe final output ideally should be:\r\n\r\n    {\r\n\t&quot;task&quot;: {\r\n\t\t&quot;id1&quot;: {\r\n\t\t\t&quot;completed&quot;: true,\r\n\t\t\t&quot;title&quot;: &quot;Testing&quot;,\r\n\t\t\t&quot;desc&quot;: &quot;short desc&quot;,\r\n\t\t\t&quot;status&quot;: &quot;completed&quot;,\r\n\t\t\t&quot;dueDate&quot;: &quot;Wednesday, 2 June 2021 12:15:10.867 GMT+08:00&quot;,\r\n\t\t\t&quot;citizenID&quot;: &quot;Uvr0vZqIPON5UZsgJsMYPe2Qfsi2&quot;,\r\n\t\t\t&quot;datePosted&quot;: &quot;Wednesday, 2 June 2021 12:16:48.365 GMT+08:00&quot;,\r\n\t\t\t&quot;genre&quot;: &quot;Errands&quot;\r\n\t\t},\r\n\t\t&quot;id2&quot;: {\r\n\t\t\t&quot;completed&quot;: true,\r\n\t\t\t&quot;title&quot;: &quot;Testing 2&quot;,\r\n\t\t\t&quot;desc&quot;: &quot;&quot;,\r\n\t\t\t&quot;status&quot;: &quot;completed&quot;,\r\n\t\t\t&quot;dueDate&quot;: &quot;Wednesday, 2 June 2021 12:36:16.476 GMT+08:00&quot;,\r\n\t\t\t&quot;citizenID&quot;: &quot;Uvr0vZqIPON5UZsgJsMYPe2Qfsi2&quot;,\r\n\t\t\t&quot;datePosted&quot;: &quot;Wednesday, 2 June 2021 12:36:32.628 GMT+08:00&quot;,\r\n\t\t\t&quot;genre&quot;: &quot;Errands&quot;\r\n\t\t}\r\n\t}\r\n\r\nAny help is appreciated\r\n\r\nEdit 1: I found the wonderful jq, but im not able to write a good enough query:\r\n\r\n        . as $data | \r\n    paths(scalars) | . as $path | \r\n    &quot;\\($path[1]):{\\($path[2]):\\($data | getpath($path))}&quot;\r\n\r\nSo this gives me:\r\n\r\n    &quot;id1:{completed:true}&quot;\r\n    &quot;id1:{title:Testing}&quot;\r\n    &quot;id1:{desc:short desc}&quot;\r\n    &quot;id1:{status:completed}&quot;\r\n    &quot;id1:{dueDate:1622607310}&quot;\r\n    &quot;id1:{dueDate:867000000}&quot;\r\n    &quot;id1:{citizenID:Uvr0vZqIPON5UZsgJsMYPe2Qfsi2}&quot;\r\n    &quot;id1:{datePosted:1622607408}&quot;\r\n    &quot;id1:{datePosted:365000000}&quot;\r\n    &quot;id1:{genre:Errands}&quot;\r\n    &quot;id2:{completed:true}&quot;\r\n    &quot;id2:{title:Testing 2}&quot;\r\n    &quot;id2:{status:completed}&quot;\r\n    &quot;id2:{dueDate:1622608576}&quot;\r\n    &quot;id2:{dueDate:476999000}&quot;\r\n    &quot;id2:{citizenID:Uvr0vZqIPON5UZsgJsMYPe2Qfsi2}&quot;\r\n    &quot;id2:{datePosted:1622608592}&quot;\r\n    &quot;id2:{datePosted:628999000}&quot;\r\n    &quot;id2:{genre:Errands}&quot;\r\n\r\nwhich is still far from the ideal output",
        "link": "https://stackoverflow.com/questions/72047013/how-to-check-json-and-add-remove-key",
        "title": "How to check JSON and add/remove key"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1651163072,
                "post_id": 72047144,
                "comment_id": 127303918,
                "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": 1651163127,
                "post_id": 72047144,
                "comment_id": 127303939,
                "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": 1651175025,
                "post_id": 72047144,
                "comment_id": 127307886,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1651163183,
                "creation_date": 1651163183,
                "answer_id": 72047215,
                "question_id": 72047144,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You want `-R`, aka `--raw-input`, to make jq treat your input as a string instead of as an object.\r\n\r\n```\r\necho &#39;{&quot;foo&quot; : &quot;bar&quot;}&#39; | jq -R .\r\n```",
                "title": "Is there a way to stringify JSON in Bash"
            },
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1651175463,
                "creation_date": 1651175463,
                "answer_id": 72049457,
                "question_id": 72047144,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By &quot;stringify&quot;, you seem to mean &quot;encode a JSON value as a JSON string&quot;.\r\n\r\n    $ echo &#39;{&quot;foo&quot;: &quot;bar&quot;}&#39; | jq &#39;@json&#39;\r\n    &quot;{\\&quot;foo\\&quot;:\\&quot;bar\\&quot;}&quot;",
                "title": "Is there a way to stringify JSON in Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1651175463,
        "creation_date": 1651162886,
        "last_edit_date": 1651163228,
        "question_id": 72047144,
        "body_markdown": "I know that `jq` can take serialized JSON strings to format/filter/modify the content. However, as far as I know the output is always human readable form of JSON. Is there a way in Bash or `jq` itself, to stringify the output?\r\n\r\nFor example, given\r\n```bash\r\necho &#39;{&quot;foo&quot; : &quot;bar&quot;}&#39; | jq -r .\r\n```\r\n\r\nI&#39;m looking for an output that is `&quot;{\\&quot;foo\\&quot; : \\&quot;bar\\&quot;}&quot;`",
        "link": "https://stackoverflow.com/questions/72047144/is-there-a-way-to-stringify-json-in-bash",
        "title": "Is there a way to stringify JSON in Bash"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651195915,
                "creation_date": 1651195915,
                "answer_id": 72051870,
                "question_id": 72048835,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unfortunately, jq does not understand bash arrays.\r\n\r\nThings would probably be simplest if you can arrange to have your shell variable be a string representing a JSON array:\r\n```\r\neu=&#39;[&quot;FR&quot;, &quot;IT&quot;]&#39;\r\njq -n --argjson eu &quot;$eu&quot; &#39;$eu&#39;\r\n```\r\nOr if you prefer:\r\n```\r\neu=&#39;[&quot;FR&quot;, &quot;IT&quot;]&#39; jq -n &#39;env.eu | fromjson&#39;\r\n```\r\n\r\nAnother possibility would be to write your bash array into a file, and then slurp the file.\r\n\r\nThere are also many variants of the above....\r\n",
                "title": "jq select input based on values in array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651247421,
                "last_edit_date": 1651247421,
                "creation_date": 1651246064,
                "answer_id": 72060260,
                "question_id": 72048835,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `--argjson` to pass the list to `jq` and `IN` to select the matching entries.\r\n\r\n    jq -c --argjson eu &#39;[&quot;FR&quot;, &quot;IT&quot;]&#39; &#39;.[]| select(.country_iso3166_alpha2 | IN($eu[]))&#39; &lt;stuff\r\n\r\nBroken out to show the individual parts:\r\n\r\n    jq -c \\ \r\n        --argjson eu &#39;[&quot;FR&quot;, &quot;IT&quot;]&#39; \\ \r\n        &#39;.[]| select(.country_iso3166_alpha2 | IN($eu[]))&#39; \\ \r\n        &lt;stuff\r\n\r\n 1. invoke jq with compact output\r\n 2. pass in the list of countries as a json array named &quot;eu&quot;\r\n 3. select using the `IN` operator, unpacking `$eu[]` to get its values\r\n 4. redirect the input file into `jq`",
                "title": "jq select input based on values in array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1651247421,
        "creation_date": 1651171662,
        "question_id": 72048835,
        "body_markdown": "I have a list of country codes like FR, IT, DE and have been trying to figure out how to use this in a select statement.  I was doing something like \r\n\r\n    cat stuff | jq -c &#39;.[]| select(.country_iso3166_alpha2 == &quot;US&quot;)&#39;\r\nBut then my list grew to a large number of countries I want to match on.  So I tried using IN since I&#39;m using jq 1.6 and did something like this:\r\n\r\n    eu=(&quot;FR&quot;, &quot;IT&quot;); cat stuff | jq -c &#39;.[]| select(.country_iso3166_alpha2 IN($eu)&#39;\r\n\r\nI&#39;ve been reading the docs and looking at the cookbook but it&#39;s not making any sense to me.  Thanks!",
        "link": "https://stackoverflow.com/questions/72048835/jq-select-input-based-on-values-in-array",
        "title": "jq select input based on values in array"
    },
    {
        "tags": [
            "json",
            "linux",
            "ubuntu",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1651185769,
                "post_id": 72050957,
                "comment_id": 127310708,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1651186494,
                "last_edit_date": 1651186494,
                "creation_date": 1651185986,
                "answer_id": 72050991,
                "question_id": 72050957,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d use the array/object value iterator `.[]` and then `[&quot;text&quot;]` to filter:\r\n```jq\r\njq &#39;.[][&quot;text&quot;]&#39; \r\n```\r\nGiving you example file as input would produce this output:\r\n```\r\n&quot;Cats make about 100 different sounds. Dogs make only about 10.&quot;\r\n&quot;Domestic cats spend about 70 percent of the day sleeping and 15 percent of the day grooming.&quot;\r\n&quot;I don&#39;t know anything about cats.&quot;\r\n&quot;The technical term for a cat’s hairball is a bezoar.&quot;\r\n&quot;Cats are the most popular pet in the United States: There are 88 million pet cats and 74 million dogs.&quot;\r\n```\r\nThe above is also the exact output you&#39;d (currently) get from:\r\n```\r\ncurl -s &#39;https://cat-fact.herokuapp.com/facts&#39; | jq &#39;.[][&quot;text&quot;]&#39;\r\n```",
                "title": "How do I return the &quot;text&quot; field of this JSON file with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1651186494,
        "creation_date": 1651185452,
        "last_edit_date": 1651185536,
        "question_id": 72050957,
        "body_markdown": "I am looking to extract the cat facts from this JSON file:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;status&quot;: {\r\n      &quot;verified&quot;: true,\r\n      &quot;feedback&quot;: &quot;&quot;,\r\n      &quot;sentCount&quot;: 1\r\n    },\r\n    &quot;_id&quot;: &quot;5887e1d85c873e0011036889&quot;,\r\n    &quot;user&quot;: &quot;5a9ac18c7478810ea6c06381&quot;,\r\n    &quot;text&quot;: &quot;Cats make about 100 different sounds. Dogs make only about 10.&quot;,\r\n    &quot;__v&quot;: 0,\r\n    &quot;source&quot;: &quot;user&quot;,\r\n    &quot;updatedAt&quot;: &quot;2020-09-03T16:39:39.578Z&quot;,\r\n    &quot;type&quot;: &quot;cat&quot;,\r\n    &quot;createdAt&quot;: &quot;2018-01-15T21:20:00.003Z&quot;,\r\n    &quot;deleted&quot;: false,\r\n    &quot;used&quot;: true\r\n  },\r\n  {\r\n    &quot;status&quot;: {\r\n      &quot;verified&quot;: true,\r\n      &quot;sentCount&quot;: 1\r\n    },\r\n    &quot;_id&quot;: &quot;588e746706ac2b00110e59ff&quot;,\r\n    &quot;user&quot;: &quot;588e6e8806ac2b00110e59c3&quot;,\r\n    &quot;text&quot;: &quot;Domestic cats spend about 70 percent of the day sleeping and 15 percent of the day grooming.&quot;,\r\n    &quot;__v&quot;: 0,\r\n    &quot;source&quot;: &quot;user&quot;,\r\n    &quot;updatedAt&quot;: &quot;2020-08-26T20:20:02.359Z&quot;,\r\n    &quot;type&quot;: &quot;cat&quot;,\r\n    &quot;createdAt&quot;: &quot;2018-01-14T21:20:02.750Z&quot;,\r\n    &quot;deleted&quot;: false,\r\n    &quot;used&quot;: true\r\n  },\r\n  {\r\n    &quot;status&quot;: {\r\n      &quot;verified&quot;: true,\r\n      &quot;sentCount&quot;: 1\r\n    },\r\n    &quot;_id&quot;: &quot;58923f2fc3878c0011784c79&quot;,\r\n    &quot;user&quot;: &quot;5887e9f65c873e001103688d&quot;,\r\n    &quot;text&quot;: &quot;I don&#39;t know anything about cats.&quot;,\r\n    &quot;__v&quot;: 0,\r\n    &quot;source&quot;: &quot;user&quot;,\r\n    &quot;updatedAt&quot;: &quot;2020-08-23T20:20:01.611Z&quot;,\r\n    &quot;type&quot;: &quot;cat&quot;,\r\n    &quot;createdAt&quot;: &quot;2018-02-25T21:20:03.060Z&quot;,\r\n    &quot;deleted&quot;: false,\r\n    &quot;used&quot;: false\r\n  },\r\n  {\r\n    &quot;status&quot;: {\r\n      &quot;verified&quot;: true,\r\n      &quot;sentCount&quot;: 1\r\n    },\r\n    &quot;_id&quot;: &quot;5894af975cdc7400113ef7f9&quot;,\r\n    &quot;user&quot;: &quot;5a9ac18c7478810ea6c06381&quot;,\r\n    &quot;text&quot;: &quot;The technical term for a cat’s hairball is a bezoar.&quot;,\r\n    &quot;__v&quot;: 0,\r\n    &quot;source&quot;: &quot;user&quot;,\r\n    &quot;updatedAt&quot;: &quot;2020-11-25T21:20:03.895Z&quot;,\r\n    &quot;type&quot;: &quot;cat&quot;,\r\n    &quot;createdAt&quot;: &quot;2018-02-27T21:20:02.854Z&quot;,\r\n    &quot;deleted&quot;: false,\r\n    &quot;used&quot;: true\r\n  },\r\n  {\r\n    &quot;status&quot;: {\r\n      &quot;verified&quot;: true,\r\n      &quot;sentCount&quot;: 1\r\n    },\r\n    &quot;_id&quot;: &quot;58e007cc0aac31001185ecf5&quot;,\r\n    &quot;user&quot;: &quot;58e007480aac31001185ecef&quot;,\r\n    &quot;text&quot;: &quot;Cats are the most popular pet in the United States: There are 88 million pet cats and 74 million dogs.&quot;,\r\n    &quot;__v&quot;: 0,\r\n    &quot;source&quot;: &quot;user&quot;,\r\n    &quot;updatedAt&quot;: &quot;2020-08-23T20:20:01.611Z&quot;,\r\n    &quot;type&quot;: &quot;cat&quot;,\r\n    &quot;createdAt&quot;: &quot;2018-03-01T21:20:02.713Z&quot;,\r\n    &quot;deleted&quot;: false,\r\n    &quot;used&quot;: false\r\n  }\r\n]\r\n```\r\n\r\nIts url is https://cat-fact.herokuapp.com/facts. I know access to the information is not a problem because when I run `curl &#39;https://cat-fact.herokuapp.com/facts&#39; | jq &#39;.&#39;`, I get the entire file in return. \r\n\r\nAfter running `curl &#39;https://cat-fact.herokuapp.com/facts&#39; | jq &#39;. | {text}&#39;`,\r\n\r\nI get the error `jq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;text&quot;`.\r\n\r\nAfter running `curl &#39;https://cat-fact.herokuapp.com/facts&#39; | jq &#39;. | {.text}&#39;`,\r\n\r\nThis is returned: `(23) Failed writing body `\r\n\r\nAfter running `curl &#39;https://cat-fact.herokuapp.com/facts&#39; | jq &#39;.[] | {text: .commit.text}&#39;`,\r\n\r\nThis is returned:\r\n```\r\n % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\nDload  Upload   Total   Spent    Left  Speed                                           100  1675\r\n100  1675    0     0   9463      0 --:--:-- --:--:-- --:--:--  9463\r\n{\r\n&quot;text&quot;: null\r\n}\r\n{\r\n&quot;text&quot;: null\r\n}\r\n{\r\n&quot;text&quot;: null\r\n}\r\n{\r\n&quot;text&quot;: null\r\n}\r\n{ \r\n&quot;text&quot;: null\r\n}            \r\n```\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72050957/how-do-i-return-the-text-field-of-this-json-file-with-jq",
        "title": "How do I return the &quot;text&quot; field of this JSON file with jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16742251,
                    "reputation": 13393,
                    "user_id": 12101554,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3cce987ffb6039e9bd8889bc9445bec3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Samathingamajig",
                    "link": "https://stackoverflow.com/users/12101554/samathingamajig"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1651196313,
                "post_id": 72051857,
                "comment_id": 127312290,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1703255853,
                "last_edit_date": 1703255853,
                "creation_date": 1651196223,
                "answer_id": 72051895,
                "question_id": 72051857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To remove specific positions from a string, use the indices you want to keep:\r\n~~~sh\r\njq -r &#39;.x | .[:1] + .[2:]&#39; &lt;&lt;&lt; &#39;{&quot;x&quot;:&quot;1,2&quot;}&#39;\r\n~~~\r\n~~~json\r\n12\r\n~~~\r\n[Demo](https://jqplay.org/s/cltkT77Z7W)\r\n\r\nTo remove one occurrence at any position, use `sub` to replace with the empty string\r\n~~~sh\r\njq -r &#39;.x | sub(&quot;,&quot;; &quot;&quot;)&#39; &lt;&lt;&lt; &#39;{&quot;x&quot;:&quot;1,2,3&quot;}&#39;\r\n~~~\r\n~~~json\r\n12,3\r\n~~~\r\n[Demo](https://jqplay.org/s/takIZcePxO)\r\n\r\nTo remove all occurrences, use `gsub` the same way\r\n~~~sh\r\njq -r &#39;.x | gsub(&quot;,&quot;; &quot;&quot;)&#39; &lt;&lt;&lt; &#39;{&quot;x&quot;:&quot;1,2,3&quot;}&#39;\r\n~~~\r\n~~~json\r\n123\r\n~~~\r\n[Demo](https://jqplay.org/s/9objxxQHuc)\r\n",
                "title": "remove a substring from a string"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1703256125,
                "last_edit_date": 1703256125,
                "creation_date": 1651274047,
                "answer_id": 72064504,
                "question_id": 72051857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You didn&#39;t make clear what output you wanted. A literal reading suggests you want `12`, but I find it more likely that you want each of the comma-separated items to be output on separate lines. The following achieves this:\r\n\r\n```sh\r\njq -r &#39;.x | split( &quot;,&quot; )[]&#39;\r\n```\r\n\r\nFor the provided input, this outputs\r\n\r\n```none\r\n1\r\n2\r\n```\r\n\r\n[Demo](https://jqplay.org/s/4DVTQt5znew) on jqplay\r\n\r\nBut if `12` is indeed what&#39;s desired, adding a `join` will do the trick.\r\n\r\n```sh\r\njq -r &#39;.x | split( &quot;,&quot; ) | join( &quot;&quot; )&#39;\r\n```\r\n\r\n```none\r\n12\r\n```\r\n\r\n[Demo](https://jqplay.org/s/ixlqAxjNA-5) on jqplay\r\n",
                "title": "remove a substring from a string"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1651455394,
                "creation_date": 1651455394,
                "answer_id": 72081607,
                "question_id": 72051857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `sub`.\r\n\r\nFilter\r\n```\r\n.x | sub(&quot;,&quot;; &quot; &quot;)\r\n```\r\n\r\nInput\r\n```\r\n{&quot;x&quot;:&quot;1,2&quot;}\r\n```\r\n\r\nOutput\r\n```\r\n1 2\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/IaViogZTsI",
                "title": "remove a substring from a string"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1703256125,
        "creation_date": 1651195750,
        "question_id": 72051857,
        "body_markdown": "I want to remove `,` from a string in jq. Take the following example, how to remove `,` when outputting `1,2`?\r\n\r\n```\r\n$ jq -r .x &lt;&lt;&lt; &#39;{&quot;x&quot;:&quot;1,2&quot;}&#39;\r\n1,2\r\n```",
        "link": "https://stackoverflow.com/questions/72051857/remove-a-substring-from-a-string",
        "title": "remove a substring from a string"
    },
    {
        "tags": [
            "gitlab",
            "continuous-integration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1651549526,
                "last_edit_date": 1651549526,
                "creation_date": 1651548794,
                "answer_id": 72094582,
                "question_id": 72057231,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Please refer to the documentation on [Merge requests API](https://docs.gitlab.com/ee/api/merge_requests.html) and [How to use the API](https://docs.gitlab.com/ee/api/#how-to-use-the-api) to construct a properly formed cURL request with GitLab API before piping the result into `jq`.\r\n\r\nThere are a few things going on with your query.\r\n\r\nFirst of all, according to the documentation, the `/merge_requests` endpoint will\r\n\r\n&gt; Get all merge requests the authenticated user has access to.\r\n\r\nThis means that `APP_REPO_URL` needs to be the GitLab instance URL followed by `/api/v4` and not the URL of the specific project.\r\n\r\n```sh\r\ncurl &quot;https://gitlab.example.com/api/v4/merge_requests&quot;\r\n```\r\n\r\nIf you need all merge requests for a given project, then you can use\r\n\r\n```sh\r\ncurl &quot;https://gitlab.example.com/api/v4/projects/:id/merge_requests&quot;\r\n```\r\n\r\nwhere `:id` is the id of your project. See more at [List project merge requests](https://docs.gitlab.com/ee/api/merge_requests.html#list-project-merge-requests)\r\n\r\nThen, the `search` attribute is expecting either a title or a description and not a commit SHA:\r\n\r\n&gt; Search merge requests against their title and description\r\n\r\n",
                "title": "Continuous deployment gitlab"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1651802989,
        "creation_date": 1651231599,
        "last_edit_date": 1651802989,
        "question_id": 72057231,
        "body_markdown": "\r\nLine of my `.gitlab-ci.yml`\r\n\r\n`IID=$(curl --verbose --request GET --header &quot;Content-Type: application/json&quot; --header &quot;PRIVATE-TOKEN: ${CI_PUSH_TOKEN}&quot; ${APP_REPO_URL}/merge_requests?author_id=xxxxxxxx\\&amp;search=${CI_COMMIT_SHORT_SHA} | jq &#39;.[0].iid&#39;)`\r\n\r\noutput jq: error (at &lt;stdin&gt;:0): Cannot index object with number",
        "link": "https://stackoverflow.com/questions/72057231/continuous-deployment-gitlab",
        "title": "Continuous deployment gitlab"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651284701,
                "creation_date": 1651284701,
                "answer_id": 72065194,
                "question_id": 72065049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following illustrates one approach to answering the twofold question:\r\n```\r\n.results |= map(\r\n  (.custom_fields | map(.value | select(. != null))) as $values\r\n  | {url, created_at, subject, description, recipient, tags, \r\n     os: $values[0],\r\n     is_signed_in: $values[1],\r\n     phone_model: $values[2],\r\n     channel: $values[3] } )\r\n```\r\n\r\nThis however results in .results having length 2.\r\n\r\n",
                "title": "JQ: Filtering a massive json with nested arrays efficiently"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1651512783,
                "last_edit_date": 1651512783,
                "creation_date": 1651317428,
                "answer_id": 72068034,
                "question_id": 72065049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a mapping to keep track of the custom fields wanted :\r\n\r\n```\r\n!/usr/bin/env bash\r\n\r\njq &#39;{&quot;os&quot;          : 360009431333,\r\n     &quot;is_signed_in&quot;: 360054304553,\r\n     &quot;phone_model&quot; : 360009431353,\r\n     &quot;channel&quot;     : 1500001920482} as $mapping |\r\n.results |= map(\r\n   { url,created_at,subject,description,recipient,tags,\r\n   } +\r\n   (.custom_fields as $custom_fields |\r\n    $mapping |\r\n    with_entries(\r\n      .value |= (. as $id | $custom_fields[]?|select(.id==$id).value)\r\n    )\r\n   )\r\n)&#39; input.json\r\n```",
                "title": "JQ: Filtering a massive json with nested arrays efficiently"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1651512783,
        "creation_date": 1651282219,
        "last_edit_date": 1651511010,
        "question_id": 72065049,
        "body_markdown": "I have a MASSIVE json file with lots of extraneous fields that I need to trim down to only include certain fields. I&#39;ve made some headway on processing the file with `jq` but I&#39;ve run into some difficulty when it comes to pulling information out of the nested arrays in the json file, and none of the solutions I&#39;ve found have seemed to work for me.\r\n\r\nMy json data looks like this:\r\n```\r\n{\r\n  &quot;results&quot;: [\r\n    {\r\n      &quot;url&quot;: &quot;https://someresult.com&quot;,\r\n      &quot;id&quot;: 5192740,\r\n      &quot;external_id&quot;: null,\r\n      &quot;via&quot;: {\r\n        &quot;channel&quot;: &quot;web&quot;,\r\n        &quot;source&quot;: {\r\n          &quot;from&quot;: {},\r\n          &quot;to&quot;: {},\r\n          &quot;rel&quot;: null\r\n        }\r\n      },\r\n      &quot;created_at&quot;: &quot;2022-04-29T15:19:37Z&quot;,\r\n      &quot;updated_at&quot;: &quot;2022-04-29T15:19:38Z&quot;,\r\n      &quot;type&quot;: null,\r\n      &quot;subject&quot;: &quot;My subject line&quot;,\r\n      &quot;raw_subject&quot;: &quot;My subject line &quot;,\r\n      &quot;description&quot;: &quot;Lorem ipsum dolor sit amet, consectetur adipiscing elit. Mauris et nulla ut sapien ultrices tempus.&quot;,\r\n      &quot;priority&quot;: &quot;normal&quot;,\r\n      &quot;status&quot;: &quot;new&quot;,\r\n      &quot;recipient&quot;: &quot;somebody@email.com&quot;,\r\n      &quot;requester_id&quot;: 1234567891,\r\n      &quot;submitter_id&quot;: 1234567891,\r\n      &quot;assignee_id&quot;: null,\r\n      &quot;organization_id&quot;: null,\r\n      &quot;group_id&quot;: 123456789,\r\n      &quot;collaborator_ids&quot;: [],\r\n      &quot;follower_ids&quot;: [],\r\n      &quot;email_cc_ids&quot;: [],\r\n      &quot;forum_topic_id&quot;: null,\r\n      &quot;problem_id&quot;: null,\r\n      &quot;has_incidents&quot;: false,\r\n      &quot;is_public&quot;: true,\r\n      &quot;due_at&quot;: null,\r\n      &quot;tags&quot;: [\r\n        &quot;_tag_1&quot;,\r\n        &quot;_tag_2&quot;,\r\n        &quot;_tag_3&quot;\r\n      ],\r\n      &quot;custom_fields&quot;: [\r\n        {\r\n          &quot;id&quot;: 1500010396161,\r\n          &quot;value&quot;: null\r\n        },\r\n        {\r\n          &quot;id&quot;: 360009431333,\r\n          &quot;value&quot;: &quot;Keep this data&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 360054304553,\r\n          &quot;value&quot;: false\r\n        },\r\n        {\r\n          &quot;id&quot;: 1900000317745,\r\n          &quot;value&quot;: null\r\n        },\r\n        {\r\n          &quot;id&quot;: 360002223154,\r\n          &quot;value&quot;: null\r\n        },\r\n        {\r\n          &quot;id&quot;: 360009431353,\r\n          &quot;value&quot;: &quot;Keep this too&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 1500001920482,\r\n          &quot;value&quot;: &quot;Keep this data, as well!&quot;\r\n        }\r\n      ],\r\n      &quot;followup_ids&quot;: [],\r\n      &quot;ticket_form_id&quot;: 12345678912,\r\n      &quot;brand_id&quot;: 112358,\r\n      &quot;allow_channelback&quot;: false,\r\n      &quot;allow_attachments&quot;: true,\r\n      &quot;result_type&quot;: &quot;ticket&quot;\r\n    },\r\n    {\r\n      &quot;url&quot;: &quot;https://anotherresult.com&quot;,\r\n      &quot;id&quot;: 5192741,\r\n      &quot;external_id&quot;: null,\r\n      &quot;via&quot;: {\r\n        &quot;channel&quot;: &quot;web&quot;,\r\n        &quot;source&quot;: {\r\n          &quot;from&quot;: {},\r\n          &quot;to&quot;: {},\r\n          &quot;rel&quot;: null\r\n        }\r\n      },\r\n      &quot;created_at&quot;: &quot;2022-04-18T15:19:37Z&quot;,\r\n      &quot;updated_at&quot;: &quot;2022-04-18T15:19:38Z&quot;,\r\n      &quot;type&quot;: null,\r\n      &quot;subject&quot;: &quot;My other subject line&quot;,\r\n      &quot;raw_subject&quot;: &quot;My other subject line &quot;,\r\n      &quot;description&quot;: &quot;Lorem ipsum dolor sit amet, consectetur adipiscing elit. Mauris et nulla ut sapien ultrices tempus.&quot;,\r\n      &quot;priority&quot;: &quot;normal&quot;,\r\n      &quot;status&quot;: &quot;new&quot;,\r\n      &quot;recipient&quot;: &quot;somebody@email.com&quot;,\r\n      &quot;requester_id&quot;: 1234567892,\r\n      &quot;submitter_id&quot;: 1234567892,\r\n      &quot;assignee_id&quot;: null,\r\n      &quot;organization_id&quot;: null,\r\n      &quot;group_id&quot;: 123456780,\r\n      &quot;collaborator_ids&quot;: [],\r\n      &quot;follower_ids&quot;: [],\r\n      &quot;email_cc_ids&quot;: [],\r\n      &quot;forum_topic_id&quot;: null,\r\n      &quot;problem_id&quot;: null,\r\n      &quot;has_incidents&quot;: false,\r\n      &quot;is_public&quot;: true,\r\n      &quot;due_at&quot;: null,\r\n      &quot;tags&quot;: [\r\n        &quot;_tag_1&quot;,\r\n        &quot;_tag_2&quot;,\r\n        &quot;_tag_3&quot;\r\n      ],\r\n      &quot;custom_fields&quot;: [\r\n        {\r\n          &quot;id&quot;: 1500010396161,\r\n          &quot;value&quot;: null\r\n        },\r\n        {\r\n          &quot;id&quot;: 360009431333,\r\n          &quot;value&quot;: &quot;Keep this data&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 360054304553,\r\n          &quot;value&quot;: false\r\n        },\r\n        {\r\n          &quot;id&quot;: 1900000317745,\r\n          &quot;value&quot;: null\r\n        },\r\n        {\r\n          &quot;id&quot;: 360002223154,\r\n          &quot;value&quot;: null\r\n        },\r\n        {\r\n          &quot;id&quot;: 360009431353,\r\n          &quot;value&quot;: &quot;Keep this too&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 1500001920482,\r\n          &quot;value&quot;: &quot;Keep this data, as well!&quot;\r\n        }\r\n      ],\r\n      &quot;followup_ids&quot;: [],\r\n      &quot;ticket_form_id&quot;: 12345678913,\r\n      &quot;brand_id&quot;: 112359,\r\n      &quot;allow_channelback&quot;: false,\r\n      &quot;allow_attachments&quot;: true,\r\n      &quot;result_type&quot;: &quot;ticket&quot;\r\n    }\r\n  ],\r\n  &quot;facets&quot;: null,\r\n  &quot;meta&quot;: {\r\n    &quot;has_more&quot;: true,\r\n    &quot;after_cursor&quot;: &quot;eyJmaWVsZCI6ImNyZWF0ZWRfYXQiLCJkZXNjIjp0cnVlLCJ0aWVCcmVha0ZpZWxkIjoiaWQiLCJ0aWVCcmVha0Rlc2MiOmZhbHNlLCJzb3J0VmFsdWVzIjpbMTY0NjQxNTc3MjAwMCwxNTA5NDY0NjMzNTYyXSwiZXhwb3J0ZWRUaHVzRmFyIjoxMDAwLCJzZXNzaW9uU3RhcnQiOjE2NTE1MTA1MDE3MDksImNyZWF0ZWRBdCI6MTY1MTUxMDUwMTgxNywic2FsdGVkUmVxdWVzdEhhc2giOjEwMTMwNTk0MjMsInNhbHRlZEN1cnNvckhhc2giOi0xMTE3Mzc0MjIxfQ==&quot;,\r\n    &quot;before_cursor&quot;: null\r\n  },\r\n  &quot;links&quot;: {\r\n    &quot;prev&quot;: null,\r\n    &quot;next&quot;: &quot;https://myendpoint.site.com/api/v2/search/export.json?filter%5Btype%5D=ticket&amp;page%5Bafter%5D=eyJmaWVsZCI6ImNyZWF0ZWRfYXQiLCJkZXNjIjp0cnVlLCJ0aWVCcmVha0ZpZWxkIjoiaWQiLCJ0aWVCcmVha0Rlc2MiOmZhbHNlLCJzb3J0VmFsdWVzIjpbMTY0NjQxNTc3MjAwMCwxNTA5NDY0NjMzNTYyXSwiZXhwb3J0ZWRUaHVzRmFyIjoxMDAwLCJzZXNzaW9uU3RhcnQiOjE2NTE1MTA1MDE3MDksImNyZWF0ZWRBdCI6MTY1MTUxMDUwMTgxNywic2FsdGVkUmVxdWVzdEhhc2giOjEwMTMwNTk0MjMsInNhbHRlZEN1cnNvckhhc2giOi0xMTE3Mzc0MjIxfQ%3D%3D&amp;page%5Bsize%5D=1000&amp;query=group%3A360000609273+created%3E6Months&quot;\r\n  }\r\n}\r\n```\r\n\r\nAnd I want to trim it down to this:\r\n\r\n```\r\n{\r\n    &quot;results&quot;: [\r\n        {\r\n            &quot;url&quot;: &quot;https://someresult.com&quot;,\r\n            &quot;created_at&quot;: &quot;2022-04-29T15:19:37Z&quot;,\r\n            &quot;subject&quot;: &quot;My subject line&quot;,\r\n            &quot;description&quot;: &quot;Lorem ipsum dolor sit amet, consectetur adipiscing elit. Mauris et nulla ut sapien ultrices tempus.&quot;,\r\n            &quot;recipient&quot;: &quot;somebody@email.com&quot;,\r\n            &quot;tags&quot;: [\r\n                &quot;_tag_1&quot;,\r\n                &quot;_tag_2&quot;,\r\n                &quot;_tag_3&quot;\r\n            ],\r\n            &quot;os&quot;: &quot;Keep this data&quot;,\r\n            &quot;is_signed_in&quot;: false,\r\n            &quot;phone_model&quot;: &quot;Keep this too&quot;,\r\n            &quot;channel&quot;: &quot;Keep this data, as well!&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\nSo far, I&#39;ve been able to brute force it by deleting fields by typing them all out\r\n```\r\njq &#39;del(.results[] | .url, .id, .external_id, .via, .updated_at, .type, .raw_subject, .priority, .status, .requester_id, .submitter_id, .assignee_id, .organization_id, .group_id, .collaborator_ids, .follower_ids, .email_cc_ids, .problem_id, .has_incidents, .is_public, .due_at, .forum_topic_id, .satisfaction_rating, .sharing_agreement_ids, .fields, .followup_ids, .ticket_form_id, .allow_channelback, .allow_attachments, .result_type)&#39;\r\n```\r\nbut that feels absurd (still, it works).\r\nBut when I try to delete or filter for the fields I want from the `custom_fields` array, I get stuck (`Cannot index array with string &quot;custom fields&quot;`).\r\n\r\nMy question is twofold:\r\n\r\n 1. **Is there a cleaner way I could be selecting which fields to *keep* rather than specifying which to delete?**\r\n 2. **How do I grab the fields I need from the nested array, and flattening them to the same level as the rest of the fields, while also renaming them?**",
        "link": "https://stackoverflow.com/questions/72065049/jq-filtering-a-massive-json-with-nested-arrays-efficiently",
        "title": "JQ: Filtering a massive json with nested arrays efficiently"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1651364100,
                "last_edit_date": 1651364100,
                "creation_date": 1651328539,
                "answer_id": 72069316,
                "question_id": 72069045,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Remove the last element, prepend a dot to `strings`, wrap `numbers` in brackets, and `join` the array:\r\n~~~sh\r\n.[:-1] | map(strings = &quot;.\\(.)&quot; | numbers = &quot;[\\(.)]&quot;) | join(&quot;&quot;)\r\n~~~\r\n~~~json\r\n&quot;.data.legacyCollection.collectionsPage.stream.edges[0].node&quot;\r\n&quot;.data.legacyCollection.collectionsPage.stream.edges[1].node&quot;\r\n&quot;.data.legacyCollection.collectionsPage.stream.edges[2].node&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/4TyeEF29rb)",
                "title": "how to concat jq paths in each array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1651364100,
        "creation_date": 1651326431,
        "last_edit_date": 1651328141,
        "question_id": 72069045,
        "body_markdown": "Here is the json paths which ends with &#39;headline&#39; I have got: \r\n\r\n\r\n```\r\njq -c &#39;paths | select(.[-1] == &quot;headline&quot;)&#39; news.json\r\n\r\n[&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;,&quot;stream&quot;,&quot;edges&quot;,0,&quot;node&quot;,&quot;headline&quot;]\r\n[&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;,&quot;stream&quot;,&quot;edges&quot;,1,&quot;node&quot;,&quot;headline&quot;]\r\n[&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;,&quot;stream&quot;,&quot;edges&quot;,2,&quot;node&quot;,&quot;headline&quot;]\r\n```\r\n\r\nHow can I **get one step further** which is concat all elements in a single path.\r\nto turn my output from:\r\n\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;,&quot;stream&quot;,&quot;edges&quot;,2,&quot;node&quot;,&quot;headline&quot;]\r\n\r\nto \r\n\r\n    &#39;.data.legacyCollection.collectionsPage.stream.edges[2].node&#39;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72069045/how-to-concat-jq-paths-in-each-array",
        "title": "how to concat jq paths in each array"
    },
    {
        "tags": [
            "jq",
            "xonsh"
        ],
        "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": 1651358298,
                "post_id": 72072644,
                "comment_id": 127346953,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25159614,
                    "reputation": 1,
                    "user_id": 19003996,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8a09c66640daddc3b44d375589038bc3?s=256&d=identicon&r=PG",
                    "display_name": "ixemad",
                    "link": "https://stackoverflow.com/users/19003996/ixemad"
                },
                "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": 1651361579,
                "post_id": 72072644,
                "comment_id": 127347368,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651521159,
                "creation_date": 1651521159,
                "answer_id": 72091703,
                "question_id": 72072644,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` is a great tool -- for this particular case with `xonsh`, I&#39;d lean on the `json` module instead, though.\r\nAssuming that `AWS_ASSUMED_ROLE` is some stringified json blob:\r\n```\r\nimport json\r\n\r\nblob = json.loads(AWS_ASSUMED_ROLE)\r\n$AWS_ACCESS_KEY_ID = blob[&quot;Credentials&quot;][&quot;AccessKeyId&quot;]\r\n...\r\n```",
                "title": "How can I efficiently extract variables from JSON with xonsh?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1651521159,
        "creation_date": 1651357800,
        "last_edit_date": 1651358438,
        "question_id": 72072644,
        "body_markdown": "Given a variable `AWS_ASSUMED_ROLE` that contains the output of the `aws sts assume-role` (a JSON string), I can write the following in `bash`.\r\n\r\n```bash\r\nexport AWS_ACCESS_KEY_ID=$( jq -r &#39;.Credentials.AccessKeyId&#39; &lt;&lt;&lt;$AWS_ASSUMED_ROLE )\r\nexport AWS_SECRET_ACCESS_KEY=$( jq -r &#39;.Credentials.SecretAccessKey&#39; &lt;&lt;&lt;$AWS_ASSUMED_ROLE )\r\nexport AWS_SESSION_TOKEN=$( jq -r &#39;.Credentials.SessionToken&#39; &lt;&lt;&lt;$AWS_ASSUMED_ROLE )\r\n\r\naws sts get-caller-identity\r\n```\r\n\r\nHowever, in order to get the same functionality in `xonsh`, I need two `echo` commands. \r\n\r\n```xonsh\r\n$AWS_ACCESS_KEY_ID     = $( echo -n @$( echo @(AWS_ASSUMED_ROLE) | jq -r &#39;.Credentials.AccessKeyId&#39;) )\r\n$AWS_SECRET_ACCESS_KEY = $( echo -n @$( echo @(AWS_ASSUMED_ROLE) | jq -r &#39;.Credentials.SecretAccessKey&#39; ) )\r\n$AWS_SESSION_TOKEN     = $( echo -n @$( echo @(AWS_ASSUMED_ROLE) | jq -r &#39;.Credentials.SessionToken&#39; ) )\r\n\r\naws sts get-caller-identity\r\n```\r\n\r\nThe inner one to provide `jq` with the input data. The outer one to be able to set the corresponding environment variable with a string value without a new line. \r\n\r\nOkay, a little awkward but not too bad. However, is there a better way to do it?",
        "link": "https://stackoverflow.com/questions/72072644/how-can-i-efficiently-extract-variables-from-json-with-xonsh",
        "title": "How can I efficiently extract variables from JSON with xonsh?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1651365039,
                "creation_date": 1651365039,
                "answer_id": 72073167,
                "question_id": 72073109,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Provide `any` with an iterator and a condition\r\n~~~sh\r\njq &#39;any(paths; .[-1] == &quot;headline&quot;)&#39;\r\n~~~\r\n\r\nYou can also provide the `-e` (or `--exit-status`) option to have an exit status of `0` if the result was `true`, and `1` if the result was `false`, which can immediately be used for further processing in the shell.\r\n~~~sh\r\njq -e &#39;any(paths; .[-1] == &quot;headline&quot;)&#39;\r\n~~~\r\n",
                "title": "Use any() to check if certain key exists in JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651365102,
                "creation_date": 1651365102,
                "answer_id": 72073174,
                "question_id": 72073109,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need an intermediate array for that.\r\n```\r\nany(paths[-1]; . == &quot;headline&quot;)\r\n```",
                "title": "Use any() to check if certain key exists in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1651367240,
        "creation_date": 1651364030,
        "last_edit_date": 1651367240,
        "question_id": 72073109,
        "body_markdown": "I want to use jq to check if a keyword exists as a key in a JSON at any level. Here is what I came up with:\r\n\r\n    jq -c &#39;paths | select(.[-1]) as $p| index(&quot;headline&quot;) //empty&#39; news.json\r\nThe output is an array:\r\n\r\n    [\r\n      6,\r\n      7,\r\n      9\r\n    ]\r\n\r\nI want to map the output array to jq function `any()` and get an overall result as true if key exists or false if it doesn&#39;t.\r\n\r\nHow can I get that done with jq ?",
        "link": "https://stackoverflow.com/questions/72073109/use-any-to-check-if-certain-key-exists-in-jq",
        "title": "Use any() to check if certain key exists in JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1651384564,
                "last_edit_date": 1651384564,
                "creation_date": 1651377074,
                "answer_id": 72073858,
                "question_id": 72073540,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`paths` produces a stream, whereas you evidently want an array from which you can easily extract the items of interest.  For example:\r\n\r\n    [paths | select(.[-1] == &quot;headline&quot;)][0:2]\r\n\r\nStream-oriented alternatives are also available, e.g. limit(2; paths ....)",
                "title": "jq select a subset of paths selected"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1651384564,
        "creation_date": 1651371271,
        "question_id": 72073540,
        "body_markdown": "I am getting mutiple array of paths contains keywords &#39;headline&#39; below:&#160;\r\n\r\n    jq -c &#39;paths | select(.[-1] == &quot;headline&quot;)&#39; nytimeseuro.json\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;,&quot;stream&quot;,&quot;edges&quot;,0,&quot;node&quot;,&quot;headline&quot;]\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;,&quot;stream&quot;,&quot;edges&quot;,1,&quot;node&quot;,&quot;headline&quot;]\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;,&quot;stream&quot;,&quot;edges&quot;,2,&quot;node&quot;,&quot;headline&quot;]\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;,&quot;stream&quot;,&quot;edges&quot;,3,&quot;node&quot;,&quot;headline&quot;]\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;,&quot;stream&quot;,&quot;edges&quot;,4,&quot;node&quot;,&quot;headline&quot;]\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;headline&quot;]\r\n\r\nCan I select them based on array index ?\r\nlike Output[0:2] select just \r\n\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;,&quot;stream&quot;,&quot;edges&quot;,0,&quot;node&quot;,&quot;headline&quot;]\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;,&quot;stream&quot;,&quot;edges&quot;,1,&quot;node&quot;,&quot;headline&quot;]\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;,&quot;stream&quot;,&quot;edges&quot;,2,&quot;node&quot;,&quot;headline&quot;]\r\n\r\nOr Output[-1] select just \r\n\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;headline&quot;]\r\n\r\nI tried command below , but that seems not to be what I want, it just sliced **each path** I got, rather than select **subset of all paths** returned:\r\n\r\n    jq -c &#39;paths | select(.[-1] == &quot;headline&quot;)[:3]&#39; nytimeseuro.json\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;]\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;]\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;]\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;]\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;collectionsPage&quot;]\r\n    [&quot;data&quot;,&quot;legacyCollection&quot;,&quot;headline&quot;]\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72073540/jq-select-a-subset-of-paths-selected",
        "title": "jq select a subset of paths selected"
    },
    {
        "tags": [
            "arrays",
            "jq",
            "reduce"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1651453889,
                "last_edit_date": 1651453889,
                "creation_date": 1651376878,
                "answer_id": 72073843,
                "question_id": 72073744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I want a solution without using slurp or inputs.\r\n\r\nUnfortunately, unless you’re willing to invoke jq twice, those are the only two options that jq has to offer, unless you allow `input`. And the same can be said of gojq and jaq.\r\n\r\nIf your input is JSONL (one JSON per line), then there are of course many obvious ways to preprocess the stream to achieve the &quot;slurping&quot; effect. Otherwise, you&#39;d probably want to use a JSON-oriented tool, either to supplement jq, or to use instead.\r\n",
                "title": "Jq Convert multiple string inputs to one larger array without slurp or inputs"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651399142,
                "creation_date": 1651399142,
                "answer_id": 72075709,
                "question_id": 72073744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I wouldn&#39;t consider this a very practical solution but you could switch the scope from the itemwise stream to an enveloping singleton by using a second call to `jq`, and an appropriate encoding for the transition, thus using `-j` and `-R` to write and read a single line of raw text. Technically, this fulfills your requirements (not using `slurp` or `inputs`), but is it worth it?\r\n\r\nOne such way could be to manually build a JSON array from already JSON-encoded parts by adding commas and brackets:\r\n\r\nIn the first instance, encode the items as JSON using `tojson`, and append a comma to each. In the second instance, remove the last character (the superfluous comma), wrap the string in brackets, and decode the ready JSON array using `fromjson`.\r\n\r\n~~~sh\r\njq -j &#39;&quot;key:\\(.key)&quot;, &quot;value:\\(.value)&quot; | &quot;\\(tojson),&quot;&#39; | jq -R &#39;&quot;[\\(.[:-1])]&quot; | fromjson&#39;\r\n~~~\r\n~~~json\r\n[\r\n  &quot;key:state&quot;,\r\n  &quot;value:pending&quot;,\r\n  &quot;key:options&quot;,\r\n  &quot;value:request&quot;\r\n]\r\n~~~\r\n\r\n",
                "title": "Jq Convert multiple string inputs to one larger array without slurp or inputs"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651406209,
                "creation_date": 1651406209,
                "answer_id": 72076460,
                "question_id": 72073744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you can use `--null-input` and `input` :\r\n\r\n```\r\n#!/usr/bin/env bash \r\n  \r\njq --null-input &#39;\r\ndef loop:\r\n    .+(input|[&quot;key:\\(.key)&quot;, &quot;value:\\(.value)&quot;]) |\r\n    . as $res |\r\n    try loop catch $res ;\r\nloop\r\n&#39; &lt;&lt; EOF\r\n{&quot;key&quot;:&quot;state&quot;,&quot;value&quot;:&quot;pending&quot;}\r\n{&quot;key&quot;:&quot;options&quot;,&quot;value&quot;:&quot;request&quot;}\r\nEOF\r\n```\r\n\r\noutput:\r\n\r\n```\r\n[\r\n  &quot;key:state&quot;,\r\n  &quot;value:pending&quot;,\r\n  &quot;key:options&quot;,\r\n  &quot;value:request&quot;\r\n]\r\n```",
                "title": "Jq Convert multiple string inputs to one larger array without slurp or inputs"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651454205,
                "last_edit_date": 1651454205,
                "creation_date": 1651452401,
                "answer_id": 72081428,
                "question_id": 72073744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just an elaboration on Philippe&#39;s answer.\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/C_C-xudpVQ\r\n\r\nFilter\r\n```\r\ndef to_array: .+[input] | . as $acc | try to_array catch $acc; to_array\r\n```\r\n\r\nInput\r\n```\r\n&quot;foo is bar&quot;\r\n&quot;goo is google&quot;\r\n&quot;stack is over&quot;\r\n&quot;over is flow&quot;\r\n```\r\n\r\nOutput\r\n```\r\n[\r\n  &quot;foo is bar&quot;,\r\n  &quot;goo is google&quot;,\r\n  &quot;stack is over&quot;,\r\n  &quot;over is flow&quot;\r\n]\r\n```\r\n\r\nIn `to_array` function, on *each* iteration we add an `input` to a single array and save to `$acc` (aka &#39;accumulated&#39;) , until **there is no more `input`**, in which case we output the `$acc` up to that point (since `try` will fail in that case this will execute `catch` exp).",
                "title": "Jq Convert multiple string inputs to one larger array without slurp or inputs"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": -1,
        "last_activity_date": 1651454205,
        "creation_date": 1651374845,
        "question_id": 72073744,
        "body_markdown": "I have:\r\n\r\nFilter:\r\n```\r\n[&quot;key:\\(.key)&quot;, &quot;value:\\(.value)&quot;][]\r\n```\r\n\r\nInput:\r\n```\r\n{&quot;key&quot;:&quot;state&quot;,&quot;value&quot;:&quot;pending&quot;}\r\n{&quot;key&quot;:&quot;options&quot;,&quot;value&quot;:&quot;request&quot;}\r\n```\r\n\r\nOutput:\r\n```\r\n&quot;key:state&quot;\r\n&quot;value:pending&quot;\r\n&quot;key:options&quot;\r\n&quot;value:request&quot;\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/9yq89orzL0\r\n\r\nI want to convert the output `&quot;key:state&quot; &quot;value:pending&quot; &quot;key:options&quot; &quot;value:request&quot;` to array `[&quot;key:state&quot;, &quot;value:pending&quot;, &quot;key:options&quot;, &quot;value:request&quot;]`.\r\n\r\nI tried `reduce . as $s ([]; .+[$s])` but this gives `[&quot;key:state&quot;] [&quot;value:pending&quot;] [&quot;key:options&quot;] [&quot;value:request&quot;]`.\r\n\r\nI want a solution *without* using `slurp` or `inputs`.\r\n\r\nThanks.",
        "link": "https://stackoverflow.com/questions/72073744/jq-convert-multiple-string-inputs-to-one-larger-array-without-slurp-or-inputs",
        "title": "Jq Convert multiple string inputs to one larger array without slurp or inputs"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1651408618,
                "creation_date": 1651408618,
                "answer_id": 72076774,
                "question_id": 72076678,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just index `entries` by `index` minus one?\r\n```\r\n.entries[.index - 1]\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/zKQZpEpgT9)&lt;/sup&gt;",
                "title": "Get array item by 1-indexed value in another field"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1658745732,
                "creation_date": 1658745732,
                "answer_id": 73107883,
                "question_id": 72076678,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The last item in entries is not necessarily the tab that was opened. [.index - 1] only works if user_pref(&quot;browser.sessionstore.max_serialize_forward&quot;, 0); cf. [https://wiki.mozilla.org/Firefox/session_restore#Browser_settings][1]\r\n\r\n\r\n  [1]: https://wiki.mozilla.org/Firefox/session_restore#Browser_settings",
                "title": "Get array item by 1-indexed value in another field"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1658745732,
        "creation_date": 1651407880,
        "last_edit_date": 1651409493,
        "question_id": 72076678,
        "body_markdown": "The Firefox file `sessionstore-backups/recovery.jsonlz4` contains information about the current Firefox windows in (compressed) JSON format. This is a simplified format representative of that file:\r\n\r\n``` json\r\n{\r\n  &quot;index&quot;: 2,\r\n  &quot;entries&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;Foo bar 0&quot;,\r\n      &quot;url&quot;: &quot;https://example.com/bar&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;Foo bar 1&quot;,\r\n      &quot;url&quot;: &quot;https://example.com/bar&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;Foo bar 2&quot;,\r\n      &quot;url&quot;: &quot;https://example.com/bar&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThe `index` field represents the currently-displayed history item per tab. Being 1-indexed, in the example above it represents the &quot;Foo bar 1&quot; entry.\r\n\r\n**How can I use that value in `jq` to get that tab?**\r\n\r\nFor testing on your own system, the following bash line will get you to this point on most modern Linux systems:\r\n\r\n```\r\nlz4jsoncat ~/.mozilla/firefox/t6e99qbe.default-release/sessionstore-backups/recovery.jsonlz4 | jq &#39;.windows[0].tabs&#39; | jq &#39;sort_by(.lastAccessed)[-1]&#39;\r\n```\r\n\r\nThis returns the most recent tab, but with all history items in the `entries` array. As the user could have navigated back in the history, we need the `index` value to determine which entry to return. Piped through `gron`, it looks like this:\r\n```\r\njson = {};\r\njson.attributes = {};\r\njson.entries = [];\r\njson.entries[0] = {};\r\njson.entries[0].ID = 504;\r\njson.entries[0].cacheKey = 0;\r\njson.entries[0].docIdentifier = 586;\r\njson.entries[0].docshellUUID = &quot;{b6c1e18a-d0f5-4ba2-996e-ddd9fc28322a}&quot;;\r\njson.entries[0].hasUserInteraction = true;\r\njson.entries[0].persist = true;\r\njson.entries[0].principalToInherit_base64 = &quot;eyIxIjp7IjAiOiJtb3otZXh0ZW5zaW9uOi8vOTAzYWU2NDgtMzRlNi00NGQ3LTg0NjYtYzgxMWQyMTg2YjBkLyJ9fQ==&quot;;\r\njson.entries[0].resultPrincipalURI = null;\r\njson.entries[0].title = &quot;Tridactyl Top Tips &amp; New Tab Page&quot;;\r\njson.entries[0].triggeringPrincipal_base64 = &quot;eyIxIjp7IjAiOiJtb3otZXh0ZW5zaW9uOi8vOTAzYWU2NDgtMzRlNi00NGQ3LTg0NjYtYzgxMWQyMTg2YjBkLyJ9fQ==&quot;;\r\njson.entries[0].url = &quot;moz-extension://7ba85bcd-8d63-4e74-a723-e627a31d6274/static/newtab.html&quot;;\r\njson.entries[1] = {};\r\njson.entries[1].ID = 506;\r\njson.entries[1].cacheKey = 0;\r\njson.entries[1].docIdentifier = 588;\r\njson.entries[1].docshellUUID = &quot;{b6c1e18a-d0f5-4ba2-996e-ddd9fc28322a}&quot;;\r\njson.entries[1].hasUserInteraction = true;\r\njson.entries[1].persist = true;\r\njson.entries[1].referrerInfo = &quot;BBoSnxDOS9qmDeAnom1e0AAAAAAAAAAAwAAAAAAAAEYAAAAAAAEBAAAAAAEA&quot;;\r\njson.entries[1].resultPrincipalURI = null;\r\njson.entries[1].title = &quot;Stack Overflow - Where Developers Learn, Share, &amp; Build Careers&quot;;\r\njson.entries[1].triggeringPrincipal_base64 = &quot;eyIzIjp7fX0=&quot;;\r\njson.entries[1].url = &quot;https://stackoverflow.com/&quot;;\r\njson.entries[2] = {};\r\njson.entries[2].ID = 508;\r\njson.entries[2].cacheKey = 0;\r\njson.entries[2].csp = &quot;CdntGuXUQAS/4CfOuSPZrAAAAAAAAAAAwAAAAAAAAEYB3pRy0IA0EdOTmQAQS6D9QJIHOlRteE8wkTq4cYEyCMYAAAAC/////wAAAbsBAAAAGmh0dHBzOi8vc3RhY2tvdmVyZmxvdy5jb20vAAAAAAAAAAUAAAAIAAAAEQAAAAj/////AAAACP////8AAAAIAAAAEQAAABkAAAABAAAAGQAAAAEAAAAZAAAAAQAAABoAAAAAAAAAGv////8AAAAA/////wAAABn/////AAAAGf////8BAAAAAAAAAAAAKHsiMSI6eyIwIjoiaHR0cHM6Ly9zdGFja292ZXJmbG93LmNvbS8ifX0AAAABAAAASwB1AHAAZwByAGEAZABlAC0AaQBuAHMAZQBjAHUAcgBlAC0AcgBlAHEAdQBlAHMAdABzADsAIABmAHIAYQBtAGUALQBhAG4AYwBlAHMAdABvAHIAcwAgACcAcwBlAGwAZgAnACAAaAB0AHQAcABzADoALwAvAHMAdABhAGMAawBlAHgAYwBoAGEAbgBnAGUALgBjAG8AbQAA&quot;;\r\njson.entries[2].docIdentifier = 590;\r\njson.entries[2].docshellUUID = &quot;{b6c1e18a-d0f5-4ba2-996e-ddd9fc28322a}&quot;;\r\njson.entries[2].hasUserInteraction = true;\r\njson.entries[2].persist = true;\r\njson.entries[2].principalToInherit_base64 = &quot;eyIxIjp7IjAiOiJodHRwczovL3N0YWNrb3ZlcmZsb3cuY29tLyJ9fQ==&quot;;\r\njson.entries[2].referrerInfo = &quot;BBoSnxDOS9qmDeAnom1e0AAAAAAAAAAAwAAAAAAAAEYBAAAAGmh0dHBzOi8vc3RhY2tvdmVyZmxvdy5jb20vAAAACAEBAAAAGmh0dHBzOi8vc3RhY2tvdmVyZmxvdy5jb20vAQE=&quot;;\r\njson.entries[2].resultPrincipalURI = null;\r\njson.entries[2].title = &quot;Highest scored questions - Stack Overflow&quot;;\r\njson.entries[2].triggeringPrincipal_base64 = &quot;eyIxIjp7IjAiOiJodHRwczovL3N0YWNrb3ZlcmZsb3cuY29tLyJ9fQ==&quot;;\r\njson.entries[2].url = &quot;https://stackoverflow.com/questions&quot;;\r\njson.entries[3] = {};\r\njson.entries[3].ID = 510;\r\njson.entries[3].cacheKey = 0;\r\njson.entries[3].csp = &quot;CdntGuXUQAS/4CfOuSPZrAAAAAAAAAAAwAAAAAAAAEYB3pRy0IA0EdOTmQAQS6D9QJIHOlRteE8wkTq4cYEyCMYAAAAC/////wAAAbsBAAAAI2h0dHBzOi8vc3RhY2tvdmVyZmxvdy5jb20vcXVlc3Rpb25zAAAAAAAAAAUAAAAIAAAAEQAAAAj/////AAAACP////8AAAAIAAAAEQAAABkAAAAKAAAAGQAAAAoAAAAZAAAAAQAAABoAAAAJAAAAGv////8AAAAA/////wAAABn/////AAAAGf////8BAAAAAAAAAAAAMXsiMSI6eyIwIjoiaHR0cHM6Ly9zdGFja292ZXJmbG93LmNvbS9xdWVzdGlvbnMifX0AAAABAAAASwB1AHAAZwByAGEAZABlAC0AaQBuAHMAZQBjAHUAcgBlAC0AcgBlAHEAdQBlAHMAdABzADsAIABmAHIAYQBtAGUALQBhAG4AYwBlAHMAdABvAHIAcwAgACcAcwBlAGwAZgAnACAAaAB0AHQAcABzADoALwAvAHMAdABhAGMAawBlAHgAYwBoAGEAbgBnAGUALgBjAG8AbQAA&quot;;\r\njson.entries[3].docIdentifier = 592;\r\njson.entries[3].docshellUUID = &quot;{b6c1e18a-d0f5-4ba2-996e-ddd9fc28322a}&quot;;\r\njson.entries[3].hasUserInteraction = true;\r\njson.entries[3].persist = true;\r\njson.entries[3].principalToInherit_base64 = &quot;eyIxIjp7IjAiOiJodHRwczovL3N0YWNrb3ZlcmZsb3cuY29tL3F1ZXN0aW9ucyJ9fQ==&quot;;\r\njson.entries[3].referrerInfo = &quot;BBoSnxDOS9qmDeAnom1e0AAAAAAAAAAAwAAAAAAAAEYBAAAAI2h0dHBzOi8vc3RhY2tvdmVyZmxvdy5jb20vcXVlc3Rpb25zAAAACAEBAAAAI2h0dHBzOi8vc3RhY2tvdmVyZmxvdy5jb20vcXVlc3Rpb25zAQE=&quot;;\r\njson.entries[3].resultPrincipalURI = null;\r\njson.entries[3].title = &quot;Tags - Stack Overflow&quot;;\r\njson.entries[3].triggeringPrincipal_base64 = &quot;eyIxIjp7IjAiOiJodHRwczovL3N0YWNrb3ZlcmZsb3cuY29tL3F1ZXN0aW9ucyJ9fQ==&quot;;\r\njson.entries[3].url = &quot;https://stackoverflow.com/tags&quot;;\r\njson.entries[4] = {};\r\njson.entries[4].ID = 512;\r\njson.entries[4].cacheKey = 0;\r\njson.entries[4].csp = &quot;CdntGuXUQAS/4CfOuSPZrAAAAAAAAAAAwAAAAAAAAEYB3pRy0IA0EdOTmQAQS6D9QJIHOlRteE8wkTq4cYEyCMYAAAAC/////wAAAbsBAAAAHmh0dHBzOi8vc3RhY2tvdmVyZmxvdy5jb20vdGFncwAAAAAAAAAFAAAACAAAABEAAAAI/////wAAAAj/////AAAACAAAABEAAAAZAAAABQAAABkAAAAFAAAAGQAAAAEAAAAaAAAABAAAABr/////AAAAAP////8AAAAZ/////wAAABn/////AQAAAAAAAAAAACx7IjEiOnsiMCI6Imh0dHBzOi8vc3RhY2tvdmVyZmxvdy5jb20vdGFncyJ9fQAAAAEAAABLAHUAcABnAHIAYQBkAGUALQBpAG4AcwBlAGMAdQByAGUALQByAGUAcQB1AGUAcwB0AHMAOwAgAGYAcgBhAG0AZQAtAGEAbgBjAGUAcwB0AG8AcgBzACAAJwBzAGUAbABmACcAIABoAHQAdABwAHMAOgAvAC8AcwB0AGEAYwBrAGUAeABjAGgAYQBuAGcAZQAuAGMAbwBtAAA=&quot;;\r\njson.entries[4].docIdentifier = 594;\r\njson.entries[4].docshellUUID = &quot;{b6c1e18a-d0f5-4ba2-996e-ddd9fc28322a}&quot;;\r\njson.entries[4].hasUserInteraction = false;\r\njson.entries[4].persist = true;\r\njson.entries[4].principalToInherit_base64 = &quot;eyIxIjp7IjAiOiJodHRwczovL3N0YWNrb3ZlcmZsb3cuY29tL3RhZ3MifX0=&quot;;\r\njson.entries[4].referrerInfo = &quot;BBoSnxDOS9qmDeAnom1e0AAAAAAAAAAAwAAAAAAAAEYBAAAAHmh0dHBzOi8vc3RhY2tvdmVyZmxvdy5jb20vdGFncwAAAAgBAQAAAB5odHRwczovL3N0YWNrb3ZlcmZsb3cuY29tL3RhZ3MBAQ==&quot;;\r\njson.entries[4].resultPrincipalURI = null;\r\njson.entries[4].title = &quot;Users - Stack Overflow&quot;;\r\njson.entries[4].triggeringPrincipal_base64 = &quot;eyIxIjp7IjAiOiJodHRwczovL3N0YWNrb3ZlcmZsb3cuY29tL3RhZ3MifX0=&quot;;\r\njson.entries[4].url = &quot;https://stackoverflow.com/users&quot;;\r\njson.hidden = false;\r\njson.index = 3;\r\njson.lastAccessed = 1651407567904;\r\njson.requestedIndex = 0;\r\njson.searchMode = null;\r\njson.userContextId = 0\r\n```",
        "link": "https://stackoverflow.com/questions/72076678/get-array-item-by-1-indexed-value-in-another-field",
        "title": "Get array item by 1-indexed value in another field"
    },
    {
        "tags": [
            "arrays",
            "json",
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651415539,
                "creation_date": 1651415539,
                "answer_id": 72077618,
                "question_id": 72077342,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can parameterize `sort_by` by a list of keys like so:\r\n```\r\nsort_by(.subscriptionId, .subscrCond.serviceName)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/ASRVUqCkJM)&lt;/sup&gt;",
                "title": "Sort array by two fields in different levels"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1651466054,
        "creation_date": 1651413293,
        "last_edit_date": 1651466054,
        "question_id": 72077342,
        "body_markdown": "My input:\r\n\r\n    [\r\n      {\r\n        &quot;nfStatusNotificationUri&quot;: &quot;http://172.19.0.2:32672/callback/nnrf-nfm/v1/onNFStatusEventPost/4e0becf9-c3ec-4002-a32b-2e35b76469b2&quot;,\r\n        &quot;subscrCond&quot;: {\r\n          &quot;serviceName&quot;: &quot;namf-evts&quot;\r\n        },\r\n        &quot;subscriptionId&quot;: &quot;36bc52dfdbdd4044b97ef15684706205&quot;,\r\n        &quot;validityTime&quot;: &quot;2022-04-30T16:40:48.274Z&quot;,\r\n        &quot;reqNotifEvents&quot;: [\r\n          &quot;NF_DEREGISTERED&quot;,\r\n          &quot;NF_PROFILE_CHANGED&quot;,\r\n          &quot;NF_REGISTERED&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;nfStatusNotificationUri&quot;: &quot;http://172.19.0.2:32672/callback/nnrf-nfm/v1/onNFStatusEventPost/5319def1-af0b-4b7b-a94e-b787e614c065&quot;,\r\n        &quot;subscrCond&quot;: {\r\n          &quot;serviceName&quot;: &quot;nbsf-management&quot;\r\n        },\r\n        &quot;subscriptionId&quot;: &quot;e2e904bb52ca4fd6b048841c83a4c38e&quot;,\r\n        &quot;validityTime&quot;: &quot;2022-04-30T16:40:48.26Z&quot;,\r\n        &quot;reqNotifEvents&quot;: [\r\n          &quot;NF_DEREGISTERED&quot;,\r\n          &quot;NF_PROFILE_CHANGED&quot;,\r\n          &quot;NF_REGISTERED&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;nfStatusNotificationUri&quot;: &quot;http://172.19.0.2:32672/callback/nnrf-nfm/v1/onNFStatusEventPost/31dfe10b-4020-47bd-943e-a3e293086b29&quot;,\r\n        &quot;subscrCond&quot;: {\r\n          &quot;serviceName&quot;: &quot;namf-comm&quot;\r\n        },\r\n        &quot;subscriptionId&quot;: &quot;e508077fab4f4b8d9dd732176a3777b9&quot;,\r\n        &quot;validityTime&quot;: &quot;2022-04-30T16:40:48.273Z&quot;,\r\n        &quot;reqNotifEvents&quot;: [\r\n          &quot;NF_DEREGISTERED&quot;,\r\n          &quot;NF_PROFILE_CHANGED&quot;,\r\n          &quot;NF_REGISTERED&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nI would like to sort it by `&quot;subscriptionId&quot;` and `&quot;serviceName&quot;`.\r\n\r\nI can sort by `subscriptionId` but I don&#39;t know how to specify `serviceName` to the following expression.\r\n\r\n    jq -S &#39;.|=sort_by(.subscriptionId)|.[].reqNotifEvents|=sort |del(.[].subscriptionId, .[].validityTime, .[].nfStatusNotificationUri)&#39;",
        "link": "https://stackoverflow.com/questions/72077342/sort-array-by-two-fields-in-different-levels",
        "title": "Sort array by two fields in different levels"
    },
    {
        "tags": [
            "regex",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1651443732,
                "post_id": 72080532,
                "comment_id": 127360942,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25167198,
                    "reputation": 49,
                    "user_id": 19010563,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GgM6plUBmn9TWvD34eOKYwFE48gUFqIyoKFh2kxLQ=k-s256",
                    "display_name": "Victor Barros",
                    "link": "https://stackoverflow.com/users/19010563/victor-barros"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1651508384,
                "post_id": 72080532,
                "comment_id": 127375801,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1697097397,
                "last_edit_date": 1697097397,
                "creation_date": 1651440684,
                "answer_id": 72080557,
                "question_id": 72080532,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.version|scan(&quot;^[^-]+&quot;)\r\n```\r\n\r\nor\r\n\r\n```\r\n.version|scan(&quot;^[0-9.]+&quot;)\r\n```\r\n\r\nDon&#39;t overcomplicate it ;)\r\n\r\nCall jq with flag `-r` for _raw output_, that is without quotation marks around strings.",
                "title": "Using JQ and regex to extract just matching regex string"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664622958,
                "last_edit_date": 1664622958,
                "creation_date": 1651440995,
                "answer_id": 72080586,
                "question_id": 72080532,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can split on the hyphen and then take the first element:\r\n\r\n    .version|split(&quot;-&quot;)|first\r\n\r\nor\r\n\r\n    .version/&quot;-&quot;|first\r\n\r\n(`/` on strings is equivalent to calling split)\r\n\r\nCall jq with flag `-r` for _raw output_, that is without quotation marks around strings.",
                "title": "Using JQ and regex to extract just matching regex string"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1651471163,
                "last_edit_date": 1651471163,
                "creation_date": 1651441454,
                "answer_id": 72080632,
                "question_id": 72080532,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yet you can use **capture** through **`[[:digit:].]+`** pattern\r\n```\r\njq -r &#39;.version| capture(&quot;(?&lt;v&gt;[[:digit:].]+)&quot;).v&#39;\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/4RzWDxKxqL)&lt;/kbd&gt;",
                "title": "Using JQ and regex to extract just matching regex string"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1697097397,
        "creation_date": 1651440441,
        "question_id": 72080532,
        "body_markdown": "I have the following input json which I obtain from a curl command and I&#39;m feeding it to jq.\r\n\r\n```\r\n{\r\n  &quot;version&quot;: &quot;14.10.0-ee&quot;,\r\n  &quot;revision&quot;: &quot;ad109bc62af&quot;\r\n}\r\n```\r\n\r\nI&#39;m trying to use jq to extract just &#39;14.10.0&#39;.\r\n\r\nI have the following jq command but it&#39;s just returning &quot;14.10.0-ee&quot;\r\n```\r\njq &#39;. | select(.version|capture(&quot;^[0-9]{1,}.[0-9]{1,}.[0-9]{1,}&quot;)).version&#39;\r\n```\r\n\r\nI&#39;ve looked at the jq documentation [here](https://stedolan.github.io/jq/manual/#RegularexpressionsPCRE) and I&#39;m not able to figure the correct syntax.\r\nI&#39;ve tried scan, capture, and match without success.\r\n\r\nI am able to achieve what I want if I pipe the result to grep but I would prefer to do it all in one command.\r\n\r\nAny help would be greatly appreciated.",
        "link": "https://stackoverflow.com/questions/72080532/using-jq-and-regex-to-extract-just-matching-regex-string",
        "title": "Using JQ and regex to extract just matching regex string"
    },
    {
        "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": 1651457373,
                "post_id": 72081662,
                "comment_id": 127362516,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5790510,
                    "reputation": 2601,
                    "user_id": 4568140,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Fbkef.jpg?s=256",
                    "display_name": "Jia",
                    "link": "https://stackoverflow.com/users/4568140/jia"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1651458386,
                "post_id": 72081662,
                "comment_id": 127362608,
                "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": 1651464464,
                "post_id": 72081662,
                "comment_id": 127363324,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651465986,
                "last_edit_date": 1651465986,
                "creation_date": 1651464695,
                "answer_id": 72082241,
                "question_id": 72081662,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way to make the selection while ensuring that the structure is preserved. This solution may be of interest because\r\nit can easily be adapted for use with jq&#39;s &quot;--stream&quot; option.\r\n```\r\ndef array_startswith($head): .[: $head|length] == $head;\r\n\r\n. as $in\r\n| [&quot;data&quot;, &quot;legacyCollection&quot;, &quot;collectionsPage&quot;, &quot;stream&quot;, &quot;edges&quot;] as $head\r\n| ($head|length) as $len\r\n| reduce (paths\r\n          | select( array_startswith($head) and .[1+$len] == &quot;node&quot; )) as $p\r\n    (null;\r\n     if ((($p|length) == $len + 3) and ($p[-1] | IN(&quot;url&quot;, &quot;firstPublished&quot;)))\r\n        or ((($p|length) == $len + 4) and $p[-2:] == [&quot;headline&quot;, &quot;default&quot;])\r\n     then setpath($p; $in | getpath($p))\r\n     else .\r\n     end)\r\n```",
                "title": "extract a subset of deep embed json and print only key,value pair I am interested in the subset json"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1651466897,
                "last_edit_date": 1651466897,
                "creation_date": 1651465555,
                "answer_id": 72082298,
                "question_id": 72081662,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a (somewhat) declarative solution:\r\n```\r\n(.data.legacyCollection.collectionsPage.stream.edges\r\n | map( {node: (.node\r\n                | {url,\r\n                   firstPublished,\r\n\t\t           headline: {default: .headline.default} })})) as $edges\r\n| {data: {\r\n     legacyCollection: {\r\n       collectionsPage: {\r\n         stream: {\r\n           $edges\r\n         }\r\n       }\r\n     }\r\n   }\r\n  }\r\n```",
                "title": "extract a subset of deep embed json and print only key,value pair I am interested in the subset json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1651466897,
        "creation_date": 1651456366,
        "last_edit_date": 1651458321,
        "question_id": 72081662,
        "body_markdown": "I have a deep embeded json file:\r\nI want to extract and parse only the subset I am interested in , in my case all content in &#39;node&#39; key.\r\nHow can I:\r\n1) extract subset of this json file which contains `&quot;edges[].node&quot;` (edges is the &#39;parent&#39; key of node) \r\n2) in `&#39;node&#39;` session , I am interested in key:value pair of \r\n\r\n       .url,\r\n       .headline.default, (*this one is &#39;grandchild&#39; of key &#39;node&#39;*)\r\n       .firstPublished\r\n\r\n   I want to keep **only above 3 item inside &#39;node&#39; key**\r\nHow can I print out the super slim version of json file I need ?\r\n3) a better to have option is : can I still keep the **structure/full path** which leads json root key to embed &#39;node&#39; json subset I am interested in ?\r\n\r\n&gt; Here is the [jqplay-myjson][1] (**full content of my json file**)\r\n\r\nTry to attach my full content here :\r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;legacyCollection&quot;: {\r\n          &quot;longDescription&quot;: &quot;The latest news, analysis and investigations from Europe.&quot;,\r\n          &quot;section&quot;: {\r\n            &quot;name&quot;: &quot;world&quot;,\r\n            &quot;url&quot;: &quot;/section/world&quot;\r\n          },\r\n          &quot;collectionsPage&quot;: {\r\n            &quot;stream&quot;: {\r\n              &quot;pageInfo&quot;: {\r\n                &quot;hasNextPage&quot;: true,\r\n                &quot;__typename&quot;: &quot;PageInfo&quot;\r\n              },\r\n              &quot;__typename&quot;: &quot;AssetsConnection&quot;,\r\n              &quot;edges&quot;: [\r\n                {\r\n                  &quot;node&quot;: {\r\n                    &quot;url&quot;: &quot;https://www.nytimes.com/video/world/europe/100000008323381/icc-war-crimes-ukraine.html&quot;,\r\n                    &quot;firstPublished&quot;: &quot;2022-04-27T23:28:33.241Z&quot;,\r\n                    &quot;headline&quot;: {\r\n                      &quot;default&quot;: &quot;I.C.C. Joins Investigation of War Crimes in Ukraine&quot;,\r\n                      &quot;__typename&quot;: &quot;CreativeWorkHeadline&quot;\r\n                    },\r\n                    &quot;summary&quot;: &quot;Karim Khan, the chief prosecutor of the International Criminal Court, said that his organization would participate in a joint effort — with Ukraine, Poland and Lithuania — to investigate war crimes committed since Russia’s invasion.&quot;,\r\n                    &quot;promotionalMedia&quot;: {\r\n                      &quot;__typename&quot;: &quot;Image&quot;,\r\n                      &quot;id&quot;: &quot;SW1hZ2U6bnl0Oi8vaW1hZ2UvYTY3MTVhNDUtZDE0NS01OWZjLThkZWItNzYxMWViN2UyODhk&quot;\r\n                    },\r\n                    &quot;embedded&quot;: false\r\n                  },\r\n                  &quot;__typename&quot;: &quot;AssetsEdge&quot;\r\n                },\r\n                {\r\n                  &quot;node&quot;: {\r\n                    &quot;__typename&quot;: &quot;Article&quot;,\r\n                    &quot;url&quot;: &quot;https://www.nytimes.com/2022/04/27/sports/soccer/chelsea-sale-roman-abramovich.html&quot;,\r\n                    &quot;firstPublished&quot;: &quot;2022-04-27T19:42:17.000Z&quot;,\r\n                    &quot;typeOfMaterials&quot;: [\r\n                      &quot;News&quot;\r\n                    ],\r\n                    &quot;archiveProperties&quot;: {\r\n                      &quot;lede&quot;: &quot;&quot;,\r\n                      &quot;__typename&quot;: &quot;ArticleArchiveProperties&quot;\r\n                    },\r\n                    &quot;headline&quot;: {\r\n                      &quot;default&quot;: &quot;Endgame Nears in Bidding for Chelsea F.C.&quot;,\r\n                      &quot;__typename&quot;: &quot;CreativeWorkHeadline&quot;\r\n                    },\r\n                    &quot;summary&quot;: &quot;The American bank selling the English soccer team on behalf of its Russian owner could name its preferred suitor by the end of the week. But the drama isn’t over.&quot;,\r\n                    &quot;translations&quot;: []\r\n                  },\r\n                  &quot;__typename&quot;: &quot;AssetsEdge&quot;\r\n                }\r\n              ],\r\n              &quot;totalCount&quot;: 52559\r\n            }\r\n          },\r\n          &quot;sourceId&quot;: &quot;100000004047788&quot;,\r\n          &quot;tagline&quot;: &quot;&quot;,\r\n          &quot;__typename&quot;: &quot;LegacyCollection&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nHere is the command I have [jqplay Demo][2]:\r\n\r\n    .data.legacyCollection.collectionsPage.stream.edges[].node|= with_entries(select([.key]|inside([&quot;default&quot;,&quot;url&quot;,&quot;firstPublished&quot;]))\r\nAnd here is the output I got \r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;legacyCollection&quot;: {\r\n          &quot;longDescription&quot;: &quot;The latest news, analysis and investigations from Europe.&quot;,\r\n          &quot;section&quot;: {\r\n            &quot;name&quot;: &quot;world&quot;,\r\n            &quot;url&quot;: &quot;/section/world&quot;\r\n          },\r\n          &quot;collectionsPage&quot;: {\r\n            &quot;stream&quot;: {\r\n              &quot;pageInfo&quot;: {\r\n                &quot;hasNextPage&quot;: true,\r\n                &quot;__typename&quot;: &quot;PageInfo&quot;\r\n              },\r\n              &quot;__typename&quot;: &quot;AssetsConnection&quot;,\r\n              &quot;edges&quot;: [\r\n                {\r\n                  &quot;node&quot;: {\r\n                    &quot;url&quot;: &quot;https://www.nytimes.com/video/world/europe/100000008323381/icc-war-crimes-ukraine.html&quot;,\r\n                    &quot;firstPublished&quot;: &quot;2022-04-27T23:28:33.241Z&quot;\r\n                  },\r\n                  &quot;__typename&quot;: &quot;AssetsEdge&quot;\r\n                },\r\n                {\r\n                  &quot;node&quot;: {\r\n                    &quot;url&quot;: &quot;https://www.nytimes.com/2022/04/27/sports/soccer/chelsea-sale-roman-abramovich.html&quot;,\r\n                    &quot;firstPublished&quot;: &quot;2022-04-27T19:42:17.000Z&quot;\r\n                  },\r\n                  &quot;__typename&quot;: &quot;AssetsEdge&quot;\r\n                }\r\n              ],\r\n              &quot;totalCount&quot;: 52559\r\n            }\r\n          },\r\n          &quot;sourceId&quot;: &quot;100000004047788&quot;,\r\n          &quot;tagline&quot;: &quot;&quot;,\r\n          &quot;__typename&quot;: &quot;LegacyCollection&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nHere is the output I **expect to have** \r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;legacyCollection&quot;: {\r\n          &quot;collectionsPage&quot;: {\r\n            &quot;stream&quot;: {\r\n              &quot;edges&quot;: [\r\n                {\r\n                  &quot;node&quot;: {\r\n                    &quot;url&quot;: &quot;https://www.nytimes.com/video/world/europe/100000008323381/icc-war-crimes-ukraine.html&quot;,\r\n                    &quot;firstPublished&quot;: &quot;2022-04-27T23:28:33.241Z&quot;\r\n                  }\r\n                },\r\n                {\r\n                  &quot;node&quot;: {\r\n                    &quot;url&quot;: &quot;https://www.nytimes.com/2022/04/27/sports/soccer/chelsea-sale-roman-abramovich.html&quot;,\r\n                    &quot;firstPublished&quot;: &quot;2022-04-27T19:42:17.000Z&quot;\r\n                  }\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n\r\n  [1]: https://jqplay.org/s/gSpv_jEDbh\r\n  [2]: https://jqplay.org/s/m4mofOjUU_",
        "link": "https://stackoverflow.com/questions/72081662/extract-a-subset-of-deep-embed-json-and-print-only-key-value-pair-i-am-intereste",
        "title": "extract a subset of deep embed json and print only key,value pair I am interested in the subset json"
    },
    {
        "tags": [
            "json",
            "bigdata",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651604162,
                "last_edit_date": 1651604162,
                "creation_date": 1651603122,
                "answer_id": 72104000,
                "question_id": 72099320,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This works for the sample input:\r\n``` shell\r\njq --null-input --raw-output --stream &#39;label $out | inputs | if .[0][0] == &quot;0001&quot; then (if length == 2 then .[1] else break $out end) else empty end&#39; file\r\n```",
                "title": "JQ stop after the first match"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651603975,
                "creation_date": 1651603975,
                "answer_id": 72104149,
                "question_id": 72099320,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If it is known beforehand that the relevant key is the first one in the JSON object, then the solution using --stream and `first/1` as given by @pmf is applicable; otherwise, it could be adapted as follows:\r\n```\r\njq --stream -n &#39;first(fromstream(1 | truncate_stream(inputs|select(.[0][0] ==&quot;0001&quot;))))[]&#39; input.json\r\n```",
                "title": "JQ stop after the first match"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1651606310,
        "creation_date": 1651580531,
        "last_edit_date": 1651606310,
        "question_id": 72099320,
        "body_markdown": "I have a large file (about 500 megabytes) and the data in it is in JSON format.\r\n```\r\n{\r\n    &quot;0001&quot;: [\r\n        &quot;aaaaa&quot;,\r\n        &quot;qqqqq&quot;\r\n    ],\r\n    &quot;0002&quot;: [\r\n        &quot;aaaaa&quot;\r\n    ],\r\n    &quot;0003&quot;: [\r\n        &quot;ccccc&quot;\r\n    ],\r\n    &quot;0004&quot;: [\r\n        &quot;bbbbb&quot;\r\n    ]\r\n...\r\n}\r\n```\r\nI need to extract from it:\r\n```\r\naaaaa\r\nqqqqq\r\n```\r\nAt the moment and I do the following `jq -r &#39;try . &quot;0001&quot; | .[]&#39; ./1.txt`, it works, but the problem is that it takes a very long time because the search continues on through the whole file, instead of stopping immediately after the first match.\r\n\r\nPlease advise me a way to stop further scouting if an input has already been found. I know that there is a `first(inputs | )`, but I don&#39;t understand how to implements this command.",
        "link": "https://stackoverflow.com/questions/72099320/jq-stop-after-the-first-match",
        "title": "JQ stop after the first match"
    },
    {
        "tags": [
            "json",
            "properties",
            "internationalization",
            "jq",
            "converters"
        ],
        "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": 1651627752,
                "post_id": 72106960,
                "comment_id": 127406844,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651642921,
                "last_edit_date": 1651642921,
                "creation_date": 1651630178,
                "answer_id": 72107270,
                "question_id": 72106960,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using an invocation with the -nR (or -n -R) options, the following generates valid JSON, which you can readily massage (or mangle) into the format you want:\r\n\r\n```\r\ndef trim: sub(&quot;^ +&quot;;&quot;&quot;)|sub(&quot; +$&quot;; &quot;&quot;); \r\n\r\nreduce inputs as $in (null;\r\n  ($in | capture(&quot;(?&lt;k&gt;^[^=]*)=(?&lt;v&gt;.*)&quot; ) | map_values(trim)) as $kv\r\n  | setpath( $kv.k | split(&quot;.&quot;); $kv.v) )\r\n```  \r\n",
                "title": "Convert properties to json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1651642921,
        "creation_date": 1651626599,
        "question_id": 72106960,
        "body_markdown": "I have some properties like that.\r\nThere may be some spaces between key and equal. \r\n\r\n    error.code.400                  = Incorrect Request.\r\n    error.code.404                  = Requested resource not available.\r\n    error.code.500                  = Internal server error. It will soon be processed.\r\n    error.msg.1                     = Sorry for the inconvenience.&lt;br /&gt;The page you have requested was not normally processed.\r\n    error.msg.2                     = Access Denied. Please contact the administrator.\r\n\r\nI wish to convert them to json with jq like that\r\n\r\n    message: {\r\n        error: {\r\n            code: {\r\n                400: &#39;Incorrect Request.&#39;,\r\n                404: &#39;Requested resource not available.&#39;,\r\n                500: &#39;Internal server error. It will soon be processed.&#39;\r\n            },\r\n            msg: {\r\n                1: &#39;Sorry for the inconvenience.&lt;br /&gt;The page you have requested was not normally processed.&#39;,\r\n                2: &#39;Access Denied. Please contact the administrator.&#39;\r\n            }\r\n        }\r\n    }\r\n\r\nThanks!!\r\n",
        "link": "https://stackoverflow.com/questions/72106960/convert-properties-to-json-with-jq",
        "title": "Convert properties to json with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1651656633,
                "last_edit_date": 1651656633,
                "creation_date": 1651656264,
                "answer_id": 72110653,
                "question_id": 72110455,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your example should be:\r\n\r\n```\r\nfind ~/somedir -mindepth 1 -maxdepth 1 -type d | /usr/local/bin/jq -nR \\\r\n&#39;{\r\n    &quot;items&quot;: [      \r\n        inputs as $title |                  \r\n        {\r\n            &quot;title&quot;: $title,\r\n        }\r\n    ]\r\n}&#39;\r\n```\r\n\r\n\r\nFrom the `jq` man page:\r\n\r\n```\r\n inputs\r\n       Outputs all remaining inputs, one by one.\r\n\r\n       This is primarily useful for reductions over a program&#180;s inputs.\r\n```\r\n\r\nThis implicitly means that every time called, `inputs` reads the next line from stdin. stdin is realized as a pipe, once a line from stdin has been read, it is gone.\r\n\r\nWhen you echo a line before the actual input, then this extra line will be subject to this extra read. Just use `inputs` twice to see the problem coming back:\r\n\r\n\r\n```\r\n(echo &quot;test&quot; &amp;&amp; find ~/somedir -mindepth 1 -maxdepth 1 -type d) | /usr/local/bin/jq -nR \\\r\n&#39;{\r\n    &quot;items&quot;: [\r\n        inputs | inputs |\r\n        inputs as $title |                  \r\n        {\r\n            &quot;title&quot;: $title,\r\n        }\r\n    ]\r\n}&#39;\r\n```\r\n\r\n---\r\n\r\nPS: As [`pmf`][1] pointed out, the whole solution can be simplified to:\r\n\r\n```\r\nfind ~/somedir -mindepth 1 -maxdepth 1 -type d \\\r\n    jq -nR &#39;{items: [{title: inputs}]}&#39;\r\n```\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/72110455/why-is-the-first-line-is-skipped/72110653#comment127413019_72110653",
                "title": "Why is the first line is skipped"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1651656633,
        "creation_date": 1651655307,
        "last_edit_date": 1651655663,
        "question_id": 72110455,
        "body_markdown": "Why is the first line skipped if I remove `echo &quot;prevent remove first line&quot;`?\r\n\r\n    (echo &quot;prevent remove first line&quot; &amp;&amp; find ~/somedir -mindepth 1 -maxdepth 1 -type d) | /usr/local/bin/jq -nR \\\r\n    &#39;{\r\n        &quot;items&quot;: [\r\n            inputs |                                     \r\n            inputs as $title |                  \r\n            {\r\n                &quot;title&quot;: $title,\r\n            }\r\n        ]\r\n    }&#39;",
        "link": "https://stackoverflow.com/questions/72110455/why-is-the-first-line-is-skipped",
        "title": "Why is the first line is skipped"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1651697665,
                "creation_date": 1651697665,
                "answer_id": 72119372,
                "question_id": 72119183,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can iterate over the other keys using `del` and `keys_unsorted`:\r\n~~~sh\r\njq &#39;map({id, value: (del(.id) | .[keys_unsorted[]])})&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;value&quot;: &quot;value-in-a&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;value&quot;: &quot;value-in-b&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;value&quot;: &quot;value-in-c&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/FCP0tp96Fd)",
                "title": "How to use jq to produce multiple JSON objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1651759764,
        "creation_date": 1651696451,
        "last_edit_date": 1651759764,
        "question_id": 72119183,
        "body_markdown": "How would one transform a `JSON` object into several derived `JSON` objects with `jq`?\r\n\r\nExample input:\r\n\r\n```json\r\n[\r\n  {\r\n     &quot;id&quot;: 1,\r\n     &quot;a&quot;: &quot;value-in-a&quot;,\r\n     &quot;b&quot;: &quot;value-in-b&quot;\r\n  },\r\n  {\r\n     &quot;id&quot;: 2,\r\n     &quot;c&quot;: &quot;value-in-c&quot;\r\n  }\r\n]\r\n```\r\n\r\nExpected output:\r\n```json\r\n[\r\n  {\r\n     &quot;id&quot;: &quot;1&quot;,\r\n     &quot;value&quot;: &quot;value-in-a&quot;\r\n  },\r\n  {\r\n     &quot;id&quot;: &quot;1&quot;,\r\n     &quot;value&quot;: &quot;value-in-b&quot;\r\n  },\r\n  {\r\n     &quot;id&quot;: &quot;2&quot;,\r\n     &quot;value&quot;: &quot;value-in-c&quot;\r\n  }\r\n]\r\n```\r\n\r\nHere the output is an array with 3 elements. First 2 elements are transformed using the first element in the input array. Third element is produced from second element in the input array.\r\n\r\n\r\nI assume to achieve there will need to be several steps:\r\n\r\n a) Construct 2 objects from single JSON object input.  Aassume this can be done using variables. First assign input object into variable, then construct object with value a and then with value b.  Not sure how to make JQ return several constructed JSON objects.\r\n\r\n b) Conditionals will need to be used to not produce an object if `a`, or `b`, or `c` is missing. This can probably be done using &#39;alternative&#39; operator or `if-then-else `\r\n\r\n",
        "link": "https://stackoverflow.com/questions/72119183/how-to-use-jq-to-produce-multiple-json-objects",
        "title": "How to use jq to produce multiple JSON objects?"
    },
    {
        "tags": [
            "json",
            "group-by",
            "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": 1664445388,
                "post_id": 72126585,
                "comment_id": 130475460,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651753331,
                "creation_date": 1651753331,
                "answer_id": 72127110,
                "question_id": 72126585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Creating an object with `key` and `value` fields, then using `from_entries` would be one way:\r\n~~~sh\r\n{\r\n  count: length,\r\n  regions: group_by(.&quot;company.u_ats_region&quot;)\r\n  | map({\r\n      key: .[0].&quot;company.u_ats_region&quot;,\r\n      value: map({name: &quot;\\(.hostname).\\(.os_domain)&quot;, os})\r\n    })\r\n  | from_entries\r\n}\r\n~~~\r\n~~~json\r\n{\r\n  &quot;count&quot;: 3,\r\n  &quot;regions&quot;: {\r\n    &quot;Region1&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;host1.test.com&quot;,\r\n        &quot;os&quot;: &quot;Windows&quot;\r\n      }\r\n    ],\r\n    &quot;Region2&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;host2.test.com&quot;,\r\n        &quot;os&quot;: &quot;Windows&quot;\r\n      }\r\n    ],\r\n    &quot;Region3&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;host3.test.com&quot;,\r\n        &quot;os&quot;: &quot;Windows&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/mwnnEKvFZc)",
                "title": "JQ: group by into single object with groups as keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651754668,
                "creation_date": 1651754668,
                "answer_id": 72127391,
                "question_id": 72126585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `reduce` to iteratively build up the arrays would be another way:\r\n~~~sh\r\n{\r\n  count: length,\r\n  regions: (\r\n    reduce .[] as $i ({};\r\n      .[$i.&quot;company.u_ats_region&quot;] += [$i | {name: &quot;\\(.hostname).\\(.os_domain)&quot;, os}]\r\n    )\r\n  )\r\n}\r\n~~~\r\n~~~json\r\n{\r\n  &quot;count&quot;: 3,\r\n  &quot;regions&quot;: {\r\n    &quot;Region1&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;host1.test.com&quot;,\r\n        &quot;os&quot;: &quot;Windows&quot;\r\n      }\r\n    ],\r\n    &quot;Region2&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;host2.test.com&quot;,\r\n        &quot;os&quot;: &quot;Windows&quot;\r\n      }\r\n    ],\r\n    &quot;Region3&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;host3.test.com&quot;,\r\n        &quot;os&quot;: &quot;Windows&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/2woiG7yWH2)",
                "title": "JQ: group by into single object with groups as keys"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1664447217,
                "last_edit_date": 1664447217,
                "creation_date": 1664445859,
                "answer_id": 73893696,
                "question_id": 72126585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can define a [custom function](https://stackoverflow.com/a/73893819/112968) which performs the grouping and then tranfsorm the result. Using a function avoids having to repeat the selector:\r\n\r\n```\r\ndef group_to_obj(f):\r\n  group_by(f) | map({key:first|f, value:.}) | from_entries;\r\n\r\n{\r\n  count: length,\r\n  regions: group_to_obj(.&quot;company.u_ats_region&quot;)\r\n    | map_values(map({name: &quot;\\(.hostname).\\(.os_domain)&quot;, os}))\r\n}\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;count&quot;: 3,\r\n  &quot;regions&quot;: {\r\n    &quot;Region1&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;host1.test.com&quot;,\r\n        &quot;os&quot;: &quot;Windows&quot;\r\n      }\r\n    ],\r\n    &quot;Region2&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;host2.test.com&quot;,\r\n        &quot;os&quot;: &quot;Windows&quot;\r\n      }\r\n    ],\r\n    &quot;Region3&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;host3.test.com&quot;,\r\n        &quot;os&quot;: &quot;Windows&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```",
                "title": "JQ: group by into single object with groups as keys"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1664447217,
        "creation_date": 1651750903,
        "last_edit_date": 1651818406,
        "question_id": 72126585,
        "body_markdown": "I have the following data:\r\n```json\r\n[\r\n  {\r\n    &quot;company.u_ats_region&quot;: &quot;Region1&quot;,\r\n    &quot;hostname&quot;: &quot;host1&quot;,\r\n    &quot;install_status&quot;: &quot;1&quot;,\r\n    &quot;os&quot;: &quot;Windows&quot;,\r\n    &quot;os_domain&quot;: &quot;test.com&quot;\r\n  },\r\n  {\r\n    &quot;company.u_ats_region&quot;: &quot;Region2&quot;,\r\n    &quot;hostname&quot;: &quot;host2&quot;,\r\n    &quot;install_status&quot;: &quot;1&quot;,\r\n    &quot;os&quot;: &quot;Windows&quot;,\r\n    &quot;os_domain&quot;: &quot;test.com&quot;\r\n  },\r\n  {\r\n    &quot;company.u_ats_region&quot;: &quot;Region3&quot;,\r\n    &quot;hostname&quot;: &quot;host3&quot;,\r\n    &quot;install_status&quot;: &quot;7&quot;,\r\n    &quot;os&quot;: &quot;Windows&quot;,\r\n    &quot;os_domain&quot;: &quot;test.com&quot;\r\n  }\r\n]\r\n```\r\nAnd I&#39;ve been using this query \r\n~~~sh\r\n{count: length,\r\n regions: [group_by(.&quot;company.u_ats_region&quot;)[] | \r\n          {( [0].&quot;company.u_ats_region&quot;): [.[] | \r\n          {name: (.hostname+&quot;.&quot;+.os_domain), \r\n      os: .os}]}]}\r\n~~~\r\nto convert the data into the following:\r\n```json\r\n{\r\n  &quot;count&quot;: 3,\r\n  &quot;regions&quot;: [\r\n    {\r\n      &quot;Region1&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;host1.test.com&quot;,\r\n          &quot;os&quot;: &quot;Windows&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;Region2&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;host2.test.com&quot;,\r\n          &quot;os&quot;: &quot;Windows&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;Region3&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;host3.test.com&quot;,\r\n          &quot;os&quot;: &quot;Windows&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nThis is close to what I&#39;m trying to achieve but I would like &#39;regions&#39; to be a single object with each region being a key within that object like this:\r\n```json\r\n{\r\n  &quot;count&quot;: 3,\r\n  &quot;regions&quot;: {\r\n      &quot;Region1&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;host1.test.com&quot;,\r\n          &quot;os&quot;: &quot;Windows&quot;\r\n        }\r\n      ],\r\n      &quot;Region2&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;host2.test.com&quot;,\r\n          &quot;os&quot;: &quot;Windows&quot;\r\n        }\r\n      ],\r\n      &quot;Region3&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;host3.test.com&quot;,\r\n          &quot;os&quot;: &quot;Windows&quot;\r\n        }\r\n      ]\r\n    }\r\n}\r\n```\r\nI have tried playing around with &#39;add&#39; but that still didn&#39;t bring me any closer to the result I&#39;m trying to achieve. Any help is appreciated!",
        "link": "https://stackoverflow.com/questions/72126585/jq-group-by-into-single-object-with-groups-as-keys",
        "title": "JQ: group by into single object with groups as keys"
    }
]