[
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1588282122,
                "creation_date": 1588282122,
                "answer_id": 61533037,
                "question_id": 61526217,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the sample data is incomplete, it&#39;s difficult to say exactly what you&#39;re looking for but it looks like you should be using `parameters` in the call to walk:\r\n\r\n```\r\nwalk(if type==&quot;object&quot; and has(&quot;parameters&quot;)\r\n     then .parameters += [{&quot;extra&quot;: &quot;value&quot;}]\r\n     else . end)\r\n```\r\n\r\nIf you want to restrict the walk to the top-level `paths`, you would preface the above with: `.paths |= `",
                "title": "Add element to arrays, that are values to a given key name (json transformation with jq)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1588282122,
        "creation_date": 1588258150,
        "question_id": 61526217,
        "body_markdown": "I&#39;m a jq newbie, and I try to transform a json (a Swagger spec). I want to add an element to the array value of the &quot;parameter&quot; keys:\r\n\r\n```\r\n{\r\n  ...\r\n  &quot;paths&quot;: {\r\n    &quot;/great/endpoint1&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;parameters&quot;: [] &lt;&lt;--- add a value here\r\n       }\r\n    }\r\n    &quot;/great/endpoint2&quot;: {\r\n      &quot;post&quot;: {\r\n        &quot;parameters&quot;: [] &lt;&lt;-- and here too here too etc.\r\n  ....\r\n```\r\n\r\nThe following jqplay almost works. It adds values to the right arrays, but it has the nasty side effect of also removing the &quot;x-id&quot; value from the root of the input json. It&#39;s probably because of a faulty if-condition. As the paths contain a varying string (the endpoint names), I don&#39;t know how to write a wildcard path expression to address those, which is why I have tried using `walk` instead:\r\nhttps://jqplay.org/s/az56quLZa3",
        "link": "https://stackoverflow.com/questions/61526217/add-element-to-arrays-that-are-values-to-a-given-key-name-json-transformation",
        "title": "Add element to arrays, that are values to a given key name (json transformation with jq)"
    },
    {
        "tags": [
            "awk",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1988065,
                    "reputation": 6133,
                    "user_id": 1782782,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://i.sstatic.net/99Sl0.jpg?s=256",
                    "display_name": "Pierre Fran&#231;ois",
                    "link": "https://stackoverflow.com/users/1782782/pierre-fran%c3%a7ois"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1588260227,
                "post_id": 61526906,
                "comment_id": 108836329,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1588326118,
                "last_edit_date": 1588326118,
                "creation_date": 1588275129,
                "answer_id": 61531313,
                "question_id": 61526906,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following jq filter can be used to achieve the desired result in a single invocation of jq:\r\n```\r\n.billing_date.meta.display |= gsub(&quot; &quot;; &quot;_&quot;)\r\n| .billing_accounting_date.meta.display |=  gsub(&quot; &quot;; &quot;_&quot;)\r\n```\r\n\r\nOr maybe this is what you want:\r\n\r\n    .mappings.properties[].meta.display |= gsub(&quot; &quot;; &quot;_&quot;) \r\n\r\nIf you are willing to take the risk to overwrite the input file, you might like to use the `sponge` utility from &quot;coreutils&quot;.\r\n\r\n### Using `walk`\r\n\r\nYou might also wish to consider using `walk`, e.g. along the lines of:\r\n\r\n```\r\nwalk(if type == &quot;object&quot; and has(&quot;display&quot;) then .display |= gsub(&quot; &quot;; &quot;_&quot;) else . end)\r\n```\r\n",
                "title": "jq to replace multiple occurrences of a character only in a section of only certain lines of a json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1588326118,
        "creation_date": 1588259963,
        "last_edit_date": 1588266630,
        "question_id": 61526906,
        "body_markdown": "I have a set of files containing sections like the following:\r\n\r\n        &quot;billing_date&quot;: {\r\n            &quot;type&quot;: &quot;date&quot;,\r\n            &quot;meta&quot;: {\r\n                &quot;display&quot;: &quot;Billing Date&quot;,\r\n                &quot;format&quot;: &quot;:%x&quot;\r\n            }\r\n        },\r\n        &quot;billing_accounting_date&quot;: {\r\n            &quot;type&quot;: &quot;date&quot;,\r\n            &quot;meta&quot;: {\r\n                &quot;display&quot;: &quot;Billing Accounting Date&quot;,\r\n                &quot;format&quot;: &quot;:%x&quot;\r\n            }\r\n        }\r\n\r\nI need to change the contents of the &quot;display&quot; field to use underscores instead of spaces, so the result is like this (note underscores in Billing_Date and Billing_Accounting_Date):\r\n\r\n        &quot;billing_date&quot;: {\r\n            &quot;type&quot;: &quot;date&quot;,\r\n            &quot;meta&quot;: {\r\n                &quot;display&quot;: &quot;Billing_Date&quot;,\r\n                &quot;format&quot;: &quot;:%x&quot;\r\n            }\r\n        },\r\n        &quot;billing_accounting_date&quot;: {\r\n            &quot;type&quot;: &quot;date&quot;,\r\n            &quot;meta&quot;: {\r\n                &quot;display&quot;: &quot;Billing_Accounting_Date&quot;,\r\n                &quot;format&quot;: &quot;:%x&quot;\r\n            }\r\n        }\r\n\r\nPierre Francois kindly suggested using jq; I&#39;ve been trying that but still haven&#39;t been able to put it all together.\r\n\r\nEach of several files have several dozen different fields; I&#39;ve been able to extract the replacements I need but don&#39;t see how to put them back into a file.\r\n\r\n    % jq &#39;.mappings.properties[].meta.display&#39; input.txt                                                                               \r\n    &quot;Key&quot;\r\n    &quot;Action&quot;\r\n    &quot;Transaction Import Time&quot;\r\n    &quot;Hash&quot;\r\n    &quot;Data Exchange 1.0 Warnings&quot;\r\n    &quot;Data Exchange 1.0 Errors&quot;\r\n    &quot;Effective Time&quot;\r\n    &quot;Import ID&quot;\r\n    &quot;Import S3 Key&quot;\r\n    &quot;Importing User Name&quot;\r\n    &quot;Utility UUID&quot;\r\n    &quot;Utility Name&quot;\r\n    &quot;Import File Row&quot;\r\n    &quot;Account ID&quot;\r\n    &quot;Location ID&quot;\r\n    &quot;Service Point ID&quot;\r\n    &quot;Meter ID&quot;\r\n    &quot;Bill ID&quot;\r\n    &quot;Register Number&quot;\r\n    &quot;Billing Unit Of Measure&quot;\r\n    &quot;Billing Cycle Start Date&quot;\r\n    &quot;Billing Cycle End Date&quot;\r\n    &quot;Billing Cycle Start Read&quot;\r\n    &quot;Billing Cycle End Read&quot;\r\n    &quot;Billing Cycle Consumption&quot;\r\n    &quot;Billing Date&quot;\r\n    &quot;Billing Accounting Date&quot;\r\n\r\n    % jq &#39;.mappings.properties[].meta.display | sub(&quot; &quot;; &quot;_&quot;) | sub(&quot; &quot;; &quot;_&quot;) | sub(&quot; &quot;; &quot;_&quot;) | sub(&quot; &quot;; &quot;_&quot;)&#39; input.txt               \r\n    &quot;Key&quot;\r\n    &quot;Action&quot;\r\n    &quot;Transaction_Import_Time&quot;\r\n    &quot;Hash&quot;\r\n    &quot;Data_Exchange_1.0_Warnings&quot;\r\n    &quot;Data_Exchange_1.0_Errors&quot;\r\n    &quot;Effective_Time&quot;\r\n    etc...",
        "link": "https://stackoverflow.com/questions/61526906/jq-to-replace-multiple-occurrences-of-a-character-only-in-a-section-of-only-cert",
        "title": "jq to replace multiple occurrences of a character only in a section of only certain lines of a json file"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1588265202,
                "creation_date": 1588265202,
                "answer_id": 61528599,
                "question_id": 61528218,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With an array:\r\n\r\n    mapfile -t arr &lt; &lt;(curl -s &quot;$url&quot; | jq -r &#39;.[1] | .[]&#39;)\r\n    declare -p arr",
                "title": "Dump Json response to a bash variable"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1588267228,
                "creation_date": 1588267228,
                "answer_id": 61529183,
                "question_id": 61528218,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do you want the values separate by TAB or NEWLINE characters in a single variable?  The `@tsv` function is [useful for controlling output][1]:\r\n\r\n```\r\noutTABS=$(curl -s &quot;$url&quot; | jq -r &#39;.[1]|.|@tsv&#39;)\r\noutLINE=$(curl -s &quot;$url&quot; | jq -r &#39;.[1]|.[]|[.]|@tsv&#39;)\r\n\r\n&gt; echo &quot;$outTABS&quot;\r\nval1\tval2\tvaln\r\n\r\n&gt; echo &quot;$outLINE&quot;\r\nval1\r\nval2\r\nvaln\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions",
                "title": "Dump Json response to a bash variable"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1588267228,
        "creation_date": 1588264074,
        "question_id": 61528218,
        "body_markdown": "I have the following ouput\r\n```\r\n[\r\n &quot;notimportant&quot;,\r\n     [\r\n       &quot;val1&quot;,\r\n       &quot;val2&quot;,\r\n       ...,\r\n       &quot;valn&quot;\r\n     ]\r\n]\r\n```\r\nI&#39;m trying to store every value into a bash string, using jq I tried this\r\n```\r\nout=&#39;&#39;\r\nreq=$(curl -s $url)\r\nlen=$(echo $req | jq length ) \r\nfor (( i = 0; i &lt; $len; i++ )); do\r\n\telement=$(echo $req | jq &#39;.[1]&#39; | jq --argjson i &quot;$i&quot; &#39;.[$i]&#39;)\r\n\tout=${element}\\n${out}\r\ndone\r\n```\r\nwhich feels clunky and also has a slow performance. I&#39;m trying to dump the values at once without looping on all the elements\r\n",
        "link": "https://stackoverflow.com/questions/61528218/dump-json-response-to-a-bash-variable",
        "title": "Dump Json response to a bash variable"
    },
    {
        "tags": [
            "json",
            "google-cloud-platform",
            "jq",
            "video-intelligence-api"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1591003823,
                "creation_date": 1591003823,
                "answer_id": 62129324,
                "question_id": 61532208,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I see you tried the suggested JQ command in [this][1] stack overflow post. You need to use a different JQ command suited to your case. \r\n\r\nI personally tried:\r\n\r\n```\r\ncat &lt;filename&gt;.json | jq -c &#39;.&#39;\r\n```\r\nand it works. Meaning, the end result is a valid newline delimited json. \r\n\r\nHowever, it may need more tweaks depending on your end table schema. \r\n\r\nInclude your end table schema on the description if it does not work so we can understand better what is the goal. \r\n\r\n[1]: https://stackoverflow.com/questions/51300674/converting-json-into-newline-delimited-json-in-python",
                "title": "Converting Google Cloud Video intelligence json to newline delimited json to upload to Big Query"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1591003823,
        "creation_date": 1588278662,
        "last_edit_date": 1588281145,
        "question_id": 61532208,
        "body_markdown": "I have created a function which outputs the json below from using the Google Video Intelligence API. I am trying to get the json into newline delimited format so that I can upload the json file to Big Query.\r\n\r\nI have tried the following JQ code however it does not convert it into a format accepted by BiG Query.\r\n\r\nAny help greatly appreciated.\r\n\r\n$ cat a.json | jq -c &#39;.[]&#39;\r\n\r\nFull json output from video intelligence\r\n```\r\n{\r\n  &quot;annotation_results&quot;: [ {\r\n    &quot;input_uri&quot;: &quot;/mastersproject-252719.appspot.com/AEnB2UoTKtyPJd1X88yUBKC60dn3kp6qrnnE91Q5PylS9RqotQWrt2TzFPE7kG1UHtxoBYyWX5mo7zoXU1jzwnNe_WRD-t0QeFSoHU4g-WJZTfeQV4cpFNY.4-FicKZIT3vtFBd2&quot;,\r\n    &quot;segment&quot;: {\r\n      &quot;start_time_offset&quot;: {\r\n      \r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 126,\r\n        &quot;nanos&quot;: 160000000\r\n      }\r\n    },\r\n    &quot;shot_annotations&quot;: [ {\r\n      &quot;start_time_offset&quot;: {\r\n      \r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 3,\r\n        &quot;nanos&quot;: 960000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 4\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 5,\r\n        &quot;nanos&quot;: 840000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 5,\r\n        &quot;nanos&quot;: 880000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 11,\r\n        &quot;nanos&quot;: 40000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 11,\r\n        &quot;nanos&quot;: 80000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 14,\r\n        &quot;nanos&quot;: 640000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 14,\r\n        &quot;nanos&quot;: 680000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 15,\r\n        &quot;nanos&quot;: 400000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 15,\r\n        &quot;nanos&quot;: 440000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 19,\r\n        &quot;nanos&quot;: 840000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 19,\r\n        &quot;nanos&quot;: 880000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 21,\r\n        &quot;nanos&quot;: 880000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 21,\r\n        &quot;nanos&quot;: 920000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 25,\r\n        &quot;nanos&quot;: 120000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 25,\r\n        &quot;nanos&quot;: 160000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 30,\r\n        &quot;nanos&quot;: 880000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 30,\r\n        &quot;nanos&quot;: 920000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 32,\r\n        &quot;nanos&quot;: 960000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 33\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 38,\r\n        &quot;nanos&quot;: 80000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 38,\r\n        &quot;nanos&quot;: 120000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 44,\r\n        &quot;nanos&quot;: 80000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 44,\r\n        &quot;nanos&quot;: 120000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 47,\r\n        &quot;nanos&quot;: 680000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 47,\r\n        &quot;nanos&quot;: 720000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 51,\r\n        &quot;nanos&quot;: 120000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 51,\r\n        &quot;nanos&quot;: 160000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 56,\r\n        &quot;nanos&quot;: 640000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 56,\r\n        &quot;nanos&quot;: 680000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 59,\r\n        &quot;nanos&quot;: 40000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 59,\r\n        &quot;nanos&quot;: 80000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 62,\r\n        &quot;nanos&quot;: 880000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 62,\r\n        &quot;nanos&quot;: 920000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 70,\r\n        &quot;nanos&quot;: 640000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 70,\r\n        &quot;nanos&quot;: 680000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 74,\r\n        &quot;nanos&quot;: 240000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 74,\r\n        &quot;nanos&quot;: 280000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 76,\r\n        &quot;nanos&quot;: 40000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 76,\r\n        &quot;nanos&quot;: 80000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 82,\r\n        &quot;nanos&quot;: 240000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 82,\r\n        &quot;nanos&quot;: 280000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 86\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 86,\r\n        &quot;nanos&quot;: 40000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 89,\r\n        &quot;nanos&quot;: 720000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 89,\r\n        &quot;nanos&quot;: 760000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 99,\r\n        &quot;nanos&quot;: 680000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 99,\r\n        &quot;nanos&quot;: 720000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 104,\r\n        &quot;nanos&quot;: 360000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 104,\r\n        &quot;nanos&quot;: 400000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 107,\r\n        &quot;nanos&quot;: 440000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 107,\r\n        &quot;nanos&quot;: 480000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 108,\r\n        &quot;nanos&quot;: 640000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 108,\r\n        &quot;nanos&quot;: 680000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 112,\r\n        &quot;nanos&quot;: 160000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 112,\r\n        &quot;nanos&quot;: 200000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 114,\r\n        &quot;nanos&quot;: 640000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 114,\r\n        &quot;nanos&quot;: 680000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 117,\r\n        &quot;nanos&quot;: 520000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 117,\r\n        &quot;nanos&quot;: 560000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 118,\r\n        &quot;nanos&quot;: 760000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 118,\r\n        &quot;nanos&quot;: 800000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 121,\r\n        &quot;nanos&quot;: 80000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 121,\r\n        &quot;nanos&quot;: 120000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 122,\r\n        &quot;nanos&quot;: 320000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 122,\r\n        &quot;nanos&quot;: 360000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 124,\r\n        &quot;nanos&quot;: 200000000\r\n      }\r\n    }, {\r\n      &quot;start_time_offset&quot;: {\r\n        &quot;seconds&quot;: 124,\r\n        &quot;nanos&quot;: 240000000\r\n      },\r\n      &quot;end_time_offset&quot;: {\r\n        &quot;seconds&quot;: 126,\r\n        &quot;nanos&quot;: 160000000\r\n      }\r\n    } ]\r\n  } ]\r\n}\r\n",
        "link": "https://stackoverflow.com/questions/61532208/converting-google-cloud-video-intelligence-json-to-newline-delimited-json-to-upl",
        "title": "Converting Google Cloud Video intelligence json to newline delimited json to upload to Big Query"
    },
    {
        "tags": [
            "list",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1588347604,
                "last_edit_date": 1588347604,
                "creation_date": 1588288893,
                "answer_id": 61534462,
                "question_id": 61534283,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The root of the difficulty you are running into is that the problem statement is improper: `.[].Conditions[].Values[]` does not correspond to your JSON.\r\n\r\nUsing jq 1.5 or later, you could use the following filter:\r\n```\r\n.[]\r\n| first(select(.Conditions | .. | objects\r\n               | select(has(&quot;Values&quot;) and \r\n                        (.Values|index(&quot;app.fantastic.com&quot;)))))\r\n| .RuleArn\r\n```\r\n\r\nSince .Values occurs in several places, it&#39;s not clear what the precise requirements are, but you might also wish to consider:\r\n\r\n```\r\n.[]\r\n| select(.Conditions[].Values? | index(&quot;app.fantastic.com&quot;))\r\n| .RuleArn\r\n ```\r\n\r\nor (less efficiently, but it works with jq 1.4 or later):\r\n```\r\n.[]\r\n| select(.Conditions[].Values[]? == &quot;app.fantastic.com&quot;)\r\n| .RuleArn\r\n```\r\n\r\n",
                "title": "jq filter JSON array based on value in list"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1588347604,
        "creation_date": 1588288068,
        "question_id": 61534283,
        "body_markdown": "I want to use `jq` to return the `RuleArn` value if the following condition matches i.e. `.[].Conditions[].Values[]` has an element that matches `app.fantastic.com`\r\n\r\nMy JSON array:\r\n\r\n```\r\n[\r\n    {\r\n        &quot;Conditions&quot;: [\r\n            {\r\n                &quot;Field&quot;: &quot;http-header&quot;,\r\n                &quot;HttpHeaderConfig&quot;: {\r\n                    &quot;Values&quot;: [\r\n                        &quot;dark&quot;\r\n                    ],\r\n                    &quot;HttpHeaderName&quot;: &quot;Environment&quot;\r\n                }\r\n            },\r\n            {\r\n                &quot;Values&quot;: [\r\n                    &quot;app.fantastic.com&quot;\r\n                ],\r\n                &quot;Field&quot;: &quot;host-header&quot;,\r\n                &quot;HostHeaderConfig&quot;: {\r\n                    &quot;Values&quot;: [\r\n                        &quot;app.fantastic.com&quot;\r\n                    ]\r\n                }\r\n            }\r\n        ],\r\n        &quot;IsDefault&quot;: false,\r\n        &quot;Priority&quot;: &quot;3&quot;,\r\n        &quot;RuleArn&quot;: &quot;iwantthisvalue&quot;\r\n    }\r\n]\r\n```\r\nI&#39;ve tried these:\r\n\r\n`| jq -r &#39;.[] | select(.Conditions[].Values[]==&quot;app.fantastic.com&quot;)&#39;`\r\n\r\nand\r\n\r\n`| jq -r &#39;.[] | select(.Conditions[].Values[] | has(&quot;app.fantastic.com&quot;))&#39;`\r\n\r\n\r\nI get the following error:\r\n\r\n*jq: error (at &lt;stdin&gt;:144): Cannot index array with string &quot;Conditions&quot;*\r\n\r\n\r\n\r\nAnd with this: \r\n\r\n`| jq &#39;.[].Conditions[].Values | index (&quot;app.fantastic.com&quot;) == 0 | .RuleArn&#39;`\r\n\r\nThis is the error I get:\r\n\r\n*jq: error (at &lt;stdin&gt;:47): Cannot index boolean with string &quot;RuleArn&quot;*\r\n\r\n**Note:** I do not want a solution using `--query` of AWS cli as I use `--query` already to get a smaller JSON payload which I want to filter further using `jq`. ",
        "link": "https://stackoverflow.com/questions/61534283/jq-filter-json-array-based-on-value-in-list",
        "title": "jq filter JSON array based on value in list"
    },
    {
        "tags": [
            "json",
            "select",
            "updates",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588431655,
                "post_id": 61561413,
                "comment_id": 108895320,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1588433296,
                "creation_date": 1588433296,
                "answer_id": 61561823,
                "question_id": 61561413,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;d use an if-then-else expression for it, not select.\r\n```\r\n.packageDirectories |= map(\r\n  if .default == true\r\n  then .ancestorId = &quot;newValue&quot;\r\n  else . end\r\n)\r\n```\r\n&lt;sup&gt;[demo at jqplay.org](https://jqplay.org/s/jUcbQ5il7e)&lt;/sup&gt;",
                "title": "jq to change a specific field value by select"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1588461789,
                "creation_date": 1588461789,
                "answer_id": 61567642,
                "question_id": 61561413,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "FYPI, there is a way to achieve the goal using `select`:\r\n\r\n```\r\n.packageDirectories[] |=\r\n  ((select(.default == true) | .ancestorId = &quot;newValue&quot;) // . )\r\n```",
                "title": "jq to change a specific field value by select"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1588476622,
        "creation_date": 1588431501,
        "last_edit_date": 1588476622,
        "question_id": 61561413,
        "body_markdown": "I have a project.json file and its contents look like this:\r\n\r\n```\r\n{\r\n    &quot;packageDirectories&quot;: [\r\n        {\r\n            &quot;path&quot;: &quot;sfdx-source/unpackaged&quot;\r\n        },\r\n        {\r\n            &quot;path&quot;: &quot;sfdx-source/untracked&quot;\r\n        },\r\n        {\r\n            &quot;path&quot;: &quot;sfdx-source/zipsc&quot;,\r\n            &quot;package&quot;: &quot;ZipSC&quot;,\r\n            &quot;versionName&quot;: &quot;Version 0.1&quot;,\r\n            &quot;versionNumber&quot;: &quot;0.1.0.NEXT&quot;,\r\n            &quot;ancestorId&quot;:&quot;oldValue&quot;,\r\n            &quot;default&quot;: true\r\n        },\r\n        {\r\n            &quot;path&quot;: &quot;sfdx-source/unpackaged/open-cti&quot;,\r\n            &quot;package&quot;: &quot;OpenCTI&quot;,\r\n            &quot;versionName&quot;: &quot;Ver 0.3&quot;,\r\n            &quot;versionNumber&quot;: &quot;0.3.0.NEXT&quot;,\r\n            &quot;ancestorId&quot;: &quot;04t1P000000cB425QAE&quot;,\r\n            &quot;default&quot;: false\r\n        }\r\n    ],\r\n    &quot;sfdcLoginUrl&quot;: &quot;https://login.salesforce.com&quot;,\r\n    &quot;sourceApiVersion&quot;: &quot;47.0&quot;,\r\n    &quot;namespace&quot;: &quot;ZAR&quot;,\r\n    &quot;packageAliases&quot;: {\r\n        &quot;ZAR&quot;: &quot;0Ho1P000000XZA4SAO&quot;,\r\n        &quot;OpenCTI&quot;: &quot;0Ho1P000000X3AvSAO&quot;\r\n    }\r\n}\r\n\r\n```\r\n\r\nI want to change the ancestorId field for the packageDirectory objects where default is true. In that case oldValue in the example should become newValue. The output should be as follows. How do I do this with jq on a shell script.\r\n\r\n```\r\n{\r\n    &quot;packageDirectories&quot;: [\r\n        {\r\n            &quot;path&quot;: &quot;sfdx-source/unpackaged&quot;\r\n        },\r\n        {\r\n            &quot;path&quot;: &quot;sfdx-source/untracked&quot;\r\n        },\r\n        {\r\n            &quot;path&quot;: &quot;sfdx-source/zipsc&quot;,\r\n            &quot;package&quot;: &quot;ZipariSC&quot;,\r\n            &quot;versionName&quot;: &quot;Version 0.1&quot;,\r\n            &quot;versionNumber&quot;: &quot;0.1.0.NEXT&quot;,\r\n            &quot;ancestorId&quot;:&quot;newValue&quot;,\r\n            &quot;default&quot;: true\r\n        },\r\n        {\r\n            &quot;path&quot;: &quot;sfdx-source/unpackaged/open-cti&quot;,\r\n            &quot;package&quot;: &quot;OpenCTI&quot;,\r\n            &quot;versionName&quot;: &quot;Ver 0.3&quot;,\r\n            &quot;versionNumber&quot;: &quot;0.3.0.NEXT&quot;,\r\n            &quot;ancestorId&quot;: &quot;04t1P000000cB425QAE&quot;,\r\n            &quot;default&quot;: false\r\n        }\r\n    ],\r\n    &quot;sfdcLoginUrl&quot;: &quot;https://login.salesforce.com&quot;,\r\n    &quot;sourceApiVersion&quot;: &quot;47.0&quot;,\r\n    &quot;namespace&quot;: &quot;ZAR&quot;,\r\n    &quot;packageAliases&quot;: {\r\n        &quot;ZAR&quot;: &quot;0Ho1P000000XZA4SAO&quot;,\r\n        &quot;OpenCTI&quot;: &quot;0Ho1P000000X3AvSAO&quot;,\r\n    }\r\n}\r\n\r\n``` ",
        "link": "https://stackoverflow.com/questions/61561413/jq-to-change-a-specific-field-value-by-select",
        "title": "jq to change a specific field value by select"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1588444431,
                "post_id": 61564361,
                "comment_id": 108900689,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3986500,
                    "reputation": 3814,
                    "user_id": 3286903,
                    "user_type": "registered",
                    "accept_rate": 32,
                    "profile_image": "https://i.sstatic.net/zRjlp.png?s=256",
                    "display_name": "WeSee",
                    "link": "https://stackoverflow.com/users/3286903/wesee"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588444545,
                "post_id": 61564361,
                "comment_id": 108900734,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1588444717,
                "post_id": 61564361,
                "comment_id": 108900810,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4452009,
                    "reputation": 492,
                    "user_id": 3623574,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/ad242b36fb17abb84925906db3252193?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Summer-Sky",
                    "link": "https://stackoverflow.com/users/3623574/summer-sky"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688025481,
                "post_id": 61564361,
                "comment_id": 135019073,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1588475265,
                "last_edit_date": 1588475265,
                "creation_date": 1588444907,
                "answer_id": 61564570,
                "question_id": 61564361,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pass `$var` as a raw string argument and JQ will automatically convert it to a valid JSON string.\r\n```\r\n$ jq -n --arg var &quot;$var&quot; &#39;{$var}&#39;\r\n{\r\n  &quot;var&quot;: &quot;Hello\\n    \\&quot;world\\&quot;. \\n    This is \\\\anything \\\\or \\\\nothing\\n&quot;\r\n}\r\n```",
                "title": "Bash: How to escape a string for use in JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666425194,
        "creation_date": 1588443967,
        "last_edit_date": 1666425194,
        "question_id": 61564361,
        "body_markdown": "My Bash script has lots of variable assignments which are put in a JSON file:\r\n\r\n    var=&#39;Hello\r\n        &quot;world&quot;. \r\n        This is \\anything \\or \\nothing\r\n    &#39;\r\n    echo &quot;{ \\&quot;var\\&quot;= \\&quot;$var\\&quot; }&quot; &gt; output.json\r\n\r\nWhen validating the file `output.json` jq says:\r\n\r\n    $ cat output.json | jq .\r\n    parse error: Invalid numeric literal at line 1, column 9\r\n\r\nHow can I make a valid JSON file out of it? Any `\\` and `&quot;` should be preserved.\r\n\r\nThe correct JSON string would be\r\n\r\n    { &quot;var&quot;: &quot;Hello\r\n        \\&quot;world\\&quot;. \r\n        This is \\\\anything \\\\or \\\\nothing\r\n      &quot; }\r\n    \r\n\r\nI cannot modify the variable assignments but the JSON creation.\r\n",
        "link": "https://stackoverflow.com/questions/61564361/bash-how-to-escape-a-string-for-use-in-json",
        "title": "Bash: How to escape a string for use in JSON?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1588493982,
                "last_edit_date": 1588493982,
                "creation_date": 1588493041,
                "answer_id": 61571353,
                "question_id": 61571148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can still use a *del(select..) thing*.\r\n```\r\n.myArray[] |= del(select(.A &gt; 5) .B)\r\n```\r\n&lt;sup&gt;[demo at jqplay.org](https://jqplay.org/s/KQXrjYzExd)&lt;/sup&gt;",
                "title": "Conditional deletion from array of field A with condition on field B"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1588513833,
        "creation_date": 1588491895,
        "last_edit_date": 1588513833,
        "question_id": 61571148,
        "body_markdown": "Let&#39;s say I have a json with an array inside. Say that the elements of this array are objects with keys A and B. I would like to remove the B objects on the elements where A objects meet a certain condition. \r\nFor example, I would like to remove the B objects where A is greater than 5, transforming\r\n```\r\n{\r\n  &quot;title&quot;: &quot;myTitle&quot;,\r\n  &quot;myArray&quot;: [\r\n     {\r\n     \t&quot;A&quot;: 1,\r\n     \t&quot;B&quot;: &quot;foo&quot;\r\n     },\r\n     {\r\n     \t&quot;A&quot;: 4,\r\n     \t&quot;B&quot;: &quot;bar&quot;\r\n     },\r\n     {\r\n     \t&quot;A&quot;: 7,\r\n     \t&quot;B&quot;: &quot;barfoo&quot;\r\n     },\r\n     {\r\n     \t&quot;A&quot;: 9,\r\n     \t&quot;B&quot;: &quot;foobar&quot;\r\n     }\r\n  ]\r\n}\r\n``` \r\ninto\r\n```\r\n{\r\n  &quot;title&quot;: &quot;myTitle&quot;,\r\n  &quot;myArray&quot;: [\r\n     {\r\n     \t&quot;A&quot;: 1,\r\n     \t&quot;B&quot;: &quot;foo&quot;\r\n     },\r\n     {\r\n     \t&quot;A&quot;: 4,\r\n     \t&quot;B&quot;: &quot;bar&quot;\r\n     },\r\n     {\r\n     \t&quot;A&quot;: 7\r\n     },\r\n     {\r\n     \t&quot;A&quot;: 9\r\n     }\r\n  ]\r\n}\r\n```\r\n\r\nThe task seems easy enough and if I had&#39;t have to keep the A&#39;s it would be a simple del(select..) thing. There surely must be an elegant way to do this as well?\r\n\r\nThank you!",
        "link": "https://stackoverflow.com/questions/61571148/conditional-deletion-from-array-of-field-a-with-condition-on-field-b",
        "title": "Conditional deletion from array of field A with condition on field B"
    },
    {
        "tags": [
            "json",
            "linux",
            "amazon-web-services",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1588576941,
                "post_id": 61586847,
                "comment_id": 108940605,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18124504,
                    "reputation": 101,
                    "user_id": 13180139,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/23def82272626a98372a5457270c426a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "marshmello",
                    "link": "https://stackoverflow.com/users/13180139/marshmello"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588577297,
                "post_id": 61586847,
                "comment_id": 108940731,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1588615093,
                "creation_date": 1588615093,
                "answer_id": 61598625,
                "question_id": 61586847,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are outputting as text, what is the need for jq ?\r\n\r\n**--output text**\r\n\r\nIf you want to output as json you can use\r\n\r\n**--output json**",
                "title": "Jq adding extra double quotation marks when parsing with AWS Secrets Manager"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1588615093,
        "creation_date": 1588576144,
        "question_id": 61586847,
        "body_markdown": "My secrets are stored in AWS Secrets Manager in the following format:\r\n\r\n    KEY_1   &quot;XXXX&quot;\r\n    KEY_2   0\r\n\r\nI am trying to retrieve the secrets in the following format:\r\n\r\n    KEY_1=&quot;XXXX&quot;\r\n    KEY_2=0\r\n\r\nthat means the same way they&#39;re stored in Secrets Manager with `=` symbol. I am using `jq` to parse in the following manner:\r\n\r\n    aws secretsmanager get-secret-value --secret-id &lt;secret_name&gt; --output text --query SecretString \\\r\n    | jq  -r &#39;to_entries[] | [.key, &quot;=&quot;, &quot;\\&quot;&quot;, .value, &quot;\\&quot;&quot; ] | @tsv&#39; \\\r\n    | tr -d &quot;\\t&quot;\r\n\r\nThis command is working fine but with a small problem. This command is adding an extra double quotation mark (`&quot;&quot;`) in the `value` field. It is giving the following output:\r\n\r\n     KEY_1=&quot;&quot;XXXX&quot;&quot;\r\n     KEY_2=&quot;0&quot;\r\n\r\nBut I do not want these extra double quotation marks to be added. I want the output should be in the same format as described above while retrieving above i.e, without extra quotation marks. \r\n    ",
        "link": "https://stackoverflow.com/questions/61586847/jq-adding-extra-double-quotation-marks-when-parsing-with-aws-secrets-manager",
        "title": "Jq adding extra double quotation marks when parsing with AWS Secrets Manager"
    },
    {
        "tags": [
            "linux",
            "bash",
            "timezone",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1588579189,
                "post_id": 61587494,
                "comment_id": 108941521,
                "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": 3,
                "creation_date": 1588580002,
                "post_id": 61587494,
                "comment_id": 108941892,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2508516,
                    "reputation": 28729,
                    "user_id": 2181514,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/pS2Yo.jpg?s=256",
                    "display_name": "fdomn-m",
                    "link": "https://stackoverflow.com/users/2181514/fdomn-m"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588580546,
                "post_id": 61587494,
                "comment_id": 108942132,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1588630793,
                "last_edit_date": 1588630793,
                "creation_date": 1588629244,
                "answer_id": 61602291,
                "question_id": 61587494,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unfortunately, jq&#39;s handling of local time zones has been problematic\r\nand you may need to adapt the following according to the specifics\r\nof your version of jq (i.e. version number and platform).\r\n\r\n\r\nHere&#39;s an illustration using the TZ environment variable, e.g.\r\n\r\n    TZ=Europe/Madrid jq -n -f program.jq\r\n\r\nwhere program.jq contains:\r\n\r\n```\r\n{&quot;@timestamp&quot;: &quot;2020-05-04T18:02:13Z&quot;}\r\n| .[&quot;@timestamp&quot;]\r\n| fromdateiso8601   # converts to seconds\r\n| gmtime\r\n| strftime(&quot;%Y-%m-%dT%H:%M:%S%Z&quot;)\r\n```\r\n\r\nOutput: `&quot;2020-05-04T19:02:13CET&quot;`\r\n\r\nNote: %Z becomes CET.",
                "title": "jq convert timezone in bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1588656463,
        "creation_date": 1588578841,
        "last_edit_date": 1588656463,
        "question_id": 61587494,
        "body_markdown": "I have a query as below:\r\n\r\n    dump=$(jq -j --raw-output &#39;.aggregations | .&quot;2&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;5&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;3&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;4&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;8&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;6&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;7&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;9&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;10&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;11&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;12&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;13&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;14&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;15&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;1&quot; | .&quot;hits&quot; | .hits[] | .&quot;_source&quot; |\r\n                                               &quot;\\(.&quot;@timestamp&quot;)&quot; | &quot;\\n&quot;))))))))))))))&#39; &lt;&lt;&lt; &quot;$cl_report&quot;)\r\n    echo -e &quot;${dump}&quot; &gt;&gt; report.csv\r\n\r\ntimestamp is ISO8601 format.\r\n\r\nI want to convert the **timestamp** from UTC to Madrid time.\r\n\r\nWhat I want is something like **this**:\r\n\r\n    dump=$(jq -j --raw-output &#39;.aggregations | .&quot;2&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;5&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;3&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;4&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;8&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;6&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;7&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;9&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;10&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;11&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;12&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;13&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;14&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;15&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;1&quot; | .&quot;hits&quot; | .hits[] | .&quot;_source&quot; | &quot;\\ \r\n                                           (.&quot;@timestamp&quot;) as $tstamp | &quot;TZ Europe/Madrid&quot; date -d $tstamp&quot; | \\n&quot;))))))))))))))&#39; &lt;&lt;&lt; &quot;$cl_report&quot;)\r\n\r\n\r\nBash throws error complaining about &quot; and &#39; etc etc.\r\n\r\nWhat is the correct way of doing this conversion?\r\n\r\n\r\n\r\n**Ok. It seems there is a bug with jq 1.5. strftime etc does not read TZ properly in this version.**\r\n\r\njq 1.6 can help:\r\n\r\n    report_dump=$(TZ=Erope/Madrid jq1.6 -j --raw-output &#39;.aggregations | .&quot;2&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;5&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;3&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;4&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;8&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;6&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;7&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;9&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;10&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;11&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;12&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;13&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;14&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;15&quot; | .buckets[] | &quot;\\(.key),&quot;,\r\n                                           (.&quot;1&quot; | .&quot;hits&quot; | .hits[] | .&quot;_source&quot; | .[&quot;@timestamp&quot;] | sub(&quot;.[0-9]+Z$&quot;; &quot;Z&quot;) | fromdateiso8601 | strflocaltime(&quot;%Y-%m-%dT%H:%M:%S %Z&quot;), &quot;\\n&quot;))))))))))))))&#39; &lt;&lt;&lt; &quot;$cl_report&quot;)\r\n\r\nAs shown above, I piped the stripped timestamp to fromdateiso8601 to get seconds and then piped into strflocaltime that utilizes TZ to get the local time.\r\n",
        "link": "https://stackoverflow.com/questions/61587494/jq-convert-timezone-in-bash-script",
        "title": "jq convert timezone in bash script"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1588584039,
                "last_edit_date": 1588584039,
                "creation_date": 1588580859,
                "answer_id": 61588017,
                "question_id": 61587875,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Declare `group_list` properly and it&#39;ll work.\r\n```\r\ngroup_list=(&quot;dummy group 1&quot; &quot;dummy group 2&quot;)\r\nfor i in &quot;${group_list[@]}&quot;; do\r\n  jq -r --arg name &quot;$i&quot; &#39;.[] | select(.name == $name) .groupid&#39; &lt;&lt;&lt; $groupid_json\r\ndone\r\n```",
                "title": "JQ - filter value with space"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1588584039,
        "creation_date": 1588580319,
        "question_id": 61587875,
        "body_markdown": "I want to select a value and filter it. But it has a space. And I&#39;m trying to do this using a for loop.\r\nBut it doesn&#39;t return any output when using a `for loop`. I even tried `--arg name &quot;$i&quot;` but that didn&#39;t work either.\r\n\r\nThe values are &quot;dummy group 1&quot;, &quot;dummy group 2&quot;\r\n\r\n    group_list=(&quot;dummy group 1&quot;, &quot;dummy group 2&quot;);\r\n\r\n    for i in &quot;${group_list[@]//,/}&quot;\r\n    do\r\n    \r\n    echo $groupid_json | jq  -r &#39;.result[] | select(.name == &quot;$i&quot;) | .groupid&#39;\r\n    \r\n    done\r\n\r\n\r\nBut nothing happens.\r\nHere is the actual json output that I&#39;m trying to filter:\r\n\r\n    [\r\n      {\r\n        &quot;groupid&quot;: &quot;92&quot;,\r\n        &quot;name&quot;: &quot;dummy group 1&quot;\r\n      },\r\n      {\r\n        &quot;groupid&quot;: &quot;93&quot;,\r\n        &quot;name&quot;: &quot;dummy group 2&quot;\r\n      }\r\n    ]\r\n\r\n\r\nIf I type the value then it works\r\n\r\n    echo $groupid_json | jq  -r &#39;.result[] | select(.name == &quot;dummy group 1&quot;) | .groupid&#39;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61587875/jq-filter-value-with-space",
        "title": "JQ - filter value with space"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1712414195,
                "last_edit_date": 1712414195,
                "creation_date": 1588584470,
                "answer_id": 61589011,
                "question_id": 61588841,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Easiest way to convert a bash array to a JSON array using JQ is to use the `--args` flag.\r\n``` none\r\n$ jq -n &#39;$ARGS.positional&#39; --args &quot;${group_list[@]}&quot;\r\n[\r\n  &quot;dummy group 1&quot;,\r\n  &quot;dummy group 2&quot;\r\n]\r\n```",
                "title": "JQ - create JSON array using bash array with space"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1712414195,
        "creation_date": 1588583878,
        "question_id": 61588841,
        "body_markdown": "I need to use proper bash array to create a JQ array. I can&#39;t use `, ` to split since I need to make use of the proper bash array in a `forloop`\r\n\r\nI need to create a json array using bash array and pass it to --jsonarg. \r\n\r\nThis is the work around I used to pass to query 1.\r\n\r\n    group_list=(&quot;dummy group 1&quot;, &quot;dummy group 2&quot;);\r\n    jsonarrray=$(echo ${group_list[@]} | jq -R &#39;split (&quot; &quot;)&#39;);\r\n\r\n    output:\r\n    [ &quot;dummy group 1&quot;, &quot;dummy group 2&quot; ]\r\n\r\n\r\nBut I need to find a way to use the proper bash array without the comma. \r\n\r\n    group_list=(&quot;dummy group 1&quot; &quot;dummy group 2&quot;);\r\n    # Cannot use SPLIT because it won&#39;t produce separate values\r\n    jsonarrray=$(echo ${group_list[@]} | jq -R &#39;split (&quot; &quot;)&#39;);\r\n\r\n    output: \r\n    [  &quot;dummy group 1 dummy group 2&quot; ]\r\n    \r\n\r\nHere is the query that I want to create.\r\nQuery 1:\r\n\r\n\r\n    query_data=(jq -n --argjson groupsName &quot;$jsonarrray&quot; \\\r\n    &#39;{\r\n        jsonrpc: &quot;2.0&quot;,\r\n        method: &quot;hostgroup.get&quot;,\r\n        params: {\r\n            output: [&quot;name&quot;, &quot;groupid&quot;],\r\n            filter: {&quot;name&quot;: $groupsName}\r\n        },\r\n        &quot;auth&quot;: &quot;6f38cddc44cfbb6c1bd186f9a220b5a0&quot;,\r\n        &quot;id&quot;: 2\r\n    }&#39;);\r\n\r\n\r\nThe final output of the query should look like this\r\n\r\n    {\r\n      &quot;jsonrpc&quot;: &quot;2.0&quot;,\r\n      &quot;method&quot;: &quot;hostgroup.get&quot;,\r\n      &quot;params&quot;: {\r\n        &quot;output&quot;: [\r\n          &quot;name&quot;,\r\n          &quot;groupid&quot;\r\n        ],\r\n        &quot;filter&quot;: {\r\n          &quot;name&quot;: [\r\n            &quot;dummy group 1&quot;,\r\n            &quot;dummy group 2&quot;\r\n          ]\r\n        }\r\n      },\r\n      &quot;auth&quot;: &quot;6f38cddc44cfbb6c1bd186f9a220b5a0&quot;,\r\n      &quot;id&quot;: 2\r\n    }\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61588841/jq-create-json-array-using-bash-array-with-space",
        "title": "JQ - create JSON array using bash array with space"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1588597473,
                "creation_date": 1588597473,
                "answer_id": 61592870,
                "question_id": 61591963,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way of doing it using `reduce`:\r\n```\r\nreduce inputs[] as [$date, $value] ({};\r\n  if has($date) then\r\n    .[$date] += {value2: $value}\r\n  else\r\n    .[$date] = {$date, value1: $value}\r\n  end\r\n) | map(.)\r\n```\r\nNote that you need to specify `-n`/`--null-input` option on the command line in order for `inputs` to work.\r\n\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/a07lsF04Q2)&lt;/sup&gt;",
                "title": "merge array of values without keys"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1588597782,
                "creation_date": 1588597782,
                "answer_id": 61592985,
                "question_id": 61591963,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the arrays in file1.json and file2.json are in lockstep as in your example, you could simply write:\r\n\r\n```\r\n.[0] |= map({date: .[0], value1: .[1]})\r\n| .[1] |= map({date: .[0], value2: .[1]})\r\n| transpose\r\n| map(add)\r\n```\r\n\r\nusing an invocation along the lines:\r\n\r\n    jq -s -f program.jq file1.json file2.json\r\n\r\nOf course there are many variations.\r\n\r\n",
                "title": "merge array of values without keys"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1588597782,
        "creation_date": 1588594288,
        "last_edit_date": 1588597519,
        "question_id": 61591963,
        "body_markdown": "I have a bit of a weird data setup, I have the following json files:\r\n\r\nfile 1:\r\n\r\n    [\r\n     [&quot;04-05-2020&quot;,\r\n      12\r\n     ],\r\n     [&quot;03-05-2020&quot;,\r\n      16\r\n     ]\r\n    ]\r\n\r\n\r\nfile 2:\r\n\r\n    [\r\n     [&quot;04-05-2020&quot;,\r\n      50\r\n     ],\r\n     [&quot;03-05-2020&quot;,\r\n      70\r\n     ]\r\n    ]\r\n\r\nI want to merge the 2 json files using the Dates (which are not specified as keys) and reassign keys and values to the output, such that the output is something like:\r\nfile 1:\r\n\r\n    [\r\n     {date: &quot;04-05-2020&quot;,\r\n      value1 : 12,\r\n      value2 : 50\r\n     },\r\n     {date: &quot;03-05-2020&quot;,\r\n      value1 : 16,\r\n      value2: 70\r\n     }\r\n    ]\r\n\r\nMy thoughts are I might have to merge the files together first and do some kind of reduce operation on the dates in the array, but my attempts have so far been unsuccessful. Or perhaps I should be formatting the Array first into Key + Value and then do a jq -s &#39;add&#39;? I&#39;m actually not sure how to reformat this.",
        "link": "https://stackoverflow.com/questions/61591963/merge-array-of-values-without-keys",
        "title": "merge array of values without keys"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq",
            "jsonparser"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1588614939,
                "last_edit_date": 1588614939,
                "creation_date": 1588614259,
                "answer_id": 61598409,
                "question_id": 61597122,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not quite clear with the logic of marking it DONE and FAILED. But to answer your first question where you want to select the multiple fields, you can do something like this:\r\n\r\n    $ cat input.js | jq -r &#39;.USER[] | select(.ipv4_address) | &quot;\\(.ipv4_address) \\(.id)&quot;&#39; &gt; result.js\r\n\r\n\r\nThis will output the result in a file named result.js. You can apply your custom logic of marking DONE and Failed on this file.\r\n\r\nIn the above command when you do **select(.ipv4_address)** It basically drops all the records for which ipv4_address value is null or it is not present.\r\nif you want to select the records which have ipv4_address as null, then your select statement would become something like this \r\n\r\n    select(.ipv4_address == null)",
                "title": "How to select multiple parameters from JSON output, which meets a condition &amp; further select individual value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1589130253,
        "creation_date": 1588610058,
        "last_edit_date": 1589130253,
        "question_id": 61597122,
        "body_markdown": "I have a json output, from which I need to get id value and IPv4_address value where IPv4_address exists (this shouldn&#39;t be null). Have to use this ID value for another request along with random generated string. \r\n\r\nHere is the breakdown of the requirement :  \r\n\r\nSTEP 1 : \r\nIn the following example, for the ipv4_address:1.1.1.1 &amp; ipv4_address:1.1.1.2, i need to get the id output which is &quot;4e-0365-4e29-95ca-329165eecf8a&quot; and &quot;c9061b6674a8546cea&quot; along with IP address. \r\n\r\nExample of my output should look like (something similar): \r\n```IPv4_address ID\r\n1.1.1.1 4e-0365-4e29-95ca-329165eecf8a\r\n1.1.1.2 c9061b6674a8546cea\r\n ```\r\n\r\nI was trying to use jq but with this I&#39;m not able to get the both values  :  \r\n```\r\nID=&quot;$(echo &quot;$test&quot; \\n | jq -r &#39;.USER[] | select(.ipv4_address) | .ipv4_address&#39;)&quot;\r\nID1=&quot;$(echo &quot;$test&quot; \\n | jq -r &#39;.USER[] | select(.ipv4_address) | .id&#39;)&quot;\r\n```\r\nSample output which is getting displayed with the above 2 commands : \r\nID value is : 1.1.1.1 1.1.1.2\r\nID1 value is : 4e-0365-4e29-95ca-329165eecf8a c9061b6674a8546cea\r\n\r\n\r\nSTEP 2: Profile creation: I need to use each $ID1 value in another request along with random generated string.  Random string is generated as per the count of $ID1&#39;s (so here I will generate 2 random string)\r\nAnd thus 2 profiles are created. \r\nQues: How can I get each ID from the $ID1 variable ? I tried something like ID1[0] but that seems to be wrong \r\n\r\nSTEP 3 : \r\nWill use each ID and random string for another request, Once its done or if that step is failed, i need to provide the output to a file &amp; output should look like :\r\nMy requirement for the final output is :\r\n```\r\n1.1.1.1 4e-0365-4e29-95ca-329165eecf8a  &lt;randomvalue-1&gt; &lt;profile-1&gt; DONE\r\n1.1.1.2 c9061b6674a8546cea &lt;randomvalue-2&gt; &lt;profile-2&gt; FAILED\r\n```\r\nwhere random  value will be generated randomly and shall be used against the ID.\r\n\r\n\r\nJSON output which needs to be parsed: \r\n```\r\n{\r\n  &quot;errorcode&quot;: 0,\r\n  &quot;message&quot;: &quot;Done&quot;,\r\n  &quot;operation&quot;: &quot;get&quot;,\r\n  &quot;resourceType&quot;: &quot;USER&quot;,\r\n  &quot;username&quot;: &quot;root&quot;,\r\n  &quot;tenant_name&quot;: &quot;Owner&quot;,\r\n  &quot;tenant_id&quot;: &quot;05db6674ad458546cd2&quot;,\r\n  &quot;resourceName&quot;: &quot;&quot;,\r\n  &quot;USER&quot;: [\r\n    {\r\n      &quot;is_default&quot;: &quot;false&quot;,\r\n      &quot;session_timeout&quot;: &quot;0&quot;,\r\n      &quot;permission&quot;: &quot;root&quot;,\r\n      &quot;name&quot;: &quot;ee&quot;,\r\n      &quot;session_timeout_unit&quot;: &quot;&quot;,\r\n      &quot;tenant_id&quot;: &quot;55bcb6674ad45854&quot;,\r\n      &quot;id&quot;: &quot;4e-0365-4e29-95ca-329165eecf8a&quot;,\r\n      &quot;ipv4_address&quot;: &quot;1.1.1.1&quot;,\r\n      &quot;state&quot;: &quot;Up&quot;,\r\n      &quot;tenant_name&quot;: &quot;Owner&quot;,\r\n      &quot;encrypted&quot;: &quot;false&quot;,\r\n      &quot;groups&quot;: [\r\n        &quot;owner&quot;\r\n      ],\r\n      &quot;root_user&quot;: &quot;&quot;\r\n    },\r\n    {\r\n      &quot;is_default&quot;: &quot;false&quot;,\r\n      &quot;session_timeout&quot;: &quot;0&quot;,\r\n      &quot;permission&quot;: &quot;read&quot;,\r\n      &quot;name&quot;: &quot;test&quot;,\r\n      &quot;session_timeout_unit&quot;: &quot;&quot;,\r\n      &quot;tenant_id&quot;: &quot;bc906674ad458546cd2&quot;,\r\n      &quot;id&quot;: &quot;12cd0-fb7f-4abf-b060-48e98b794b06&quot;,\r\n      &quot;tenant_name&quot;: &quot;Owner&quot;,\r\n      &quot;encrypted&quot;: &quot;false&quot;,\r\n      &quot;groups&quot;: [\r\n        &quot;read&quot;\r\n      ],\r\n      &quot;root_user&quot;: &quot;&quot;\r\n    },\r\n    {\r\n      &quot;is_default&quot;: &quot;true&quot;,\r\n      &quot;session_timeout&quot;: &quot;0&quot;,\r\n      &quot;permission&quot;: &quot;root&quot;,\r\n      &quot;name&quot;: &quot;root&quot;,\r\n      &quot;session_timeout_unit&quot;: &quot;&quot;,     \r\n      &quot;tenant_id&quot;: &quot;c905db6d458546cd2&quot;,\r\n      &quot;id&quot;: &quot;c9061b6674a8546cea&quot;,\r\n      &quot;ipv4_address&quot;: &quot;1.1.1.2&quot;,\r\n      &quot;state&quot;: &quot;Not Reachable&quot;,\r\n      &quot;tenant_name&quot;: &quot;Owner&quot;,\r\n      &quot;encrypted&quot;: &quot;false&quot;,\r\n      &quot;groups&quot;: [\r\n        &quot;owner&quot;\r\n      ],\r\n      &quot;root_user&quot;: &quot;&quot;\r\n    },\r\n    {\r\n      &quot;is_default&quot;: &quot;false&quot;,\r\n      &quot;session_timeout&quot;: &quot;0&quot;,\r\n      &quot;permission&quot;: &quot;readonly&quot;,\r\n      &quot;name&quot;: &quot;a&quot;,\r\n      &quot;session_timeout_unit&quot;: &quot;&quot;,\r\n      &quot;tenant_id&quot;: &quot;c905674ad458546cd2&quot;,\r\n      &quot;id&quot;: &quot;bc8a-4fd6-bc09-8c39c131b54e&quot;,\r\n      &quot;tenant_name&quot;: &quot;Owner&quot;,\r\n      &quot;encrypted&quot;: &quot;false&quot;,\r\n      &quot;groups&quot;: [\r\n        &quot;read&quot;\r\n      ],\r\n      &quot;root_user&quot;: &quot;&quot;\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/61597122/how-to-select-multiple-parameters-from-json-output-which-meets-a-condition-fu",
        "title": "How to select multiple parameters from JSON output, which meets a condition &amp; further select individual value"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588612121,
                "post_id": 61597675,
                "comment_id": 108959703,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588612175,
                "post_id": 61597675,
                "comment_id": 108959729,
                "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": 1588612650,
                "post_id": 61597675,
                "comment_id": 108959962,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1588612853,
                "last_edit_date": 1588612853,
                "creation_date": 1588612336,
                "answer_id": 61597843,
                "question_id": 61597675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "That approach is way more complex than is really needed. Does this do what you wanted?\r\n\r\n    &lt; json.json jq --arg prefix &quot;${prefix}&quot; --arg hk &quot;${hk}&quot; -r \\\r\n      &#39;.g[] | &quot;\\($prefix)    \\(.id) \\($hk)  \\(.name)&quot;&#39;\r\n\r\nThis replaces the `for` loop entirely with a single `jq` call, using jq to do the string formatting instead of `echo`, eliminating the base64 encoding and decoding, and eliminating four subprocess calls per row.",
                "title": "Improve `jq | @base64` speed"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1588612853,
        "creation_date": 1588611801,
        "last_edit_date": 1588612524,
        "question_id": 61597675,
        "body_markdown": "**Note:** This is a simplified version of a large script.\r\n\r\nThe real scripts recursively searches for a server to ssh to, each `.g[]` (group) can contain more `groups` and eventualy will contain a `.s` (server) object which holds IP/name/user/etc...\r\n\r\nAfter showing the first groups (which takes too long) the user is asked which group he wants to &#39;enter&#39; or which server he wants to connect to. (Servers omitted to simplify)\r\n&lt;Hr&gt;\r\nConsider the following JSON file;\r\n```\r\n{\r\n    &quot;g&quot;: [\r\n        {\r\n            &quot;id&quot;: &quot;1&quot;,\r\n            &quot;name&quot;: &quot;Group - 1&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;2&quot;,\r\n            &quot;name&quot;: &quot;Group - 2&quot;\r\n        },\r\n        ...\r\n        {\r\n            &quot;id&quot;: &quot;10&quot;,\r\n            &quot;name&quot;: &quot;Group - 10&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nUsing [tag:jq], I&#39;m showing the user each &#39;option&#39; presented in the `.g[]` array.\r\n\r\nBased on [this](https://starkandwayne.com/blog/bash-for-loop-over-json-array-using-jq/) post, I&#39;m using the following `for-loop` to iterate of the &#39;options&#39;;\r\n```bash\r\nfor row in $(jq -r &#39;.g[] | @base64&#39; &lt;&lt;&lt; $raw); do\r\n    echo -e &quot;${prefix}    $(_jq $row &#39;.id&#39;)${hk}  $(_jq $row &#39;.name&#39;)&quot;\r\ndone\r\n```\r\n&lt;hr&gt;\r\n**Problem**: The script needs ~`0.6` seconds to show me the first 10 entries;\r\n```\r\n$ time ./script\r\n./script  0.61s user 0.09s system 101% cpu 0.685 total\r\n```\r\n**Question**: How to improve the speed of the script?\r\n&lt;hr&gt;\r\nSome failed attempts;\r\n\r\n - Tried implementing the following `loop-logic` but unfortunately could not make it work \r\n     - &lt;https://stackoverflow.com/questions/39736840/loop-through-json-object-using-jq&gt;\r\n - Removing `| @base64` and `base64 --decode` causes the loop to show each literal row\r\n&lt;hr&gt;\r\n```bash\r\n#!/bin/bash\r\nset -e\r\n\r\n# Statics\r\n_DIR=&quot;$( cd &quot;$( dirname &quot;${BASH_SOURCE[0]}&quot; )&quot; &gt;/dev/null 2&gt;&amp;1 &amp;&amp; pwd )/&quot;\r\nred=`tput setaf 1`; green=`tput setaf 2`; yellow=`tput setaf 3`; blue=`tput setaf 4`; magenta=`tput setaf 5`; cyan=`tput setaf 6`; bow=`tput setaf 0;tput setab 7`; reset=`tput sgr0`; hk=&quot;${blue})${reset}&quot;; undl=`tput smul`; bold=`tput bold`;\r\n\r\n# getopts\r\nP_DEBUG=false\r\nwhile getopts &quot;q: d&quot; o; do\r\n    case &quot;${o}&quot; in\r\n        d) P_DEBUG=true ;;\r\n    esac\r\ndone\r\nshift $(($OPTIND - 1))\r\n\r\n#\r\n#       _jq\r\n#       Decodes and search for json key/value\r\n#       $1 --&gt; json\r\n#       $2 --&gt; key\r\n#\r\nfunction _jq() {\r\n    echo ${1} | base64 --decode | jq -r ${2}\r\n}\r\n\r\n# Validate &amp; Read JSON\r\njq -e type ./json.json &gt;/dev/null 2&gt;&amp;1 || echo -e &#39;Invalid JSON!&#39;\r\nraw=`jq . ./json.json`\r\n\r\n# Search for server\r\nreached_end=false\r\nwhile [[ $reached_end == false ]]; do\r\n\r\n    # Show id &amp; name of each group\r\n    for row in $(jq -r &#39;.g[] | @base64&#39; &lt;&lt;&lt; $raw); do\r\n        echo -e &quot;${prefix}    $(_jq $row &#39;.id&#39;)${hk}  $(_jq $row &#39;.name&#39;)&quot;\r\n    done\r\n\r\n    # Debug\r\n    exit 22\r\ndone\r\n```",
        "link": "https://stackoverflow.com/questions/61597675/improve-jq-base64-speed",
        "title": "Improve `jq | @base64` speed"
    },
    {
        "tags": [
            "json",
            "conditional-statements",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1588620056,
                "post_id": 61599834,
                "comment_id": 108963764,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1588620162,
                "creation_date": 1588620162,
                "answer_id": 61599979,
                "question_id": 61599834,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The thing you were trying to do is handled by the jq `select` function:\r\n\r\n    ROBOT_ID=$(jq &#39;.[] | select(.name == &quot;robot$deployer&quot;) | .id&#39;)",
                "title": "How to escape $ in the value of the field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1588631492,
        "creation_date": 1588619565,
        "last_edit_date": 1588631492,
        "question_id": 61599834,
        "body_markdown": "Need to get value of `id` that corresponds **`name=&#39;robot$deployer&#39;`**. How can `$` be escaped so `jq` only select corrct ID (1321) instead of both (1321 and 1326)? Currently script below with print both IDs\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 1321,\r\n    &quot;name&quot;: &quot;robot$deployer&quot;,\r\n    &quot;token&quot;: &quot;&quot;,\r\n    &quot;description&quot;: &quot;deployer&quot;,\r\n    &quot;project_id&quot;: 55,\r\n    &quot;expires_at&quot;: 1590799816,\r\n    &quot;disabled&quot;: false,\r\n    &quot;creation_time&quot;: &quot;2020-04-29T10:50:16.029882-07:00&quot;,\r\n    &quot;update_time&quot;: &quot;2020-04-29T10:50:16.029882-07:00&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 1326,\r\n    &quot;name&quot;: &quot;robot$test&quot;,\r\n    &quot;token&quot;: &quot;&quot;,\r\n    &quot;description&quot;: &quot;test&quot;,\r\n    &quot;project_id&quot;: 55,\r\n    &quot;expires_at&quot;: 1590862956,\r\n    &quot;disabled&quot;: false,\r\n    &quot;creation_time&quot;: &quot;2020-04-30T04:22:36.940445-07:00&quot;,\r\n    &quot;update_time&quot;: &quot;2020-04-30T04:22:36.940445-07:00&quot;\r\n  }\r\n]\r\n```\r\n\r\ntest script\r\n\r\n```bash\r\n#!/bin/bash\r\n \r\nexport PROJECT_INFO=&#39;[ { &quot;id&quot;: 1321, &quot;name&quot;: &quot;robot$deployer&quot;, &quot;token&quot;: &quot;&quot;, &quot;description&quot;: &quot;deployer&quot;, &quot;project_id&quot;: 55, &quot;expires_at&quot;: 1590799816, &quot;disabled&quot;: false, &quot;creation_time&quot;: &quot;2020-04-29T10:50:16.029882-07:00&quot;, &quot;update_time&quot;: &quot;2020-04-29T10:50:16.029882-07:00&quot; }, { &quot;id&quot;: 1326, &quot;name&quot;: &quot;robot$test&quot;, &quot;token&quot;: &quot;&quot;, &quot;description&quot;: &quot;test&quot;, &quot;project_id&quot;: 55, &quot;expires_at&quot;: 1590862956, &quot;disabled&quot;: false, &quot;creation_time&quot;: &quot;2020-04-30T04:22:36.940445-07:00&quot;, &quot;update_time&quot;: &quot;2020-04-30T04:22:36.940445-07:00&quot; } ]&#39;\r\n\r\nROBOT_LOGIN=&quot;robot\\$deployer&quot;\r\nexport ROBOT_ID=$(echo $PROJECT_INFO | jq --arg robot_name &quot;$ROBOT_LOGIN&quot; &#39;if .[].name == &quot;robot$deployer&quot; then .[].id else empty end&#39;)\r\necho &quot;ROBOT_ID:&quot; $ROBOT_ID\r\n```\r\n\r\n**Updated working version of the script**, thx @[hobbs][1]\r\n\r\n```bash\r\nexport PROJECT_INFO=&#39;[ { &quot;id&quot;: 1321, &quot;name&quot;: &quot;robot$deployer&quot;, &quot;token&quot;: &quot;&quot;, &quot;description&quot;: &quot;deployer&quot;, &quot;project_id&quot;: 55, &quot;expires_at&quot;: 1590799816, &quot;disabled&quot;: false, &quot;creation_time&quot;: &quot;2020-04-29T10:50:16.029882-07:00&quot;, &quot;update_time&quot;: &quot;2020-04-29T10:50:16.029882-07:00&quot; }, { &quot;id&quot;: 1326, &quot;name&quot;: &quot;robot$test&quot;, &quot;token&quot;: &quot;&quot;, &quot;description&quot;: &quot;test&quot;, &quot;project_id&quot;: 55, &quot;expires_at&quot;: 1590862956, &quot;disabled&quot;: false, &quot;creation_time&quot;: &quot;2020-04-30T04:22:36.940445-07:00&quot;, &quot;update_time&quot;: &quot;2020-04-30T04:22:36.940445-07:00&quot; } ]&#39;\r\n\r\nROBOT_LOGIN=&quot;robot\\$deployer&quot;\r\nexport ROBOT_ID=$(echo $PROJECT_INFO | jq --arg rl &quot;${ROBOT_LOGIN}&quot; &#39;.[] | select(.name == $rl) | .id&#39;)\r\necho &quot;ROBOT_ID:&quot; $ROBOT_ID\r\n```\r\n\r\n\r\n  [1]: https://stackoverflow.com/users/152948/hobbs",
        "link": "https://stackoverflow.com/questions/61599834/how-to-escape-in-the-value-of-the-field",
        "title": "How to escape $ in the value of the field"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588664859,
                "post_id": 61607509,
                "comment_id": 108977897,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1588666893,
                "creation_date": 1588666893,
                "answer_id": 61608760,
                "question_id": 61607509,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the Q only indicates the source for the key=value strings, the following focuses on the conversion of these strings to a JSON object.\r\n\r\n\r\nInvocation: jq -n -R -f program.jq props.txt\r\n\r\nprogram.jq:\r\n```\r\n[inputs | capture(&quot;^(?&lt;key&gt;[^=]*)=(?&lt;value&gt;.*)&quot;)]\r\n| from_entries\r\n```\r\n\r\nUsing `inputs` here has several small advantages but is inessential.\r\n",
                "title": "Json from external file"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1588666893,
        "creation_date": 1588662142,
        "question_id": 61607509,
        "body_markdown": "I need to create a JSON file with the following contents:\r\n\r\n```json\r\n{\r\n    &quot;destinationVersion&quot;:&quot;4&quot;,\r\n    &quot;sourceVersion&quot;:&quot;0&quot;,\r\n    &quot;props&quot;:{\r\n       &quot;METADATA_SIZE&quot;:&quot;91669&quot;,\r\n       &quot;METADATA_HASH&quot;:&quot;O7CLdR2j7qoD0RI2k1AGc8b+xoWYn20Ic24eZ1ZWUWE=&quot;,\r\n       &quot;FILE_SIZE&quot;:&quot;980374602&quot;,\r\n       &quot;FILE_HASH&quot;:&quot;+XW4QKN5Y4ynTx43m4NYbMuk1x3P91f1biAVZBpj4fI=&quot;\r\n    }\r\n }\r\n```\r\n\r\nThe main snag with the `props` block.\r\nThese values for `props` must be read from the text file.\r\nIn it they are in the following format:\r\n```\r\nFILE_HASH=+XW4QKN5Y4ynTx43m4NYbMuk1x3P91f1biAVZBpj4fI=\r\nFILE_SIZE=980374602\r\nMETADATA_HASH=O7CLdR2j7qoD0RI2k1AGc8b+xoWYn20Ic24eZ1ZWUWE=\r\nMETADATA_SIZE=91669\r\n```\r\nMy task is to read the file and somehow create the final JSON (append formatted text to `props` block).\r\nI try to do this through jq, but I don’t know how to convert the file to be added to the final JSON. Preferred way - `bash + jq`",
        "link": "https://stackoverflow.com/questions/61607509/json-from-external-file",
        "title": "Json from external file"
    },
    {
        "tags": [
            "json",
            "ansible",
            "jq",
            "qradar"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1588687145,
                "post_id": 61614422,
                "comment_id": 108989735,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9455675,
                    "reputation": 1392,
                    "user_id": 7031065,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Y0X59.jpg?s=256",
                    "display_name": "Ajay Kr Choudhary",
                    "link": "https://stackoverflow.com/users/7031065/ajay-kr-choudhary"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1588700517,
                "post_id": 61614422,
                "comment_id": 108997924,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1588746756,
                "last_edit_date": 1588746756,
                "creation_date": 1588735239,
                "answer_id": 61626797,
                "question_id": 61614422,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming away the minor errors in the JSON examples in the question, the following bash script produces the output as shown:\r\n```\r\n#!/bin/bash\r\n\r\njq -n \\\r\n --argfile lst log_source_types.json \\\r\n --argfile ls  log_sources.json \\\r\n --argfile pe  property_expressions.json \\\r\n --argfile rp  regex_properties.json &#39;\r\n  [ range(0, $pe|length) as $i\r\n    | {identifier: $pe[$i].identifier,\r\n       log_source_type_id: $lst[$i].id,\r\n       log_source_id: $pe[$i].log_source_id,\r\n       regex_property_identifier: $pe[$i].regex_property_identifier,\r\n       property_type: $rp[$i].property_type,\r\n       regex_name: $rp[$i].name,\r\n       lst_name: $lst[$i].name,\r\n       ls_name: $ls[$i].name\r\n     }\r\n  ]\r\n&#39;\r\n```\r\n\r\nNote: I wouldn&#39;t be too concerned that --argfile is officially deprecated, but if that bothers you, there are many workarounds, though some are version-dependent. If you want a non-deprecated solution that will work with every version of jq, I&#39;d use the form:\r\n\r\n    jq -s -f program.jq \\ \r\n     log_source_types.json \\\r\n     log_sources.json \\\r\n     property_expressions.json \\\r\n     regex_properties.json\r\n\r\nwhere program.jq begins by defining the four $-variables, beginning with: `.[0] as $lst |`",
                "title": "Combining JSON with different Key Names"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1588746756,
        "creation_date": 1588685576,
        "last_edit_date": 1588713830,
        "question_id": 61614422,
        "body_markdown": "EDIT: Going to try and simplify my question, and the JSON examples to just relevant elements.\r\n\r\nBuilding a playbook in Ansible, and one task I am trying to do involves pulling down data from 4 separate Qradar API endpoints, and trying to combine some details from each of the endpoints. \r\n\r\n4 different json sources for each of the endpoints:\r\n\r\n - &quot;regex_properties.json&quot; : Has unique &quot;identifier&quot;, and I need to reference the &quot;name&quot; and &quot;property_type&quot; values.\r\n - &quot;log_source_types.json&quot; : Has unique &quot;id&quot; field, and I need to reference it&#39;s &quot;name&quot;\r\n - &quot;log_sources.json&quot; : Has unique &quot;id&quot; field, and may include a &quot;type_id&quot; field if it&#39;s part of a log_source_type grouping (matches &quot;id&quot; above). Would need the &quot;name&quot; field from this, as well as potentially the &#39;last_event_time&#39; for filtering (but can get by without it).\r\n - &quot;property_expressions.json&quot; : Has unique &quot;identifier&quot; field. Also has which &quot;log_source_type_id&quot; and/or &quot;log_source_id&quot; each &quot;regex_property_identifier&quot; is mapped to. These values map to the unique identifiers in the other logs\r\n\r\nExamples from Lab:\r\n```\r\nregex_properties.json\r\n[\r\n  {\r\n    &quot;identifier&quot;: &quot;59723052-d96c-4cef-ba7b-69d426602e04&quot;,\r\n    &quot;property_type&quot;: &quot;numeric&quot;,\r\n    &quot;name&quot;: &quot;indexTotalSize&quot;,\r\n  }\r\n]\r\n\r\nlog_sources.json\r\n[\r\n  {\r\n    &quot;id&quot;: 64,\r\n    &quot;name&quot;: &quot;SIM Audit-2 :: eng-qradar-aio-01&quot;,\r\n    &quot;type_id&quot;: 105,\r\n    &quot;last_event_time&quot;: 1588628234930,\r\n  }\r\n]\r\n\r\nlog_source_types.json\r\n[\r\n    &quot;name&quot;: &quot;SIM Audit&quot;,\r\n    &quot;id&quot;: 105\r\n  },\r\n]\r\n\r\nproperty_expressions.json\r\n[\r\n  {\r\n    &quot;identifier&quot;: &quot;0311c65b-d5b5-483e-943f-b539543a8e95&quot;,\r\n    &quot;log_source_type_id&quot;: 105,\r\n    &quot;log_source_id&quot;: 65,\r\n    &quot;regex_property_identifier&quot;: &quot;59723052-d96c-4cef-ba7b-69d426602e04&quot;,\r\n  }\r\n]\r\n```\r\n\r\nI would like to pull in these 4 sources, and output a file that has the following data linkeed by the property_expressions.json:\r\n\r\n - The &quot;name&quot; &amp; &quot;property_type&quot; of the regex_property.json (renamed to regex_name or something similiar)\r\n - The &quot;name&quot; from log_sources.json and log_source_types.json (renamed to ls_name &amp; lst_name, respectively)\r\n\r\nSuch as below\r\n```\r\nmerged_example.json\r\n[\r\n  {\r\n    &quot;identifier&quot;: &quot;0311c65b-d5b5-483e-943f-b539543a8e95&quot;,\r\n    &quot;log_source_type_id&quot;: 105,\r\n    &quot;log_source_id&quot;: 65,\r\n    &quot;regex_property_identifier&quot;: &quot;59723052-d96c-4cef-ba7b-69d426602e04&quot;,\r\n    &quot;property_type&quot;: &quot;numeric&quot;,\r\n    &quot;regex_name&quot;: &quot;indexTotalSize&quot;,\r\n    &quot;lst_name&quot;: &quot;SIM Audit&quot;,\r\n    &quot;ls_name&quot;: &quot;SIM Audit-2 :: eng-qradar-aio-01&quot;,\r\n  }\r\n]\r\n```\r\nOr into a csv with the same data, which the end goal of the export, but can wait.\r\n\r\nI tried to rename &quot;identifier&quot; to &quot;regex_property_identifier&quot; in regex_properties.json, then using &#39;jq -s regex_properties.json property_expressions.json&#39; but I&#39;m still just seeing both contents being separate arrays in the same output/file.\r\n\r\nI&#39;ve tried using ansible and doing something like: \r\n```\r\n  - name: use JQ to reformat json to csv\r\n    shell: cat /tmp/property_expressions.json | jq -r &#39;.[]&#39; | jq &#39;select(.enabled == true)&#39; | jq &#39;[.identifier,.regex_property_identifier,.log_source_id,.log_source_type_id] | @csv&#39; &gt; /tmp/props.csv\r\n\r\n  - name: Read CSV into dictionary\r\n    read_csv:\r\n      path: &quot;/tmp/props.csv&quot;\r\n      fieldnames: &quot;prop_id,regex_id,ls_id,lst_id&quot;\r\n      delimiter: &quot;,&quot;\r\n    register: props\r\n\r\n  - name: Loop Prop Dictionary and replace in CSV the regex_id\r\n    replace:\r\n      path: &quot;/tmp/props.csv&quot;\r\n      regexp: &quot;{{ item.regex_id }}&quot;\r\n      replace: &quot;{{ regex_properties.json | json_query(regex_name_q) }},{{ regex_properties.json | json_query(regex_type_q) }}&quot;\r\n    loop: &quot;{{ props.list }}&quot;\r\n    vars:\r\n      regex_name_q: &quot;{{ item.regex_id }}.name&quot;\r\n      regex_type_q: &quot;{{ item.regex_id }}.property_type&quot;\r\n```\r\nIn order to just make a CSV and find/replace the terms item by item. But if I can do it within the JSON arrays that&#39;d be cleaner.\r\n",
        "link": "https://stackoverflow.com/questions/61614422/combining-json-with-different-key-names",
        "title": "Combining JSON with different Key Names"
    },
    {
        "tags": [
            "json",
            "shell",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1588751730,
                "creation_date": 1588751730,
                "answer_id": 61630070,
                "question_id": 61629999,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [tag:jq] like:\r\n```\r\nprogram | jq -Rn &#39;{Result:[{models:[inputs]}]}&#39;\r\n```\r\n`program` being the program producing that output.",
                "title": "How to convert output into JSON format?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1666425115,
        "creation_date": 1588751445,
        "last_edit_date": 1666425115,
        "question_id": 61629999,
        "body_markdown": "I am trying to convert below output into a valid json output. \r\nCant able to solve this using shell scripts.\r\n\r\n**output**\r\n```\r\nsvc pts/0        localhost. Tue Apr 28 21:40   still logged in   \r\nsvc pts/0        localhost. Tue Apr 28 21:40 - 21:40  (00:00)    \r\nsvc pts/0        localhost. Tue Apr 28 21:40 - 21:40  (00:00)\r\n...etc\r\n```\r\n\r\n**valid json output**\r\n```\r\n{\r\n\t&quot;Result&quot;: [{\r\n\t\t&quot;models&quot;: [&quot;svc pts 0 localhost.Tue Apr 28 21: 40 still logged in&quot;,\r\n\t\t\t&quot;svc pts/0        localhost. Tue Apr 28 21:40 - 21:40  (00:00)&quot;\r\n\t\t]\r\n\t}]\r\n}\r\n```\r\nis it possible to convert? can someone provide solution.s",
        "link": "https://stackoverflow.com/questions/61629999/how-to-convert-output-into-json-format",
        "title": "How to convert output into JSON format?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1588763614,
                "last_edit_date": 1588763614,
                "creation_date": 1588759368,
                "answer_id": 61632397,
                "question_id": 61632324,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For your immediate problem at the last hop, you can just do below which does [String interpolation](https://stedolan.github.io/jq/manual/v1.6/#Stringinterpolation-\\(foo), in `jq`\r\n\r\n    { &quot;\\(.ExportName)&quot; : &quot;\\(.OutputValue)&quot; }\r\n\r\nbut you can just do below by spelling out the explicit k/v names\r\n\r\n    { (.ExportName) : (.OutputValue) }\r\n",
                "title": "jq - how to create an output including double quote surrouding field values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1588774184,
                "last_edit_date": 1588774184,
                "creation_date": 1588771750,
                "answer_id": 61636453,
                "question_id": 61632324,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I [would] like to create a JSON dictionary\r\n\r\nTo create a single dictionary from the stream:\r\n\r\n    jq -n &#39;reduce inputs as $i (null;\r\n      . + ($i|{ (.ExportName) : (.OutputValue) }))&#39;\r\n\r\nOr you could modify your jq invocation to use a similar snippet along the lines of:\r\n\r\n    [ .Stacks[] .... \r\n     | { (.ExportName) : (.OutputValue) } ]\r\n    | add\r\n",
                "title": "jq - how to create an output including double quote surrouding field values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1588808999,
        "creation_date": 1588759133,
        "last_edit_date": 1588808999,
        "question_id": 61632324,
        "body_markdown": "# Background\r\n\r\nThe command below produce a JSON stream.\r\n\r\n```\r\naws cloudformation describe-stacks --stack-name ${stack} --region us-east-1 |\\\r\njq --arg STACK ${stack} &#39;.Stacks[] | select(.StackName==&quot;mlai-metadata-development-backend&quot;) | .Outputs[] | select(.ExportName != null) \r\n```\r\n\r\n```\r\n{\r\n  &quot;OutputKey&quot;: &quot;outputvpcid&quot;,\r\n  &quot;OutputValue&quot;: &quot;vpc-d4520cb1&quot;,\r\n  &quot;Description&quot;: &quot;VPC ID of the Stack mlai-metadata-development-backend&quot;,\r\n  &quot;ExportName&quot;: &quot;stack-vpc-id&quot;\r\n}\r\n{\r\n  &quot;OutputKey&quot;: &quot;outputvpccidr&quot;,\r\n  &quot;OutputValue&quot;: &quot;172.31.0.0/16&quot;,\r\n  &quot;Description&quot;: &quot;VPC CIDR of the Stack mlai-metadata-development-backend&quot;,\r\n  &quot;ExportName&quot;: &quot;stack-vpc-cidr&quot;\r\n}\r\n```\r\n\r\nI like to create a JSON dictionary like ```{&quot;stack-vpc-cidr&quot;: &quot;172.31.0.0/16&quot;}```.\r\n\r\nRunning this:\r\n```\r\naws cloudformation describe-stacks --stack-name ${stack} --region us-east-1 |\\\r\njq --arg STACK ${stack} &#39;.Stacks[] | select(.StackName==&quot;mlai-metadata-development-backend&quot;) | .Outputs[] | select(.ExportName != null) | &quot;\\(.ExportName):\\(.OutputValue)&quot;&#39;\r\n```\r\n\r\ncreates.\r\n```\r\n&quot;stack-vpc-id:vpc-d4520cb1&quot;\r\n&quot;stack-vpc-cidr:172.31.0.0/16&quot;\r\n```\r\n\r\n## Question\r\nHow can I turn them into lines of JSON dictionary using jq?\r\n\r\n---\r\n\r\n# Update\r\n\r\nThanks to the answers, got it right.\r\n\r\n```\r\naws cloudformation describe-stacks --stack-name ${stack} --region ${AWS_DEFAULT_REGION} |\\\r\njq --arg stack ${stack} \\\r\n  &#39;[.Stacks[] | select(.StackName==$stack) | .Outputs[] |\r\n  select(.ExportName != null) | { (.ExportName) : (.OutputValue) }] |\r\n  add&#39; |\\\r\ntee &quot;${stack}&quot;.json\r\n```\r\n\r\nResult:\r\n```\r\n{\r\n  &quot;apigw-rest-api-conntent-metadata-url&quot;: &quot;https://****.execute-api.us-east-1.amazonaws.com/development/&quot;,\r\n  &quot;apigw-rest-api-conntent-metadata-stage-name&quot;: &quot;development&quot;,\r\n  &quot;stack-availability-zones&quot;: &quot;us-east-1a,us-east-1b,us-east-1c,us-east-1d,us-east-1e,us-east-1f&quot;,\r\n  &quot;apigw-rest-api-conntent-metadata-deployment-id&quot;: &quot;***0tk&quot;,\r\n  &quot;stack-vpc-id&quot;: &quot;vpc-d4520cb1&quot;,\r\n  &quot;stack-vpc-cidr&quot;: &quot;172.31.0.0/16&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/61632324/jq-how-to-create-an-output-including-double-quote-surrouding-field-values",
        "title": "jq - how to create an output including double quote surrouding field values"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588781343,
                "post_id": 61638971,
                "comment_id": 109033119,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1588781389,
                "creation_date": 1588781389,
                "answer_id": 61639927,
                "question_id": 61638971,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This script does this:\r\n\r\n```shell\r\n#!/bin/bash\r\n\r\nLEN=$1\r\n\r\n# If no length has been provided as argument,\r\n# using the terminal width-1 as default.\r\nif [[ -z $LEN ]]; then\r\n    LEN=$(tput cols)\r\n    let LEN=LEN-1\r\nfi\r\n\r\nIFS=&#39;&#39;\r\nwhile read LINE; do\r\n    [[ ${#LINE} -ge $LEN ]] &amp;&amp; LINE=&quot;${LINE:0:$LEN}$&quot;\r\n    echo &quot;$LINE&quot;\r\ndone &lt; /dev/stdin\r\n```\r\n\r\nSave it as `trim.sh` and use like this:\r\n\r\n```shell\r\njq . your.json | ./trim.sh 25\r\n```\r\n\r\nThe argument value of 25 is desired length. Omit it to use the terminal window width as default.\r\n\r\nThe only caveat is disabled color output from `jq`. You can force enable it with `-C` argument to `jq`, but it screws script&#39;s output. Not sure how to fix.",
                "title": "prerty print jq bash"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1588781389,
        "creation_date": 1588778671,
        "question_id": 61638971,
        "body_markdown": "I need to print a json file in bash in a way that each element of the file fits in one line.\r\n\r\nThere are a couple of elements with many caracters and when I print it they take several lines.\r\n\r\nI would like find a way that bash prints the begining + $. Dollar sign means there is aditional text not being displayed.\r\n\r\nThanks for your help.\r\n\r\nGerard",
        "link": "https://stackoverflow.com/questions/61638971/prerty-print-jq-bash",
        "title": "prerty print jq bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1588834284,
                "last_edit_date": 1588834284,
                "creation_date": 1588829577,
                "answer_id": 61650571,
                "question_id": 61650539,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your idea is right, but you don&#39;t need the `--slurp` mode/`-s`, which puts the whole JSON within an array. Dropping it should work as expected\r\n\r\nYou can do a manual verification by doing `jq -s . json` which would show your whole JSON wrapped inside the array `[..]`\r\n\r\n    jq --argjson data \\\r\n       &#39;{&quot;biomes&quot;: &quot;pc/1.15.2&quot;,&quot;blocks&quot;: &quot;pc/1.15.2&quot;,&quot;entities&quot;: &quot;pc/1.15.2&quot;,&quot;items&quot;: &quot;pc/1.15.2&quot;,&quot;recipes&quot;: &quot;pc/1.15.2&quot;}&#39; \\\r\n          &#39;.pc |= with_entries(select(.key==&quot;1.15.2&quot;).value += $data)&#39; json",
                "title": "JQ Error: Cannot index array with string &quot;pc&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1588834902,
        "creation_date": 1588829415,
        "last_edit_date": 1588834902,
        "question_id": 61650539,
        "body_markdown": "I have a JSON File with - from what I understand - , objects listed:\r\n\r\n    {\r\n      &quot;pc&quot;: {\r\n        &quot;1.15.2&quot;: {\r\n          &quot;protocol&quot;: &quot;pc/1.15.2&quot;,\r\n          &quot;version&quot;: &quot;pc/1.15.2&quot;,\r\n          &quot;language&quot;: &quot;pc/1.15.2&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI want it to look like this:\r\n\r\n    {\r\n      &quot;pc&quot;: {\r\n        &quot;1.15.2&quot;: {\r\n          &quot;protocol&quot;: &quot;pc/1.15.2&quot;,\r\n          &quot;version&quot;: &quot;pc/1.15.2&quot;,\r\n          &quot;language&quot;: &quot;pc/1.15.2&quot;,\r\n          &quot;biomes&quot;: &quot;pc/1.15.2&quot;,\r\n          &quot;blocks&quot;: &quot;pc/1.15.2&quot;,\r\n          &quot;entities&quot;: &quot;pc/1.15.2&quot;,\r\n          &quot;items&quot;: &quot;pc/1.15.2&quot;,\r\n          &quot;recipes&quot;: &quot;pc/1.15.2&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI am using JQ to add objects to the 1.15.2 array:\r\n\r\n    cat $DP_PATH/dataPaths.json | jq -s &#39;.pc.&quot;1.15.2&quot; += {&quot;biomes&quot;: &quot;pc/1.15.2&quot;,&quot;blocks&quot;: &quot;pc/1.15.2&quot;,&quot;entities&quot;: &quot;pc/1.15.2&quot;,&quot;items&quot;: &quot;pc/1.15.2&quot;,&quot;recipes&quot;: &quot;pc/1.15.2&quot;}&#39; &gt; $DP_PATH/tmp.json\r\n\r\nHowever, on the above command I get:\r\n\r\n    jq: error (at &lt;stdin&gt;:501): Cannot index array with string &quot;pc&quot;\r\n\r\nI do not understand why it&#39;s looking for an ARRAY? aren&#39;t arrays indicated with []?\r\nHow can I add the objects to the json?",
        "link": "https://stackoverflow.com/questions/61650539/jq-error-cannot-index-array-with-string-pc",
        "title": "JQ Error: Cannot index array with string &quot;pc&quot;"
    },
    {
        "tags": [
            "python",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1589052458,
                "creation_date": 1589052458,
                "answer_id": 61702507,
                "question_id": 61652099,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I understand the question correctly, you want to call the python script `check_account.py` from the shell script that you have written. This is intended because `check_account.py` is getting used at multiple places and you do not want to change its functionality.\r\n\r\nThe jq command that you have written in the above script is able to get the AccountId and aggregated value of number_of_requests. Now, you want to call `check_account.py` with AccountId as a parameter. The script below is the implementation of the same.\r\n\r\n \r\n\r\n    #!/bin/bash\r\n    \r\n    ResultsDir=$1\r\n    accountIds=`cat input.js | jq -nr &#39;[inputs | .results[] | map( { (.field) : .value} ) | add] | group_by(.AccountId)| map([.[0].AccountId, (map(.number_of_requests|tonumber) | add)])| sort_by(.[1]) | reverse| &quot;\\(.[]) &quot;&#39; | jq -r .[0]`\r\n    echo $accountIds\r\n    numberOfRequests=`cat input.js | jq -nr &#39;[inputs | .results[] | map( { (.field) : .value} ) | add] | group_by(.AccountId)| map([.[0].AccountId, (map(.number_of_requests|tonumber) | add)])| sort_by(.[1]) | reverse| &quot;\\(.[]) &quot;&#39; | jq -r .[1]`\r\n    echo &quot;Results saved in file query-results&quot;\r\n    echo &quot;AccountID : Number of Requests : Type&quot; &gt; $ResultsDir/query-results\r\n    echo &quot;$list&quot;\r\n    echo &quot;Will call the check_account.py now&quot;\r\n    accountIdsArray=($(echo $accountIds | tr &quot; &quot; &quot;\\n&quot;)) # to convert into array so that i can loop on the array\r\n    numberOfRequestsArray=($(echo $numberOfRequests | tr &quot; &quot; &quot;\\n&quot;))\r\n    len=${#accountIdsArray[@]} # to find the length of the array\r\n    echo $len\r\n      for (( i=0; i&lt;=$((len-1)); i++ )); do \r\n      \t   value=${accountIdsArray[$i]} \r\n           echo &quot;index $i - value $value&quot;\r\n           account=$(python check_account.py $value)\r\n           echo $value ${numberOfRequestsArray[$i]} $account &gt;&gt; $ResultsDir/query-results\r\n      done\r\n\r\n   \r\n\r\nI do not have the implementation of the `check_account.py`. So, I wrote the following python script to validate my shell script.\r\n\r\n    #!/usr/bin/env python\r\n    import sys\r\n    a = int(sys.argv[1])\r\n    \r\n    def my_function():\r\n    \tif a == 11352:\r\n    \t\tprint(&quot;Internal&quot;)\r\n    \tif a == 74923:\r\n    \t\tprint(&quot;External&quot;)\r\n    \r\n    if __name__ == &quot;__main__&quot;:\r\n        my_function()\r\n\r\nOne key thing to note here is that the shell script by default **captures the &quot;Standard Output&quot;** (STDOUT) of the Python process. To capture that you simply need to use $(). Inside the parenthesis, you can write your command to call the python script.\r\n\r\nBy executing the shell script like this \r\n\r\n    ./final-test.sh /Users/ajay/Desktop/\r\nI was able to get a file named query-results. Content of the file query-results is following:\r\n\r\n    AccountID : Number of Requests : Type\r\n    11352 : 426494 : Internal\r\n    74923 : 238566 : External\r\n\r\nHope this helps in understanding how to call python script from the shell script and capture it&#39;s result in the shell script.",
                "title": "Aggregating JSON results with JQ and passing argument to a python code"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1597209327,
        "creation_date": 1588836468,
        "last_edit_date": 1597209327,
        "question_id": 61652099,
        "body_markdown": "I have to aggregate a few JSON results from a site. Because the site has a query concurrency limit and the queries timeout, the time frame for the queries have to be divided. So I am left with a JSON as follows:\r\n\r\n```\r\n{\r\n      &quot;results&quot;: [\r\n          [\r\n              {\r\n                  &quot;field&quot;: &quot;AccountId&quot;,\r\n                  &quot;value&quot;: &quot;11352&quot;\r\n              },\r\n              {\r\n                  &quot;field&quot;: &quot;number_of_requests&quot;,\r\n                  &quot;value&quot;: &quot;241398&quot;\r\n              }\r\n          ],\r\n          [\r\n              {\r\n                  &quot;field&quot;: &quot;AccountId&quot;,\r\n                  &quot;value&quot;: &quot;74923&quot;\r\n              },\r\n              {\r\n                  &quot;field&quot;: &quot;number_of_requests&quot;,\r\n                  &quot;value&quot;: &quot;238566&quot;\r\n              }\r\n          ]\r\n          ],\r\n&quot;statistics&quot;: {\r\n          &quot;recordsMatched&quot;: 502870.0,\r\n          &quot;recordsScanned&quot;: 165908292.0,\r\n          &quot;bytesScanned&quot;: 744173091162.0\r\n      },\r\n      &quot;status&quot;: &quot;Complete&quot;\r\n}\r\n{\r\n      &quot;results&quot;: [\r\n          [\r\n              {\r\n                  &quot;field&quot;: &quot;AccountId&quot;,\r\n                  &quot;value&quot;: &quot;11352&quot;\r\n              },\r\n              {\r\n                  &quot;field&quot;: &quot;number_of_requests&quot;,\r\n                  &quot;value&quot;: &quot;185096&quot;\r\n              }\r\n           ]\r\n          ],\r\n&quot;statistics&quot;: {\r\n          &quot;recordsMatched&quot;: 502870.0,\r\n          &quot;recordsScanned&quot;: 165908292.0,\r\n          &quot;bytesScanned&quot;: 744173091162.0\r\n      },\r\n      &quot;status&quot;: &quot;Complete&quot;\r\n  }\r\n```\r\n\r\n\r\nMy objective is to aggregate the results as well as feed account ID as an argument to a python code that prints a string output.\r\nThe python code runs as follows:\r\n\r\npython check_account.py 11352\r\n\r\nInternal\r\n\r\npython check_account.py 74923\r\n\r\nExternal\r\n\r\nSo my desired output to be added to the file is:\r\n\r\nAccountID : Number of Requests : Type\r\n\r\n11352 : 426494 : Internal\r\n\r\n74923 : 238566 : External\r\n\r\nFor now, I have a python code, with an API that calls the relevant functions and prints Internal or External as the output.\r\n\r\nAnd the following script in bash using jq:\r\n\r\n```\r\n#!/bin/zsh\r\n\r\nResultsDir=$1\r\n\r\nlist=$(jq -nr &#39;\r\n[inputs | .results[] | map( { (.field) : .value} ) | add]\r\n| group_by(.AccountId)\r\n| map([.[0].AccountId, (map(.number_of_requests|tonumber) | add)])\r\n| sort_by(.[1]) | reverse\r\n| &quot;\\(.[]) &quot; &#39; $ResultsDir)\r\necho &quot;Results saved in file query-results&quot;\r\necho &quot;ACCOUNT ID : #_OF_REQUESTS&quot; &gt; $ResultsDir/query-results\r\necho &quot;$list&quot; &gt;&gt; $ResultsDir/query-results\r\n```\r\n\r\nThere is a way of doing the above in the python code itself but I was wondering if there was a way to leverage the python script above as the python code is leveraged in multiple other functions.",
        "link": "https://stackoverflow.com/questions/61652099/aggregating-json-results-with-jq-and-passing-argument-to-a-python-code",
        "title": "Aggregating JSON results with JQ and passing argument to a python code"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "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": 1588843783,
                "post_id": 61653907,
                "comment_id": 109057916,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1931724,
                    "reputation": 319,
                    "user_id": 1740982,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/HpXzA.jpg?s=256",
                    "display_name": "Mario Super",
                    "link": "https://stackoverflow.com/users/1740982/mario-super"
                },
                "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": 1588843885,
                "post_id": 61653907,
                "comment_id": 109057973,
                "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": 1588844234,
                "post_id": 61653907,
                "comment_id": 109058163,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1931724,
                    "reputation": 319,
                    "user_id": 1740982,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/HpXzA.jpg?s=256",
                    "display_name": "Mario Super",
                    "link": "https://stackoverflow.com/users/1740982/mario-super"
                },
                "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": 1588844386,
                "post_id": 61653907,
                "comment_id": 109058258,
                "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": 1588844718,
                "post_id": 61653907,
                "comment_id": 109058448,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1931724,
                    "reputation": 319,
                    "user_id": 1740982,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/HpXzA.jpg?s=256",
                    "display_name": "Mario Super",
                    "link": "https://stackoverflow.com/users/1740982/mario-super"
                },
                "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": 1588844868,
                "post_id": 61653907,
                "comment_id": 109058527,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1588845447,
                "creation_date": 1588845447,
                "answer_id": 61654926,
                "question_id": 61653907,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need `bash` processing at all for this. You can use the `range()` function in `jq` to create the number range from 1 to million and create multiple objects using the `reduce()` function\r\n\r\n    jq -n &#39;reduce range(1; 1000000) as $data (.; . + [{&quot;field&quot;: { &quot;empID&quot;: $data, &quot;location&quot;: &quot;India&quot;}}])&#39;\r\n\r\nThis creates a million objects inside the array with `empID` set, starting from 1. Modify the value inside `range()` to customize the numbers.",
                "title": "How to pass dynamic values to JSON with duplicate fields"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1588845959,
                "creation_date": 1588845959,
                "answer_id": 61655106,
                "question_id": 61653907,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for the `range` built-in.\r\n```\r\n.[] | [.field.empID = range(1;1000000)]\r\n```\r\n&lt;sup&gt;[demo at jqplay.org](https://jqplay.org/s/6Gss5N6Fxu)&lt;/sup&gt;",
                "title": "How to pass dynamic values to JSON with duplicate fields"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1588846146,
        "creation_date": 1588842321,
        "last_edit_date": 1588846146,
        "question_id": 61653907,
        "body_markdown": "\r\nI have a usecase where i have to send REST request in bulk.\r\n\r\nJSON File: emp.json\r\n\r\n    [\r\n        {\r\n            &quot;field&quot;: {\r\n                &quot;empID&quot;: &quot;sapid&quot;,\r\n                &quot;location&quot;: &quot;India&quot;\r\n            }\r\n        }\r\n    ]\r\n\r\nMy shell script:\r\n\r\n    func emp_details\r\n    {\r\n    START=1\r\n    END=1000000\r\n    CURRENT=1\r\n    while [ $END -gt $CURRENT ];\r\n    do\r\n    CURRENT=$((CURRENT+1))\r\n    cat emp.json | jq --arg new &quot;$CURRENT&quot; &#39;.[].field.empID |= $new&#39; &gt; temp.json\r\n    cat temp.json\r\n    curl &lt;REST Server URL with temp.json as input&gt; &quot;Content-Type: application/json&quot; -d @temp.json\r\n    done\r\n    }\r\n\r\nThe above json and script is working. I am able send the request properly.\r\nI am looking for an approach to prepare the json file with mutiple empID before triggering the CURL.\r\n\r\nFor Example:\r\n\r\n    [\r\n        {\r\n            &quot;field&quot;: {\r\n                &quot;empID&quot;: &quot;sapid&quot;,\r\n                &quot;location&quot;: &quot;India&quot;,            \r\n            }\r\n        },\r\n    \t{\r\n            &quot;field&quot;: {\r\n                &quot;empID&quot;: &quot;sapid&quot;,\r\n                &quot;location&quot;: &quot;India&quot;,            \r\n            }\r\n        },\r\n    \t{\r\n            &quot;field&quot;: {\r\n                &quot;empID&quot;: &quot;sapid&quot;,\r\n                &quot;location&quot;: &quot;India&quot;,            \r\n            }\r\n        }\r\n    ]\r\n\r\nBut am not sure how to traverse through each individual empID field and replace its value with dynamic CURRENT values.\r\n\r\nAny help is much appreciated ",
        "link": "https://stackoverflow.com/questions/61653907/how-to-pass-dynamic-values-to-json-with-duplicate-fields",
        "title": "How to pass dynamic values to JSON with duplicate fields"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1588849278,
                "last_edit_date": 1588849278,
                "creation_date": 1588848572,
                "answer_id": 61655940,
                "question_id": 61655382,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "*some sub key filter mechanism* can be implemented as follows.\r\n```\r\ndef pick(paths):\r\n  . as $in\r\n  | reduce path(paths) as $path (null;\r\n    setpath($path; $in | getpath($path))\r\n  );\r\n```\r\nAnd you can use it like:\r\n```\r\n.[] | pick(.name, .colors.head.eyes)\r\n```\r\n&lt;sup&gt;[demo at jqplay.org](https://jqplay.org/s/cXw8yBAB7S)&lt;/sup&gt;",
                "title": "filter certain (sub) keys from a JSON value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1610164779,
                "last_edit_date": 1610164779,
                "creation_date": 1605677764,
                "answer_id": 64887653,
                "question_id": 61655382,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are plenty libraries out there. We really like [object-fields][1] (build on top of [object-scan][2], so it&#39;s fast). It&#39;s especially great if you want to support the fields parameter syntax. Anyways, here is how you could answer your question\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    // const objectFields = require(&#39;object-fields&#39;);\r\n    \r\n    const input = [{ name: &#39;foo&#39;, age: 12, weight: 23, colors: { head: { hair: &#39;blue&#39;, eyes: &#39;green&#39; } } }, { name: &#39;bar&#39;, age: 42, weight: 54, colors: { head: { hair: &#39;blue&#39;, eyes: &#39;blue&#39; } } }, { name: &#39;baz&#39;, age: 65, weight: 439, colors: { head: { hair: &#39;green&#39;, eyes: &#39;red&#39; } } }];\r\n    \r\n    const retain = objectFields.Retainer([&#39;name&#39;, &#39;colors.head.eyes&#39;]);\r\n    retain(input);\r\n    console.log(input);\r\n    // =&gt; [ { name: &#39;foo&#39;, colors: { head: { eyes: &#39;green&#39; } } }, { name: &#39;bar&#39;, colors: { head: { eyes: &#39;blue&#39; } } }, { name: &#39;baz&#39;, colors: { head: { eyes: &#39;red&#39; } } } ]\r\n\r\n&lt;!-- language: lang-html --&gt;\r\n\r\n    &lt;script src=&quot;https://bundle.run/object-fields@2.0.19&quot;&gt;&lt;/script&gt;\r\n\r\n&lt;!-- language: lang-css --&gt;\r\n\r\n    .as-console-wrapper {max-height: 100% !important; top: 0}\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n_Disclaimer_: I&#39;m the author of [object-fields](https://www.npmjs.com/package/object-fields)\r\n\r\n\r\n  [1]: https://github.com/blackflux/object-fields#readme\r\n  [2]: https://github.com/blackflux/object-scan",
                "title": "filter certain (sub) keys from a JSON value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1610164779,
        "creation_date": 1588846845,
        "last_edit_date": 1598368243,
        "question_id": 61655382,
        "body_markdown": "I have a relatively huge JSON file that contains lot of data that I do not need.\r\n\r\nI would like to just keep the elements that are of interest for me but I want to keep the general structure.\r\n\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;  : &quot;foo&quot;,\r\n    &quot;age&quot;   : 12,\r\n    &quot;weight&quot;: 23, \r\n    &quot;colors&quot;: {\r\n      &quot;head&quot;:{\r\n        &quot;hair&quot;: &quot;blue&quot;,\r\n        &quot;eyes&quot;: &quot;green&quot;\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;name&quot;  : &quot;bar&quot;,\r\n    &quot;age&quot;   : 42,\r\n    &quot;weight&quot;: 54, \r\n    &quot;colors&quot;: {\r\n      &quot;head&quot;:{\r\n        &quot;hair&quot;: &quot;blue&quot;,\r\n        &quot;eyes&quot;: &quot;blue&quot;\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;name&quot;  : &quot;baz&quot;,\r\n    &quot;age&quot;   : 65,\r\n    &quot;weight&quot;: 439, \r\n    &quot;colors&quot;: {\r\n      &quot;head&quot;:{\r\n        &quot;hair&quot;: &quot;green&quot;,\r\n        &quot;eyes&quot;: &quot;red&quot;\r\n      }\r\n    }\r\n  }\r\n\r\n]\r\n```\r\n\r\nThe output should look like:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;foo&quot;,\r\n  &quot;colors&quot;: {\r\n    &quot;head&quot;: {\r\n      &quot;eyes&quot;: &quot;green&quot;\r\n    }\r\n  }\r\n}\r\n{\r\n  &quot;name&quot;: &quot;bar&quot;,\r\n  &quot;colors&quot;: {\r\n    &quot;head&quot;: {\r\n      &quot;eyes&quot;: &quot;blue&quot;\r\n    }\r\n  }\r\n}\r\n{\r\n  &quot;name&quot;: &quot;baz&quot;,\r\n  &quot;colors&quot;: {\r\n    &quot;head&quot;: {\r\n      &quot;eyes&quot;: &quot;red&quot;\r\n    }\r\n  }\r\n}\r\n\r\n```\r\nMy actual input object has ~100 leaf keys per top level object and I need ~10 and nearly all on different levels of the hierarchy.\r\n\r\nI looked into some json processing APIs (e.g. javascript, lodash, and jq) and could not find such a mechanism. They mostly rely on creating new objects in plain syntax that require to construct the object from scratch.\r\n\r\nLike:\r\n```\r\njq &#39;[.[]| {name: .name, colors:{head:{eyes: .colors.head.eyes}}}]&#39;\r\n```\r\nwith deep hierarchies this is a bit messy.\r\n\r\nDid I miss something that either allows easier specifying deep objects keys like:\r\n```\r\n.[] | {name: .name, colors.head.eyes = .colors.head.eyes}\r\n```\r\nor some even more convenient: some sub key filter mechanism like\r\n```\r\n.[] | filteKeys([&quot;name&quot;, &quot;colors.head.eyes&quot;])\r\n```\r\n\r\nI would prefer some command line able program, so I tried with JQ.",
        "link": "https://stackoverflow.com/questions/61655382/filter-certain-sub-keys-from-a-json-value",
        "title": "filter certain (sub) keys from a JSON value"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1588847642,
                "creation_date": 1588847642,
                "answer_id": 61655611,
                "question_id": 61655397,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were close. Assuming the number of objects in `resources` equals the number of child documents, this should do the trick:\r\n```\r\njq &#39;.resources[].properties.template |= . + input&#39; parent children...\r\n```\r\n&lt;sup&gt;[demo at jqplay.org](https://jqplay.org/s/EEBSWKECsF)&lt;/sup&gt;",
                "title": "Using jq to merge child files into a master file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1588847642,
        "creation_date": 1588846905,
        "question_id": 61655397,
        "body_markdown": "There are plenty of `jq`-related questions about merging JSON documents, but they all seem to be about merging documents with the same structure.\r\n\r\nMy problem is different, in that I need to merge child documents into a parent document, where the child and parent documents have a different structure.\r\n\r\nThe parent document looks like this:\r\n\r\n```json\r\n{\r\n  &quot;resources&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;child0&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;template&quot;: {}\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child1&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;template&quot;: {}\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child2&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;template&quot;: {}\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nWhat I need to do is merge in child documents at `.resources[].properties.template`, such that the first file is at `.resources[0].properties.template`, the second file is at `.resources[1].properties.template` etc.\r\n\r\nNote the structure of the child documents is not important here, as I want to merge them in their entirety.\r\n\r\nI have actually got this to work, but using multiple commands:\r\n\r\n```bash\r\njq &#39;.resources[0].properties.template += input&#39; main.json child0.json &gt; temp0.json\r\njq &#39;.resources[1].properties.template += input&#39; temp0.json child1.json &gt; temp1.json\r\njq &#39;.resources[2].properties.template += input&#39; temp1.json child2.json &gt; temp2.json\r\nmv temp2.json merged.json\r\nrm temp*.json\r\n```\r\n\r\nThis is pretty ugly - I&#39;m looking for a single `jq` command that can merge in the child files.",
        "link": "https://stackoverflow.com/questions/61655397/using-jq-to-merge-child-files-into-a-master-file",
        "title": "Using jq to merge child files into a master file"
    },
    {
        "tags": [
            "function",
            "syntax",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1588858136,
                "last_edit_date": 1588858136,
                "creation_date": 1588854690,
                "answer_id": 61657925,
                "question_id": 61657757,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In brief, jq defines range/1 as:\r\n\r\n    def range($x): range(0;$x);\r\n\r\nSo range(0,$n) evaluates to\r\n\r\n    range(0), range($n)\r\n\r\nwhich yields the stream `empty, range($n)`, which is equivalent to the stream \r\n\r\n    range(0;$n)\r\n\r\nThe main point, perhaps, is that the &quot;comma&quot; operator can be used freely.",
                "title": "Why does jq allow range() function to accept comma as arguments separator when semi-colon is documented?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1588951678,
        "creation_date": 1588854222,
        "last_edit_date": 1588951678,
        "question_id": 61657757,
        "body_markdown": "I&#39;m trying to find out why the `range()` function in `jq` allows arguments separated by `,` when the more general style is to separate arguments by `;` for other functions? I know for a fact that if `sub()` or other functions used with `,` would throw a not-defined error most likely due to prototype mismatch.\r\n\r\nBut why is range behaving this way for the `range(from;upto)` prototype \r\n\r\n    $ jq -n &#39;range(0; 4)&#39;\r\n    0\r\n    1\r\n    2\r\n    3\r\n\r\nand \r\n\r\n    $ jq -n &#39;range(0, 4)&#39;\r\n    0\r\n    1\r\n    2\r\n    3\r\n\r\nFor `range(from;upto;by)` using `,` misbehaves, but I would still like a warning to be thrown nevertheless. \r\n\r\n    # runs as if did range(0; 2)\r\n    $ jq -n &#39;range(0, 4; 2)&#39;\r\n    0\r\n    1\r\n\r\nand\r\n\r\n    # runs as if did range(0; 4) + range(0; 2)\r\n    $ jq -n &#39;range(0; 4, 2)&#39;\r\n    0\r\n    1\r\n    2\r\n    3\r\n    0\r\n    1\r\n\r\nThis is seen in both `jq-1.6` and `jq-1.5`. Since the official documentation does not talk about type the prototype involving `,` and is not likely a bug, how should the behavior with `,` be interpreted?\r\n",
        "link": "https://stackoverflow.com/questions/61657757/why-does-jq-allow-range-function-to-accept-comma-as-arguments-separator-when-s",
        "title": "Why does jq allow range() function to accept comma as arguments separator when semi-colon is documented?"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "loops",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1588962159,
                "last_edit_date": 1588962159,
                "creation_date": 1588958854,
                "answer_id": 61684641,
                "question_id": 61657791,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You cannot set environment variable directly from jq (cf. [manual](https://stedolan.github.io/jq/manual/#$ENV,env)). What you can do is to generate a series of bash declarations for the `declare` builtin. I suggest to store the declarations in an intermediate bash array (with `mapfile`) processed directly by `declare` so that you can stay away from hazardous commands like `eval`.\r\n\r\n    mapfile -t &lt; &lt;(\r\n        jq --raw-output &#39;\r\n            def m(exp): first(.[0] | path(exp)[-1]) + &quot;=(&quot; + (map(exp) | @sh) + &quot;)&quot;;\r\n            [ .coordinates[].xyz[] ]\r\n            | m(.x), m(.y), m(.z), m(.id), m(.inner_arr[].a), m(.inner_arr[].b)\r\n        &#39; input\r\n    )\r\n\r\n    declare -a &quot;${MAPFILE[@]}&quot;\r\n\r\nThe jq script packs all `xyz` objects in a single array and filters it with the `m` function for each field represented as a path expression. The function returns a string formatted as `field=(val1 val2... valN)`, where the field name is the last component of the path expression, i.e. `x` for `.x` and `a` for `.inner_arr[].a` (extracted on the first item of the array).\r\n\r\nThen you can check the shell variables with `declare -p var` or `${var[@]}`. `${var}` refers to the first element only.\r\n\r\n    declare -p MAPFILE\r\n    declare -p z\r\n    echo a: &quot;${a[@]}&quot; / size = ${#a[@]}\r\n\r\n---\r\n\r\n    declare -a MAPFILE=([0]=&quot;x=(1 8 10 7 2 51)&quot; [1]=&quot;y=(2 9 6 3 6 9)&quot; [2]=&quot;z=(4 9 9 0 4 2)&quot; [3]=&quot;id=(99 100 101 99 100 101)&quot; [4]=&quot;a=(1 3 1 3 1 3 1 3 1 3 1 3)&quot; [5]=&quot;b=(2 4 2 4 2 4 2 4 2 4 2 4)&quot;)\r\n    declare -a z=([0]=&quot;4&quot; [1]=&quot;9&quot; [2]=&quot;9&quot; [3]=&quot;0&quot; [4]=&quot;4&quot; [5]=&quot;2&quot;)\r\n    a: 1 3 1 3 1 3 1 3 1 3 1 3 / size = 12\r\n",
                "title": "jq - parse structure and save values in bash variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1588962159,
        "creation_date": 1588854312,
        "question_id": 61657791,
        "body_markdown": "I have a json input as follow\r\n\r\n    {\r\n      &quot;unique&quot;: 1924,\r\n      &quot;coordinates&quot;: [\r\n        {\r\n          &quot;time&quot;: &quot;2015-01-25T00:00:01.683&quot;,\r\n          &quot;xyz&quot;: [\r\n            {\r\n              &quot;z&quot;: 4,\r\n              &quot;y&quot;: 2,\r\n              &quot;x&quot;: 1,\r\n              &quot;id&quot;: 99,\r\n              &quot;inner_arr&quot; : [\r\n              {\r\n                  &quot;a&quot;: 1,\r\n                  &quot;b&quot;: 2\r\n              },\r\n              {\r\n                  &quot;a&quot;: 3,\r\n                  &quot;b&quot;: 4\r\n              }\r\n              ]\r\n            },\r\n            {\r\n              &quot;z&quot;: 9,\r\n              &quot;y&quot;: 9,\r\n              &quot;x&quot;: 8,\r\n              &quot;id&quot;: 100,\r\n              &quot;inner_arr&quot; : [\r\n              {\r\n                  &quot;a&quot;: 1,\r\n                  &quot;b&quot;: 2\r\n              },\r\n              {\r\n                  &quot;a&quot;: 3,\r\n                  &quot;b&quot;: 4\r\n              }\r\n              ]\r\n            },\r\n            {\r\n              &quot;z&quot;: 9,\r\n              &quot;y&quot;: 6,\r\n              &quot;x&quot;: 10,\r\n              &quot;id&quot;: 101,\r\n              &quot;inner_arr&quot; : [\r\n              {\r\n                  &quot;a&quot;: 1,\r\n                  &quot;b&quot;: 2\r\n              },\r\n              {\r\n                  &quot;a&quot;: 3,\r\n                  &quot;b&quot;: 4\r\n              }\r\n              ]\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;time&quot;: &quot;2015-01-25T00:00:02.790&quot;,\r\n          &quot;xyz&quot;: [\r\n            {\r\n              &quot;z&quot;: 0,\r\n              &quot;y&quot;: 3,\r\n              &quot;x&quot;: 7,\r\n              &quot;id&quot;: 99,\r\n             &quot;inner_arr&quot; : [\r\n              {\r\n                  &quot;a&quot;: 1,\r\n                  &quot;b&quot;: 2\r\n              },\r\n              {\r\n                  &quot;a&quot;: 3,\r\n                  &quot;b&quot;: 4\r\n              }\r\n              ]\r\n            },\r\n            {\r\n              &quot;z&quot;: 4,\r\n              &quot;y&quot;: 6,\r\n              &quot;x&quot;: 2,\r\n              &quot;id&quot;: 100,\r\n              &quot;inner_arr&quot; : [\r\n              {\r\n                  &quot;a&quot;: 1,\r\n                  &quot;b&quot;: 2\r\n              },\r\n              {\r\n                  &quot;a&quot;: 3,\r\n                  &quot;b&quot;: 4\r\n              }\r\n              ]\r\n            },\r\n            {\r\n              &quot;z&quot;: 2,\r\n              &quot;y&quot;: 9,\r\n              &quot;x&quot;: 51,\r\n              &quot;id&quot;: 101,\r\n              &quot;inner_arr&quot; : [\r\n              {\r\n                  &quot;a&quot;: 1,\r\n                  &quot;b&quot;: 2\r\n              },\r\n              {\r\n                  &quot;a&quot;: 3,\r\n                  &quot;b&quot;: 4\r\n              }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to parse this input with jq and store values in bash arrays:\r\n\r\n\r\n    #!/bin/bash\r\n    \r\n    z=()\r\n    x=()\r\n    y=()\r\n    id=()\r\n    a=()\r\n    b=()\r\n    \r\n    jq --raw-output &#39;.coordinates[] | .xyz[] | (.z) as $z, (.y) as $y,7 (.x) as $x, (.id) as $id, .inner_arr[].a $a, .inner_arr[].b as $b | $z, $y, $x, $id, $a, $b&#39; &lt;&lt;&lt; &quot;$input&quot;\r\n    \r\n    \r\n    echo -e &quot;${z}&quot;\r\n\r\nExpected output for above echo command:\r\n\r\n    4\r\n    9\r\n    9\r\n    0\r\n    4\r\n    2\r\n\r\n    echo -e &quot;${a}&quot;\r\n\r\nExpected output for above echo command:\r\n\r\n\r\n    1\r\n    3\r\n    1\r\n    3\r\n    1\r\n    3\r\n    1\r\n    3\r\n    1\r\n    3\r\n    1\r\n    3\r\n\r\nHow can I do it with jq with a single jq call looping through all arrays in a cascading fashion?\r\nI want to save CPU by calling jq just once and extract all single or array values.\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61657791/jq-parse-structure-and-save-values-in-bash-variable",
        "title": "jq - parse structure and save values in bash variable"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1588926815,
                "last_edit_date": 1588926815,
                "creation_date": 1588926572,
                "answer_id": 61675101,
                "question_id": 61674867,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pair corresponding elements using `transpose`, and create a new array with sums of them.\r\n```\r\ntranspose | [.[0][0]] + map(add)[1:]\r\n```\r\n&lt;sup&gt;[demo at jqplay.org](https://jqplay.org/s/X1NbZxbeoH)&lt;/sup&gt;",
                "title": "Pair and add corresponding elements in multiple arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1588926946,
        "creation_date": 1588925702,
        "last_edit_date": 1588926946,
        "question_id": 61674867,
        "body_markdown": "I have a json data like : \r\n\r\n    [\r\n      [\r\n        &quot;2020-05-07T16:30:00.000+0530&quot;,\r\n        1,\r\n        29,\r\n        693,\r\n        0,\r\n        7,\r\n        3663,\r\n        7413\r\n      ],\r\n      [\r\n        &quot;2020-05-07T15:30:00.000+0530&quot;,\r\n        0,\r\n        16,\r\n        996,\r\n        3,\r\n        13,\r\n        4452,\r\n        10106\r\n      ]\r\n    ]\r\n\r\nUsing JQ, I want to add the corresponding elements of the both array and result a new array. In case of date string the value from one of the array will be fine. The Expected output is\r\n\r\n    [\r\n            &quot;2020-05-07T16:30:00.000+0530&quot;,\r\n            1,\r\n            45,\r\n            1689,\r\n            3,\r\n            20,\r\n            8115,\r\n            17519\r\n          ]\r\n\r\nPlease can u suggest the solution?",
        "link": "https://stackoverflow.com/questions/61674867/pair-and-add-corresponding-elements-in-multiple-arrays",
        "title": "Pair and add corresponding elements in multiple arrays"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1588962872,
                "post_id": 61683452,
                "comment_id": 109112433,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2022415,
                    "reputation": 2248,
                    "user_id": 1808261,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://i.sstatic.net/8f2eP.png?s=256",
                    "display_name": "dtmland",
                    "link": "https://stackoverflow.com/users/1808261/dtmland"
                },
                "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": 1588964597,
                "post_id": 61683452,
                "comment_id": 109113281,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1588962856,
                "last_edit_date": 1588962856,
                "creation_date": 1588957866,
                "answer_id": 61684338,
                "question_id": 61683452,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can get paths to non-iterable values at any level in the input using `paths(scalars)`, and update them with *empty* values using `reduce` and `setpath`-`getpath` built-ins.\r\n```\r\n{null: null, boolean: false, number: 0, string: &quot;&quot;} as $e\r\n| reduce paths(scalars) as $p (.; setpath($p; $e[getpath($p)|type])\r\n```\r\n&lt;sup&gt;[demo at jqplay.org](https://jqplay.org/s/72RkJXj2h3)&lt;/sup&gt;",
                "title": "Use jq to &quot;clear&quot; values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1588962856,
        "creation_date": 1588954776,
        "question_id": 61683452,
        "body_markdown": "Using arbitrary [tag:json] with [tag:jq] how can I print a version with the &quot;values&quot; cleared to &quot;empty&quot;. (sorry if I am butchering the terminology). \r\n\r\nSo basically from this:\r\n\r\n    {\r\n      &quot;colors&quot;: [\r\n        {\r\n          &quot;color&quot;: &quot;black&quot;,\r\n          &quot;category&quot;: &quot;hue&quot;,\r\n          &quot;type&quot;: &quot;primary&quot;,\r\n          &quot;code&quot;: {\r\n            &quot;rgba&quot;: [255,255,255,1],\r\n            &quot;hex&quot;: &quot;#000&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nto this:\r\n\r\n\r\n    {\r\n      &quot;colors&quot;: [\r\n        {\r\n          &quot;color&quot;: &quot;&quot;,\r\n          &quot;category&quot;: &quot;&quot;,\r\n          &quot;type&quot;: &quot;&quot;,\r\n          &quot;code&quot;: {\r\n            &quot;rgba&quot;: ,\r\n            &quot;hex&quot;: &quot;&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nOr this:\r\n\r\n    {\r\n      &quot;kind&quot;: &quot;youtube#searchListResponse&quot;,\r\n      &quot;etag&quot;: &quot;\\&quot;m2yskBQFythfE4irbTIeOgYYfBU/PaiEDiVxOyCWelLPuuwa9LKz3Gk\\&quot;&quot;,\r\n      &quot;nextPageToken&quot;: &quot;CAUQAA&quot;,\r\n      &quot;regionCode&quot;: &quot;KE&quot;,\r\n      &quot;pageInfo&quot;: {\r\n        &quot;totalResults&quot;: 4249,\r\n        &quot;resultsPerPage&quot;: 5\r\n      },\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;kind&quot;: &quot;youtube#searchResult&quot;,\r\n          &quot;etag&quot;: &quot;\\&quot;m2yskBQFythfE4irbTIeOgYYfBU/2dIR9BTfr7QphpBuY3hPU-h5u-4\\&quot;&quot;,\r\n          &quot;id&quot;: {\r\n            &quot;kind&quot;: &quot;youtube#video&quot;,\r\n            &quot;videoId&quot;: &quot;IirngItQuVs&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nTo this (or a rough equivalent):\r\n\r\n    {\r\n      &quot;kind&quot;: &quot;&quot;,\r\n      &quot;etag&quot;: &quot;&quot;,\r\n      &quot;nextPageToken&quot;: &quot;&quot;,\r\n      &quot;regionCode&quot;: &quot;&quot;,\r\n      &quot;pageInfo&quot;: {\r\n        &quot;totalResults&quot;: ,\r\n        &quot;resultsPerPage&quot;:\r\n      },\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;kind&quot;: &quot;&quot;,\r\n          &quot;etag&quot;: &quot;&quot;,\r\n          &quot;id&quot;: {\r\n            &quot;kind&quot;: &quot;&quot;,\r\n            &quot;videoId&quot;: &quot;&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/61683452/use-jq-to-clear-values",
        "title": "Use jq to &quot;clear&quot; values"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588962780,
                "post_id": 61685700,
                "comment_id": 109112397,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14231204,
                    "reputation": 65,
                    "user_id": 10391150,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/167eebe319842c90bbf5893683c66d83?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Hernan Bernal",
                    "link": "https://stackoverflow.com/users/10391150/hernan-bernal"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588964106,
                "post_id": 61685700,
                "comment_id": 109113027,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1588972815,
                "creation_date": 1588972815,
                "answer_id": 61688270,
                "question_id": 61685700,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Perhaps this will suggest a solution to the kind of problem you have in mind:\r\n\r\n    jq -n &#39;{a:[1],b:[1]} | any(.a, .b; . == [])&#39;\r\n    false\r\n\r\n",
                "title": "what is the best method to check that multiple values are empty using jq?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1588972815,
        "creation_date": 1588962581,
        "last_edit_date": 1588964082,
        "question_id": 61685700,
        "body_markdown": "I&#39;m trying to get a boolean that show me if any value are not empty with jq.\r\n\r\nis possible that `jq &#39;if .a and .b =!&#39;` return true or false ? any exit code maybe ?\r\n\r\nempty:\r\n\r\n    | jq &#39;.a , .b&#39; \r\n    []\r\n    []",
        "link": "https://stackoverflow.com/questions/61685700/what-is-the-best-method-to-check-that-multiple-values-are-empty-using-jq",
        "title": "what is the best method to check that multiple values are empty using jq?"
    },
    {
        "tags": [
            "json",
            "streaming",
            "jq",
            "memory-efficient"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1588998758,
                "last_edit_date": 1588998758,
                "creation_date": 1588969459,
                "answer_id": 61687520,
                "question_id": 61687180,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`foreach` is unnecessary for this case.\r\n```\r\n{key: .[1]}\r\n+ ( inputs\r\n    | select(length == 2)\r\n    | {member: .[0][1], score: .[1]}\r\n  )\r\n```\r\n---\r\nNote: This answers [the initial version of OP](https://stackoverflow.com/revisions/61687180/1).",
                "title": "Expand a fairly large object to smaller objects using --stream"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1589005149,
                "last_edit_date": 1589005149,
                "creation_date": 1588974920,
                "answer_id": 61688727,
                "question_id": 61687180,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution using --stream and `foreach` that can be used for a stream of JSON objects of the type described.  Note that it assumes that &quot;key&quot; appears before &quot;value&quot; in each of the top-level objects.\r\n```\r\necho &#39;{&quot;key&quot;: &quot;key1&quot;, &quot;value&quot;: {&quot;one&quot;: 1, &quot;two&quot;: 2}}&#39; |\r\n    jq -n --stream -c &#39;foreach inputs as $in (null;\r\n       if $in|length == 2\r\n       then if $in[0][0] == &quot;key&quot; then .key=$in[1]\r\n            elif $in[0][0] == &quot;value&quot; \r\n            then .emit = {key: .key, member: $in[0][1], score: $in[1]}\r\n            else .emit=null end\r\n       else .emit=null end;\r\n       select(.emit) | .emit)&#39;\r\n```\r\n",
                "title": "Expand a fairly large object to smaller objects using --stream"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1589264929,
        "creation_date": 1588968061,
        "last_edit_date": 1589264929,
        "question_id": 61687180,
        "body_markdown": "I have the following working jq transform. Input file (input.jsonl):\r\n```\r\n{&quot;key&quot;: &quot;key1&quot;, &quot;value&quot;: {&quot;one&quot;: 1, &quot;two&quot;: 2}}\r\n{&quot;key&quot;: &quot;key2&quot;, &quot;value&quot;: {&quot;three&quot;: 3, &quot;four&quot;: 4}}\r\n```\r\njq transform:\r\n```\r\n$ jq --compact-output &#39;.key as $key|.value|to_entries|map({key: ($key), member:.key, score:(.value|tostring)})|.[]&#39; input.jsonl\r\n```\r\nwhich correctly produces the desired output:\r\n```\r\n{&quot;key&quot;:&quot;key1&quot;,&quot;member&quot;:&quot;one&quot;,&quot;score&quot;:&quot;1&quot;}\r\n{&quot;key&quot;:&quot;key1&quot;,&quot;member&quot;:&quot;two&quot;,&quot;score&quot;:&quot;2&quot;}\r\n{&quot;key&quot;:&quot;key2&quot;,&quot;member&quot;:&quot;three&quot;,&quot;score&quot;:&quot;3&quot;}\r\n{&quot;key&quot;:&quot;key2&quot;,&quot;member&quot;:&quot;four&quot;,&quot;score&quot;:&quot;4&quot;}\r\n```\r\n\r\nThe input json is quite large - imagine thousands of entries in the &quot;values&quot; field of above example. I wish to perform this exact transformation in jq stream mode with the goal of avoiding memory pressure.\r\n\r\nI have tried using jq `foreach` to no avail. I cannot find a way to store the &quot;key1&quot; value to be referenced as entries in &quot;values&quot; are processed. \r\n\r\nExample, using the same input as the working example:\r\n```\r\n$ jq -c --stream &#39;foreach . as $input ({};{in: $input};.)&#39; input.jsonl\r\n\r\n{&quot;in&quot;:[[&quot;key&quot;],&quot;key1&quot;]}\r\n{&quot;in&quot;:[[&quot;value&quot;,&quot;one&quot;],1]}\r\n{&quot;in&quot;:[[&quot;value&quot;,&quot;two&quot;],2]}\r\n{&quot;in&quot;:[[&quot;value&quot;,&quot;two&quot;]]}\r\n{&quot;in&quot;:[[&quot;value&quot;]]}\r\n{&quot;in&quot;:[[&quot;key&quot;],&quot;key2&quot;]}\r\n{&quot;in&quot;:[[&quot;value&quot;,&quot;three&quot;],3]}\r\n{&quot;in&quot;:[[&quot;value&quot;,&quot;four&quot;],4]}\r\n{&quot;in&quot;:[[&quot;value&quot;,&quot;four&quot;]]}\r\n{&quot;in&quot;:[[&quot;value&quot;]]}\r\n```\r\n\r\nI need to reference the value &quot;key1&quot; when processing lines 2 and 3 above and so on for the remaining keys.\r\n\r\nTo reiterate, I desire the exact output from the non-stream version.",
        "link": "https://stackoverflow.com/questions/61687180/expand-a-fairly-large-object-to-smaller-objects-using-stream",
        "title": "Expand a fairly large object to smaller objects using --stream"
    },
    {
        "tags": [
            "json",
            "path",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1588987745,
                "creation_date": 1588987745,
                "answer_id": 61690650,
                "question_id": 61690375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq &#39;{&quot;new_v1&quot;: .}&#39; from.json\r\n\r\nor even just:\r\n\r\n    jq &#39;{new_v1: .}&#39; from.json\r\n\r\n",
                "title": "Adding a new path to a json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1589085625,
        "creation_date": 1588985389,
        "last_edit_date": 1589085625,
        "question_id": 61690375,
        "body_markdown": "I&#39;m new to jq and looking form assistance, how do I transform the first json format data to the &quot;from&quot; format, adding an extra path.\r\n\r\n    **From:**\r\n\r\n    {\r\n      &quot;v1&quot;: &quot;9.0.19&quot;,\r\n      &quot;v2&quot;: &quot;9.0.52&quot;,\r\n      &quot;t2&quot;: &quot;9.3.2&quot;,\r\n      &quot;t3&quot;: &quot;9.3.2&quot;,\r\n      &quot;x&quot;: &quot;9.0.46&quot;\r\n    }\r\n    \r\n    **To**\r\n    \r\n    \r\n    {\r\n    \t  &quot;new_v1&quot;: {\r\n    \t\t  &quot;v1&quot;: &quot;9.0.19&quot;,\r\n    \t\t  &quot;v2&quot;: &quot;9.0.52&quot;,\r\n    \t\t  &quot;t2&quot;: &quot;9.3.2&quot;,\r\n    \t\t  &quot;t3&quot;: &quot;9.3.2&quot;,\r\n    \t\t  &quot;x&quot;: &quot;9.0.46&quot;\r\n    \t  }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61690375/adding-a-new-path-to-a-json-using-jq",
        "title": "Adding a new path to a json using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "max",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588998486,
                "post_id": 61691807,
                "comment_id": 109122965,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18531840,
                    "reputation": 23,
                    "user_id": 13502427,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a24443e86e213fc153c4e02be9703aff?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "SimpleBI",
                    "link": "https://stackoverflow.com/users/13502427/simplebi"
                },
                "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": 1588999784,
                "post_id": 61691807,
                "comment_id": 109123204,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18531840,
                    "reputation": 23,
                    "user_id": 13502427,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a24443e86e213fc153c4e02be9703aff?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "SimpleBI",
                    "link": "https://stackoverflow.com/users/13502427/simplebi"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1588999809,
                "post_id": 61691807,
                "comment_id": 109123207,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1589000187,
                "creation_date": 1589000187,
                "answer_id": 61692000,
                "question_id": 61691807,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    &#160;jq &#39;.results | max_by(.date) | .date&#39; &quot;$jsonfilePath&quot;\r\n\r\nis a more efficient way to get the maximum date value out of that JSON that might work better for you. It avoids the Useless Use Of Cat, doesn&#39;t create a temporary array of just the date values, and thus only needs one pass through the array.\r\n",
                "title": "How to get max value of a date field in a large json file?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1589177220,
                "last_edit_date": 1589177220,
                "creation_date": 1589000629,
                "answer_id": 61692043,
                "question_id": 61691807,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given --stream option on the command line, JQ won&#39;t load the whole input into the memory, instead it&#39;ll read the input token by token, producing arrays in this fashion:\r\n```\r\n[[&quot;results&quot;,0,&quot;Id&quot;],&quot;123&quot;]\r\n[[&quot;results&quot;,0,&quot;date&quot;],1588910400000]\r\n...\r\n[[&quot;results&quot;,1,&quot;date&quot;],1588910412345]\r\n...\r\n```\r\nThanks to this feature, we can pick only `date`s from the input and find out the maximum one without exhausting the memory (at the expense of speed). For example:\r\n```\r\njq -n --stream &#39;reduce (inputs|select(.[0][-1]==&quot;date&quot; and length==2)[1]) as $d (null; [.,$d]|max)&#39; file\r\n```",
                "title": "How to get max value of a date field in a large json file?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1589098080,
                "last_edit_date": 1589098080,
                "creation_date": 1589005828,
                "answer_id": 61692734,
                "question_id": 61691807,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "500MB should not be so large as to require the --stream option, which generally slows things down.  Here then is a fast and efficient(*) solution that does not use the streaming option, but instead uses a generic, stream-oriented &quot;max_by&quot; function defined as follows:\r\n```\r\n# max_by(empty;1) yields null\r\ndef max_by(s; f):\r\n  reduce s as $s (null;\r\n    if . == null then {s: $s, m: ($s|f)}\r\n    else  ($s|f) as $m\r\n    | if $m &gt; .m then {s: $s, m: $m} else . end\r\n    end)\r\n  | .s ;\r\n```\r\n\r\n\r\nWith this in our toolkit, we can simply write:\r\n```\r\nmax_by(.results[].date; .)\r\n```\r\n\r\nThis of course assumes that there is a &quot;results&quot; field containing an array of JSON objects. (**) From the problem statement, it would appear that this assumption does not always hold, so you will probably want to modify whichever approach you choose accordingly (e.g. by checking whether there is a results field, whether it&#39;s array-valued, etc.)\r\n\r\n---\r\n\r\n(*) Using max_by/2 here is more efficient, both in terms of space and time, than using the built-in max_by/1.\r\n\r\n(**) The absence of a &quot;date&quot; subfield should not matter as `null` is less than every number.\r\n ",
                "title": "How to get max value of a date field in a large json file?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1589266224,
        "creation_date": 1588998408,
        "last_edit_date": 1589266224,
        "question_id": 61691807,
        "body_markdown": "I have a large JSON file around 500MB which is the response of a URL call.I need to get the max value of &quot;date&quot; field in the JSON file in the &quot;results&quot; array using shell script(bash).Currently using jq as below.Below works good for smaller files but for larger files it is returning null.\r\n\r\n    maxDate=$(cat ${jsonfilePath} | jq &#39;[ .results[]?.date ] | max&#39;) \r\n\r\nPlease help.Thanks! I am new to shell scripting,json,jq.\r\n\r\nsample/input json file contents: \r\n\r\n    {\r\n        &quot;results&quot;: [\r\n            {\r\n                &quot;Id&quot;: &quot;123&quot;,\r\n                &quot;date&quot;: 1588910400000,\r\n                &quot;col&quot;: &quot;test&quot;\r\n            },\r\n            {\r\n                &quot;Id&quot;: &quot;1234&quot;,\r\n                &quot;date&quot;: 1588910412345,\r\n                &quot;col&quot;: &quot;test2&quot;\r\n            }\r\n        ],\r\n        &quot;col2&quot;: 123\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61691807/how-to-get-max-value-of-a-date-field-in-a-large-json-file",
        "title": "How to get max value of a date field in a large json file?"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1589082734,
                "last_edit_date": 1589082734,
                "creation_date": 1589075627,
                "answer_id": 61706208,
                "question_id": 61705239,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you really want valid CSV, it&#39;s usually best to use `@csv` in conjunction with the -r command-line option.\r\nIn your case, you could go with:\r\n```\r\n.symbol as $symbol\r\n| .candles[]\r\n| [.open, .high, .low, .close, .volume, .datetime, $symbol]\r\n| @csv\r\n```\r\n\r\nor equivalently but without the $-variable:\r\n```\r\n(.candles[] | [.open, .high, .low, .close, .volume, .datetime]) + [.symbol]\r\n| @csv\r\n```\r\n\r\nIf you&#39;re willing to take the risk, you could also consider:\r\n```\r\n.symbol as $symbol\r\n| .candles[]\r\n| [.[], $symbol]\r\n| @csv\r\n```\r\n",
                "title": "JQ - pick up another higher level key value after array print"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1589082734,
        "creation_date": 1589067289,
        "last_edit_date": 1589075706,
        "question_id": 61705239,
        "body_markdown": "I have this JSON data:\r\n\r\nprice_history.json\r\n\r\n\r\n```\r\n{\r\n  &quot;candles&quot;: [\r\n    {\r\n      &quot;open&quot;: 26,\r\n      &quot;high&quot;: 26.25,\r\n      &quot;low&quot;: 25.75,\r\n      &quot;close&quot;: 26.0625,\r\n      &quot;volume&quot;: 1038600,\r\n      &quot;datetime&quot;: 957762000000\r\n    },\r\n    {\r\n      &quot;open&quot;: 25.8125,\r\n      &quot;high&quot;: 26.25,\r\n      &quot;low&quot;: 25.75,\r\n      &quot;close&quot;: 26,\r\n      &quot;volume&quot;: 765900,\r\n      &quot;datetime&quot;: 957848400000\r\n    }\r\n  ],\r\n  &quot;symbol&quot;: &quot;ABC&quot;,\r\n  &quot;empty&quot;: false\r\n}\r\n```\r\nI need to get this to a CSV. I can get almost everything I need with the following filter, but I want to add the symbol that is outside the array:\r\n```\r\ncat price_history.json | jq &#39;.candles[] | (.open|tostring) + &quot;,&quot; + (.high|tostring)  + &quot;,&quot; + (.low|tostring)  + &quot;,&quot; + (.close|tostring)  + &quot;,&quot; + (.volume|tostring)  + &quot;,&quot; + (.datetime|tostring)&#39; \r\n```\r\nresponse:\r\n```\r\n&quot;26,26.25,25.75,26.0625,1038600,957762000000&quot;\r\n&quot;25.8125,26.25,25.75,26,765900,957848400000&quot;\r\n```\r\ndesired response:\r\n```\r\n&quot;26,26.25,25.75,26.0625,1038600,957762000000,ABC&quot;\r\n&quot;25.8125,26.25,25.75,26,765900,957848400000,ABC&quot;\r\n```\r\nI have tried many combinations trying to get back to the top level to pick up the symbol, including trying to pick it up first. I don&#39;t care where it sits in the line\r\n\r\nThis is the closest I got, it has everything but prints the keys and everything I don&#39;t need:\r\n```\r\ncat /home/utility/scripts/marketScan/app/modules/api-comm/tdam/port/input/price_history-2.txt | jq &#39;(.candles[]|tostring) + &quot;,&quot; + (.symbol|tostring)&#39;\r\n```\r\nresponse\r\n```\r\n&quot;{\\&quot;open\\&quot;:26,\\&quot;high\\&quot;:26.25,\\&quot;low\\&quot;:25.75,\\&quot;close\\&quot;:26.0625,\\&quot;volume\\&quot;:1038600,\\&quot;datetime\\&quot;:957762000000},ABC&quot;\r\n&quot;&quot;{\\&quot;open\\&quot;:25.8125,\\&quot;high\\&quot;:26.25,\\&quot;low\\&quot;:25.75,\\&quot;close\\&quot;:26,\\&quot;volume\\&quot;:765900,\\&quot;datetime\\&quot;:957848400000},ABC&quot;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/61705239/jq-pick-up-another-higher-level-key-value-after-array-print",
        "title": "JQ - pick up another higher level key value after array print"
    },
    {
        "tags": [
            "google-cloud-platform",
            "zsh",
            "jq",
            "video-intelligence-api",
            "google-speech-to-text-api"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1589119188,
                "post_id": 61712885,
                "comment_id": 109160400,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1589147433,
                "post_id": 61712885,
                "comment_id": 109171464,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14639787,
                    "reputation": 89,
                    "user_id": 10793272,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/YG7jA.png?s=256",
                    "display_name": "InfoMiner",
                    "link": "https://stackoverflow.com/users/10793272/infominer"
                },
                "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": 1589165426,
                "post_id": 61712885,
                "comment_id": 109175435,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1589181241,
                "last_edit_date": 1589181241,
                "creation_date": 1589178983,
                "answer_id": 61723624,
                "question_id": 61712885,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; My problem was not understanding how to only print the startTime if it has a corresponding speakerTag.\r\n\r\nThis could be accomplished using the filter:\r\n\r\n```\r\n.response.annotationResults[].speechTranscriptions[].alternatives[].words[]\r\n | select(.speakerTag)\r\n | {time: .startTime, speaker: .speakerTag}\r\n```\r\n\r\nSo perhaps the following is a solution (or at least close to a solution) to the main problem:\r\n\r\n```\r\n.response.annotationResults[].speechTranscriptions[].alternatives[]\r\n| (INDEX(.words[] | select(.speakerTag); .startTime) | map_values(.speakerTag)) as $dict\r\n| {startTime: .words[0].startTime, segment: .transcript}\r\n| . + {speaker: $dict[.startTime]}\r\n```",
                "title": "How do I extract transcript with multiple speakers from Google Video Intelligence API Speech Transcription JSON output using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1589186129,
        "creation_date": 1589117523,
        "last_edit_date": 1589186129,
        "question_id": 61712885,
        "body_markdown": "I&#39;m testing out Google [Video Intelligence speech-to-text][1] for transcribing podcast episodes with multiple speakers. \r\n\r\nI&#39;ve extracted an example and published that to a gist: [output.json][2].\r\n\r\n    cat file.json | jq &#39;.response.annotationResults[].speechTranscriptions[].alternatives[] | {startTime: .words[0].startTime, segment: .transcript }&#39;\r\n\r\nAbove command will print out the `startTime` of each segment, along with the segment itself. [jq-output.json][4]\r\n\r\n    {\r\n      &quot;time&quot;: &quot;6.400s&quot;,\r\n      &quot;segment&quot;: &quot;Hi, my name is Melinda Smith from Noble works. ...snip&quot;\r\n    }\r\n    {\r\n      &quot;time&quot;: &quot;30s&quot;,\r\n      &quot;segment&quot;: &quot; Any Graham as a tool for personal and organizational ...snip&quot;\r\n    }\r\n\r\n**What I&#39;m aiming for is to have the `speakerTag`for each segment included in my jq output.**\r\n\r\nThis is where I&#39;m stuck... to start, each array within `.alternatives[]` contains `.transcript` a string containing that segment, `.confidence`, and `.words[]` an array with each word of that segment and the time it was spoken. \r\n\r\nThat part of the JSON is how I get the first part of the output. Then, after it&#39;s gone through each segment of the transcript, at the bottom, it has one last `.alternatives[]` array, containing (again) each word from the entire transcript, one at a time, along with it&#39;s startTime, endTime, and speakerTag.\r\n\r\nHere&#39;s a simplified example of what I mean:\r\n\r\n    speechTranscriptions:\r\n      alternatives:\r\n        transcript: &quot;Example transcript segment&quot;\r\n        words:\r\n          word: &quot;Example&quot;; startTime: 0s;\r\n          word: &quot;transcript&quot;; startTime: 1s;\r\n          word: &quot;segment&quot;; startTime: 2s;\r\n      alternatives:\r\n        transcript: &quot;Another transcript segment&quot;\r\n        words:\r\n          word: &quot;Another&quot;; startTime: 3s;\r\n          word: &quot;transcript&quot;; startTime: 4s;\r\n          word: &quot;segment&quot;; startTime: 5s;\r\n      alternatives:\r\n        words:\r\n          word: &quot;Example&quot;; startTime: 0s; speakerTag: 1;\r\n          word: &quot;transcript&quot;; startTime: 1s; speakerTag: 1;\r\n          word: &quot;segment&quot;; startTime: 2s; speakerTag: 1;\r\n          word: &quot;Another&quot;; startTime: 3s; speakerTag: 2;\r\n          word: &quot;transcript&quot;; startTime: 4s; speakerTag: 2;\r\n          word: &quot;segment&quot;; startTime: 5s; speakerTag: 2;\r\n\r\n\r\nWhat I was thinking is to somehow go through the [jq-output.json][4], and match each `startTime` with it&#39;s corresponding `speakerTag` found in the original Video Intelligence API output.\r\n\r\n    .response.annotationResults[].speechTranscriptions[].alternatives[] | ( if .words[].speakerTag then {time: .words[].startTime, speaker: .words[].speakerTag} else empty end)\r\n\r\nI tried a few variations of this, with the idea to print out only start-time and speakerTag, then match the values in my next step. My problem was not understanding how to only print the startTime if it has a corresponding speakerTag.\r\n\r\nAs mentioned in the comments, it would be preferable to generate this result in one command, but I was just trying to break the problem down into parts I could attempt to understand. \r\n\r\n  [1]: https://cloud.google.com/video-intelligence/docs/transcription\r\n  [2]: https://gist.github.com/infominer33/d07ababfa98df8bf98d71ba7420aa1da\r\n  [4]: https://gist.github.com/infominer33/586e87c79ab51e42571ea29d08597940\r\n",
        "link": "https://stackoverflow.com/questions/61712885/how-do-i-extract-transcript-with-multiple-speakers-from-google-video-intelligenc",
        "title": "How do I extract transcript with multiple speakers from Google Video Intelligence API Speech Transcription JSON output using jq?"
    },
    {
        "tags": [
            "amazon-web-services",
            "amazon-ec2",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1589220907,
                "post_id": 61732744,
                "comment_id": 109201684,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1002989,
                    "reputation": 1385,
                    "user_id": 1017466,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/73d62289ed695b520ad2a3ae80c45277?s=256&d=identicon&r=PG",
                    "display_name": "bluethundr",
                    "link": "https://stackoverflow.com/users/1017466/bluethundr"
                },
                "reply_to_user": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1589224768,
                "post_id": 61732744,
                "comment_id": 109203751,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1589209723,
                "creation_date": 1589209723,
                "answer_id": 61732966,
                "question_id": 61732744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need extra tools like `jq` to query the output. AWS CLI has JMESPath \r\n built-in to help you do that.\r\n\r\n```\r\naws ec2 describe-instances --query &#39;Reservations[*].Instances[*].Tags[?Key == `Name`].Value&#39;\r\n```",
                "title": "Get Value of Name Tag from EC2 instances using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1589210190,
                "creation_date": 1589210190,
                "answer_id": 61733114,
                "question_id": 61732744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is a mismatch between the jq command-line expression shown in the Q and the error message. I would suggest that, at least until you have sorted things out, you put your jq program in a file, and invoke jq with the -f command-line option.",
                "title": "Get Value of Name Tag from EC2 instances using jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1640081691,
                "creation_date": 1640081691,
                "answer_id": 70433794,
                "question_id": 61732744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could do something like this, this will get what you want from ec2 in a comma separated list\r\n\r\n    jq -r &#39;.Reservations[].Instances[] \\ | ((.Tags // empty) | from_entries) as $tags | [($tags.Name), ($tags.environment), .ImageId, .InstanceId, .AmiLaunchIndex] | @csv&#39;\r\n\r\nThe `.Tags // empty` will ignore those with tags that do not exist if you are wondering.\r\n\r\nHope this helps, it Is correct you do not need jq to get these details, but this is how you do it with :)\r\n",
                "title": "Get Value of Name Tag from EC2 instances using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1640081691,
        "creation_date": 1589209025,
        "question_id": 61732744,
        "body_markdown": "I am trying to get the values of the `Name` tag of AWS EC2 instances using jq.\r\n\r\n`aws ec2 describe-instances | jq -r &#39;.Reservations[].Instances[] | .Tags[] | select (.Key == &quot;Name&quot;)&#39;`\r\n\r\nBut I am getting this error:\r\n\r\n    jq: error: Name/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .Reservations[].Instances[] | .Tags[] | select (.Key == Name)\r\n    jq: 1 compile error\r\n\r\nThis is the json I&#39;m trying to process:\r\n\r\n    {\r\n    \t&quot;Reservations&quot;: [{\r\n    \t\t&quot;Instances&quot;: [{\r\n    \t\t\t&quot;AmiLaunchIndex&quot;: 0,\r\n    \t\t\t&quot;ImageId&quot;: &quot;ami-00c3c949f325a4149&quot;,\r\n    \t\t\t&quot;InstanceId&quot;: &quot;i-0c17052ee1c7113e5&quot;,\r\n    \t\t\t&quot;Architecture&quot;: &quot;x86_64&quot;,\r\n    \t\t\t&quot;Tags&quot;: [{\r\n    \t\t\t\t\t&quot;Key&quot;: &quot;Name&quot;,\r\n    \t\t\t\t\t&quot;Value&quot;: &quot;bastion001&quot;\r\n    \t\t\t\t},\r\n    \t\t\t\t{\r\n    \t\t\t\t\t&quot;Key&quot;: &quot;environment&quot;,\r\n    \t\t\t\t\t&quot;Value&quot;: &quot;stg-us-east&quot;\r\n    \t\t\t\t}\r\n    \t\t\t]\r\n    \t\t}]\r\n    \t}]\r\n    }\r\n\r\nHow can I get the value of the `Name` tag from EC2 instances?",
        "link": "https://stackoverflow.com/questions/61732744/get-value-of-name-tag-from-ec2-instances-using-jq",
        "title": "Get Value of Name Tag from EC2 instances using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "append",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1589223849,
                "post_id": 61737304,
                "comment_id": 109203263,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6346093,
                    "reputation": 9850,
                    "user_id": 4926605,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4e3c60705404efebe3bd70316b9d4f5c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "LundinCast",
                    "link": "https://stackoverflow.com/users/4926605/lundincast"
                },
                "reply_to_user": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1589308618,
                "post_id": 61737304,
                "comment_id": 109240964,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1589225588,
                "creation_date": 1589225588,
                "answer_id": 61737821,
                "question_id": 61737304,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "While obvious problem is that you are reading and redirecting to same file which you cannot do in `bash` and [this answer has many useful explanations and work around for that][1].\r\n\r\nBut a better solution would be to totally avoid invoking `jq` multiple times in a loop and get it done in a single execution of `jq`.\r\n\r\n    # array to hold new values in json format\r\n    narr=()\r\n    \r\n    # loop through input file and append json formatted values to array\r\n    while read -r line; do\r\n        narr+=(&#39;{&quot;role&quot;: &quot;WRITER&quot;, &quot;userByEmail&quot;: &quot;&#39;$line&#39;&quot;}&#39;)\r\n    done &lt; service-accounts-list.txt\r\n\r\n    # call jq only once using -n option\r\n    jq -n &#39;input | .access += [inputs]&#39; results.json &lt;(printf &#39;%s\\n&#39; &quot;${narr[@]}&quot;)\r\n\r\n**Output:**\r\n\r\n    {\r\n      &quot;access&quot;: [\r\n        {\r\n          &quot;role&quot;: &quot;WRITER&quot;,\r\n          &quot;specialGroup&quot;: &quot;projectWriters&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;OWNER&quot;,\r\n          &quot;specialGroup&quot;: &quot;projectOwners&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;READER&quot;,\r\n          &quot;specialGroup&quot;: &quot;projectReaders&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;WRITER&quot;,\r\n          &quot;userByEmail&quot;: &quot;serviceAccount:p12345-001@gcp-sa-logging.iam.gserviceaccount.com&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;WRITER&quot;,\r\n          &quot;userByEmail&quot;: &quot;serviceAccount:p12345-002@gcp-sa-logging.iam.gserviceaccount.com&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;WRITER&quot;,\r\n          &quot;userByEmail&quot;: &quot;serviceAccount:p12345-003@gcp-sa-logging.iam.gserviceaccount.com&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;WRITER&quot;,\r\n          &quot;userByEmail&quot;: &quot;serviceAccount:p12345-004@gcp-sa-logging.iam.gserviceaccount.com&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;WRITER&quot;,\r\n          &quot;userByEmail&quot;: &quot;serviceAccount:p12345-005@gcp-sa-logging.iam.gserviceaccount.com&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/6696842/how-can-i-use-a-file-in-a-command-and-redirect-output-to-the-same-file-without-t",
                "title": "jq - can&#39;t append objects to array in while loop"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1589227765,
                "creation_date": 1589227765,
                "answer_id": 61738393,
                "question_id": 61737304,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `jq` itself without any shell processing. Process the plain text file using raw input mode `-R` over null input and start forming the resultant JSON from scratch. \r\n\r\nThe `reduce()` function iteratively runs over each entry int the text file and creates a object with role name and appends it to the `access` array.\r\n\r\n    jq -Rn \\\r\n       --slurpfile res result.json \\\r\n       &#39;[ inputs | split(&quot;\\n&quot;) | add ] as $data \r\n        | $res[] \r\n        | reduce $data[] as $d (.; .access += [{ role: &quot;WRITER&quot;, userByEmail: $d  }] )&#39; \\\r\n    service-accounts-list.txt",
                "title": "jq - can&#39;t append objects to array in while loop"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1589265676,
                "last_edit_date": 1589265676,
                "creation_date": 1589234289,
                "answer_id": 61740125,
                "question_id": 61737304,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe the simplest efficient solution would be:\r\n```\r\njq -nR --argfile result result.json &#39;\r\n  $result \r\n  | .access += [{role: &quot;WRITER&quot;, userByEmail: inputs}] \r\n&#39; service-accounts-list.txt\r\n```\r\n\r\nNotice -- no slurping, no splitting, no shell scripting.  If the use of --argfile bothers you, feel free to use --slurpfile but &quot;unslurp&quot; $result by writing `$result[0]`.",
                "title": "jq - can&#39;t append objects to array in while loop"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1589265676,
        "creation_date": 1589223699,
        "last_edit_date": 1589246541,
        "question_id": 61737304,
        "body_markdown": "I&#39;ve got this `service-accounts-list.txt` file with service accounts:\r\n\r\n    serviceAccount:p12345-001@gcp-sa-logging.iam.gserviceaccount.com\r\n    serviceAccount:p12345-002@gcp-sa-logging.iam.gserviceaccount.com\r\n    serviceAccount:p12345-003@gcp-sa-logging.iam.gserviceaccount.com\r\n    serviceAccount:p12345-004@gcp-sa-logging.iam.gserviceaccount.com\r\n    serviceAccount:p12345-005@gcp-sa-logging.iam.gserviceaccount.com\r\n\r\nand this `results.json` file which I&#39;d like to append data to:\r\n\r\n    {\r\n      &quot;access&quot;: [\r\n        {\r\n          &quot;role&quot;: &quot;WRITER&quot;,\r\n          &quot;specialGroup&quot;: &quot;projectWriters&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;OWNER&quot;,\r\n          &quot;specialGroup&quot;: &quot;projectOwners&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;READER&quot;,\r\n          &quot;specialGroup&quot;: &quot;projectReaders&quot;\r\n        }\r\n      ]\r\n    }\r\n**Expected result**: I&#39;d like to add an object for each line in `service-accounts-list.txt`, like so:\r\n\r\n    {\r\n      &quot;access&quot;: [\r\n        {\r\n          &quot;role&quot;: &quot;WRITER&quot;,\r\n          &quot;specialGroup&quot;: &quot;projectWriters&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;OWNER&quot;,\r\n          &quot;specialGroup&quot;: &quot;projectOwners&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;READER&quot;,\r\n          &quot;specialGroup&quot;: &quot;projectReaders&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;WRITER&quot;,\r\n          &quot;userByEmail&quot;: &quot;serviceAccount:p12345-001@gcp-sa-logging.iam.gserviceaccount.com&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;WRITER&quot;,\r\n          &quot;userByEmail&quot;: &quot;serviceAccount:p12345-002@gcp-sa-logging.iam.gserviceaccount.com&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;WRITER&quot;,\r\n          &quot;userByEmail&quot;: &quot;serviceAccount:p12345-003@gcp-sa-logging.iam.gserviceaccount.com&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;WRITER&quot;,\r\n          &quot;userByEmail&quot;: &quot;serviceAccount:p12345-004@gcp-sa-logging.iam.gserviceaccount.com&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;WRITER&quot;,\r\n          &quot;userByEmail&quot;: &quot;serviceAccount:p12345-005@gcp-sa-logging.iam.gserviceaccount.com&quot;\r\n        }\r\n      ]\r\n    }\r\nMy bash script so far looks like this:\r\n\r\n    while read p;\r\n    do\r\n      cat result.json | jq --arg email &quot;$p&quot; &#39;.access += [{&quot;role&quot;: &quot;WRITER&quot;, &quot;userByEmail&quot;: $email}]&#39; &gt; result.json\r\n    done &lt; service-accounts-list.txt\r\nThe resulting `result.json` file is actually empty. If I redirect the output to for `example &gt; result2.json` it correctly adds the last service account, like so:\r\n\r\n    {\r\n      &quot;access&quot;: [\r\n        {\r\n          &quot;role&quot;: &quot;WRITER&quot;,\r\n          &quot;specialGroup&quot;: &quot;projectWriters&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;OWNER&quot;,\r\n          &quot;specialGroup&quot;: &quot;projectOwners&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;READER&quot;,\r\n          &quot;specialGroup&quot;: &quot;projectReaders&quot;\r\n        },\r\n        {\r\n          &quot;role&quot;: &quot;WRITER&quot;,\r\n          &quot;userByEmail&quot;: &quot;serviceAccount:p12345-005@gcp-sa-logging.iam.gserviceaccount.com&quot;\r\n        }\r\n      ]\r\n    }\r\nso it seems the `jq` syntax is correct. I&#39;ve tried adding the `--unbuffered` flag to no avail.\r\n\r\nWhat am I missing?",
        "link": "https://stackoverflow.com/questions/61737304/jq-cant-append-objects-to-array-in-while-loop",
        "title": "jq - can&#39;t append objects to array in while loop"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1904631,
                    "reputation": 82301,
                    "user_id": 1719752,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://i.sstatic.net/aRHn9.jpg?s=256",
                    "display_name": "Milind Anantwar",
                    "link": "https://stackoverflow.com/users/1719752/milind-anantwar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1589271248,
                "post_id": 61746783,
                "comment_id": 109219071,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1589273480,
                "last_edit_date": 1589273480,
                "creation_date": 1589271742,
                "answer_id": 61746968,
                "question_id": 61746783,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the invocation:\r\n\r\n    jq -r -f sleeping.jq pattern.json\r\n\r\nwhere sleeping.jq is:\r\n```\r\n.a[]\r\n| .metadata.name as $raj\r\n| select( any(.status[].state; has(&quot;sleeping&quot;)) )\r\n| &quot;Name ID \\($raj)&quot;\r\n```\r\nthe result is:\r\n```\r\nName ID raj\r\nName ID tom\r\n```\r\n\r\n### Solution to amended question\r\n```\r\n.a[]\r\n| .metadata.name as $raj\r\n| .status[].state\r\n| select( has(&quot;sleeping&quot;))\r\n| &quot;Name ID \\($raj) \\(.sleeping.ID)&quot;\r\n```\r\n\r\n",
                "title": "Need to search a value in json in one array and provide output from another array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1589273480,
        "creation_date": 1589271181,
        "last_edit_date": 1589271667,
        "question_id": 61746783,
        "body_markdown": "I have a below pattern json. \r\n\r\n    {\r\n    &quot;a&quot;: [{\r\n    &quot;metadata&quot;:{ &quot;name&quot;:&quot;raj&quot;},\r\n    &quot;status&quot;:[{\r\n    &quot;state&quot;:\r\n    {  &quot;sleeping&quot;:\r\n      { &quot;started&quot;:&quot;2020-05-11T14:49:04Z&quot;,\r\n        &quot;ID&quot;:&quot;1002&quot;}\r\n     }},{\r\n    &quot;state&quot;: \r\n     { &quot;sleeping&quot;:\r\n       { &quot;started&quot;:&quot;2020-05-11T14:49:04Z&quot;,\r\n         &quot;ID&quot;:&quot;1002&quot;}\r\n     }}],\r\n    &quot;phase&quot;:&quot;sleeping&quot;},\r\n    \r\n    {\r\n    &quot;metadata&quot;:{ &quot;name&quot;:&quot;tom&quot;},\r\n    &quot;status&quot;:[{\r\n    &quot;state&quot;:\r\n    {  &quot;sleeping&quot;:\r\n      { &quot;started&quot;:&quot;2020-05-11T14:49:04Z&quot;,\r\n        &quot;ID&quot;:&quot;1002&quot;}\r\n     }},{\r\n    &quot;state&quot;: \r\n     { &quot;sleeping&quot;:\r\n       { &quot;started&quot;:&quot;2020-05-11T14:49:04Z&quot;,\r\n         &quot;ID&quot;:&quot;1002&quot;}\r\n     }}],\r\n    &quot;phase&quot;:&quot;sleeping&quot;}]}\r\n\r\nI need to the output using jq to filter the name(.metadata.name) for those items in the list that have the state(.status[].state) as sleeping in below format\r\nName ID\r\nraj\r\nSo far I was successful to select the state in sleeping.\r\njq &#39;.a[].status[]| select(.state | has(&quot;terminated&quot;))\r\nHowever I am unable to combine the name and generate the output.\r\nSorry if sounds silly and thanks in advance.",
        "link": "https://stackoverflow.com/questions/61746783/need-to-search-a-value-in-json-in-one-array-and-provide-output-from-another-arra",
        "title": "Need to search a value in json in one array and provide output from another array using jq"
    },
    {
        "tags": [
            "python",
            "json",
            "python-3.x",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13799927,
                    "reputation": 649,
                    "user_id": 9960125,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a1065e120881f1c10ca8a583ae10e8f5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jjj",
                    "link": "https://stackoverflow.com/users/9960125/jjj"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1589271874,
                "post_id": 61746910,
                "comment_id": 109219392,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1621672737,
                "last_edit_date": 1621672737,
                "creation_date": 1589271986,
                "answer_id": 61747033,
                "question_id": 61746910,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Covert your JSON into Pandas Dataframe\r\n\r\n    {  \r\n    \r\n    import pandas as pd \r\n    df=pd.read_json(&#39;your json variable&#39;)\r\n    res=df.drop([&#39;url_whitelis&#39;,&#39;api_key&#39;],axis=1) \r\n                                              \r\n    pd.to_json(res) }    \r\n\r\n  ",
                "title": "Need to cut off some unnecessary information from a JSON file and preserve the JSON structure"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1589272596,
                "last_edit_date": 1589272596,
                "creation_date": 1589272245,
                "answer_id": 61747129,
                "question_id": 61746910,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using python, you could first deserialize the JSON file(JSON array of objects) with [`json.load`][1], then filter out the keys you want with a list comprehension:\r\n\r\n    from json import load\r\n\r\n    keys = [&quot;name&quot;, &quot;id&quot;]\r\n\r\n    with open(&quot;test.json&quot;) as json_file:\r\n        data = load(json_file)\r\n\r\n        filtered_json = [{k: obj.get(k) for k in keys} for obj in data]\r\n\r\n        print(filtered_json)\r\n\r\n**Output:**\r\n\r\n    [{&#39;name&#39;: &#39;asdasdaasd&#39;, &#39;id&#39;: &#39;34234243224224&#39;}]\r\n\r\nIf we want to serialize this python list to another output file, we can use [`json.dump`][2]:\r\n\r\n    from json import load\r\n    from json import dump\r\n\r\n    keys = [&quot;name&quot;, &quot;id&quot;]\r\n\r\n    with open(&quot;test.json&quot;) as json_file, open(&quot;output.json&quot;, mode=&quot;w&quot;) as json_output:\r\n        data = load(json_file)\r\n\r\n        filtered_json = [{k: obj.get(k) for k in keys} for obj in data]\r\n\r\n        dump(filtered_json, json_output, indent=4, sort_keys=True)\r\n\r\n**output.json**\r\n\r\n    [\r\n        {\r\n            &quot;id&quot;: &quot;34234243224224&quot;,\r\n            &quot;name&quot;: &quot;asdasdaasd&quot;\r\n        }\r\n    ]\r\n\r\n\r\n  [1]: https://docs.python.org/3/library/json.html#json.load\r\n  [2]: https://docs.python.org/3/library/json.html#json.dump",
                "title": "Need to cut off some unnecessary information from a JSON file and preserve the JSON structure"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1589272301,
                "creation_date": 1589272301,
                "answer_id": 61747150,
                "question_id": 61746910,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `jq`:\r\n\r\n    $ jq &#39;map({id: .id, name: .name})&#39; input.json \r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;34234243224224&quot;,\r\n        &quot;name&quot;: &quot;asdasdaasd&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "Need to cut off some unnecessary information from a JSON file and preserve the JSON structure"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1589272723,
                "creation_date": 1589272723,
                "answer_id": 61747285,
                "question_id": 61746910,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try this:\r\n\r\n    import json\r\n    \r\n    with open(&#39;&lt;input filename&gt;&#39;, &#39;r&#39;) as f:\r\n        data = json.load(f)\r\n    \r\n    new_data = []\r\n    for item in data:\r\n        new_item = {key: value for key, value in item.items() if key == &quot;id&quot; or key ==&quot;name&quot;}\r\n        new_data.append(new_item)\r\n    \r\n    with open(&#39;&lt;output filename&gt;&#39;, &#39;w&#39;) as f:\r\n        json.dump(new_data, f)",
                "title": "Need to cut off some unnecessary information from a JSON file and preserve the JSON structure"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1621672737,
        "creation_date": 1589271608,
        "last_edit_date": 1589272205,
        "question_id": 61746910,
        "body_markdown": "I have a JSON file\r\n\r\n    [\r\n        {\r\n            &quot;api_key&quot;: &quot;123123112313121321&quot;,\r\n            &quot;collaborators_count&quot;: 1,\r\n            &quot;created_at&quot;: &quot;&quot;,\r\n            &quot;custom_event_fields_used&quot;: 0,\r\n            &quot;discarded_app_versions&quot;: [],\r\n            &quot;discarded_errors&quot;: [],\r\n            &quot;errors_url&quot;: &quot;https://api.bugsnag.com/projects/1231231231312/errors&quot;,\r\n            &quot;events_url&quot;: &quot;https://api.bugsnag.com/projects/1231231231213/events&quot;,\r\n            &quot;global_grouping&quot;: [],\r\n            &quot;html_url&quot;: &quot;https://app.bugsnag.com/lol/kek/&quot;,\r\n            &quot;id&quot;: &quot;34234243224224&quot;,\r\n            &quot;ignore_old_browsers&quot;: true,\r\n            &quot;ignored_browser_versions&quot;: {},\r\n            &quot;is_full_view&quot;: true,\r\n            &quot;language&quot;: &quot;javascript&quot;,\r\n            &quot;location_grouping&quot;: [],\r\n            &quot;name&quot;: &quot;asdasdaasd&quot;,\r\n            &quot;open_error_count&quot;: 3,\r\n            &quot;release_stages&quot;: [\r\n                &quot;production&quot;\r\n            ],\r\n            &quot;resolve_on_deploy&quot;: false,\r\n            &quot;slug&quot;: &quot;wqeqweqwwqweq&quot;,\r\n            &quot;type&quot;: &quot;js&quot;,\r\n            &quot;updated_at&quot;: &quot;2020-04-06T15:22:10.480Z&quot;,\r\n            &quot;url&quot;: &quot;https://api.bugsnag.com/projects/12312312213123&quot;,\r\n            &quot;url_whitelist&quot;: null\r\n        }\r\n    ]\r\n\r\nWhat I need is to remove all lines apart from &quot;id:&quot; and &quot;name:&quot; and preserve the JSON structure. Can anybody advise a Python or bash script to handle this?\r\n",
        "link": "https://stackoverflow.com/questions/61746910/need-to-cut-off-some-unnecessary-information-from-a-json-file-and-preserve-the-j",
        "title": "Need to cut off some unnecessary information from a JSON file and preserve the JSON structure"
    },
    {
        "tags": [
            "json",
            "linux",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1589282265,
                "post_id": 61749964,
                "comment_id": 109224973,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1589282498,
                "creation_date": 1589282498,
                "answer_id": 61750435,
                "question_id": 61749964,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Once you fix your example JSON so it&#39;s valid:\r\n\r\n    $&#160;jq -r &#39;to_entries[] | [.key, (.value | tonumber)] | @csv&#39; input.json\r\n    &quot;A1&quot;,1.2\r\n    &quot;A2&quot;,3.5\r\n    &quot;A3&quot;,2.6\r\n\r\n`to_entries` turns an object into an array of objects with the `key` field holding the name of one of the original object&#39;s keys and `value` its corresponding value. Then turn each of those objects into a two-element array which is fed to `@csv`.",
                "title": "How I can transform json to csv with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1661082091,
        "creation_date": 1589281013,
        "last_edit_date": 1661082091,
        "question_id": 61749964,
        "body_markdown": "My json file is similar of this: \r\n````\r\n{\r\n&quot;A1&quot;: &quot;1.2&quot;\r\n&quot;A2&quot;: &quot;3.5&quot;\r\n&quot;A3&quot;: &quot;2.6&quot;\r\n}\r\n````\r\nI need transform it to csv file and it looks like this:\r\n``` \r\nA1,1.2\r\nA2,3.5\r\nA3,2.6\r\n````\r\nMy code is:\r\n\r\n```\r\njq -r &#39;map(.[] | tonumber) | @csv&#39; file.json &gt; file.csv\r\n```\r\nand my result is:\r\n```\r\n1.2,3.5,2.6\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/61749964/how-i-can-transform-json-to-csv-with-jq",
        "title": "How I can transform json to csv with jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4654355,
                    "reputation": 3851,
                    "user_id": 3794110,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/e9c91d05250485e6bffe85655d4ac6bd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Mornor",
                    "link": "https://stackoverflow.com/users/3794110/mornor"
                },
                "reply_to_user": {
                    "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": 1589286302,
                "post_id": 61751375,
                "comment_id": 109227245,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1,
                "creation_date": 1589286814,
                "post_id": 61751375,
                "comment_id": 109227551,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1589286430,
                "creation_date": 1589286430,
                "answer_id": 61751718,
                "question_id": 61751375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try [JQ Play][1]\r\n\r\n\r\nI tried with the following jq. It should work as long as you are sure of the format of the array.\r\n\r\n`[.[] |  {ParameterKey: split(&quot;=&quot;)[0], ParameterValue: split(&quot;=&quot;)[1]}]`\r\n\r\n\r\nIf you are using from terminal, you can use the following option\r\n\r\n`cat test.json | jq &#39;[.[] |  {ParameterKey: split(&quot;=&quot;)[0], ParameterValue: split(&quot;=&quot;)[1]}]&#39;`\r\n\r\n  [1]: https://jqplay.org",
                "title": "Transforming a list containing key/value strings with jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1589287436,
                "creation_date": 1589287436,
                "answer_id": 61752044,
                "question_id": 61751375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need to use `split()` call twice but just once and access the results directly with the Array/Object Value Iterator: `.[]` and specifying the index inside\r\n\r\n    jq -n &#39;[ inputs[] | split(&quot;=&quot;) | {ParameterKey: .[0], ParameterValue: .[1]} ]&#39;\r\n",
                "title": "Transforming a list containing key/value strings with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1589290555,
        "creation_date": 1589285412,
        "last_edit_date": 1589290555,
        "question_id": 61751375,
        "body_markdown": "So, I basically have a file `test.json`\r\n```\r\n[\r\n  &quot;Name=TestName&quot;,\r\n  &quot;Tag=TestTag&quot;\r\n]\r\n```\r\n\r\nWhich I&#39;d like to transform into \r\n```\r\n[\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;Name&quot;,\r\n    &quot;ParameterValue&quot;: &quot;TestName&quot;,\r\n  },\r\n  {\r\n    &quot;ParameterKey&quot;: &quot;Tag&quot;,\r\n    &quot;ParameterValue&quot;: &quot;TestTag&quot;,\r\n  }\r\n]\r\n```\r\n\r\nWith `jq`. Any idea? ",
        "link": "https://stackoverflow.com/questions/61751375/transforming-a-list-containing-key-value-strings-with-jq",
        "title": "Transforming a list containing key/value strings with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12425782,
                    "reputation": 9067,
                    "user_id": 9050514,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/UE2mV.jpg?s=256",
                    "display_name": "deadshot",
                    "link": "https://stackoverflow.com/users/9050514/deadshot"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1589344637,
                "post_id": 61766505,
                "comment_id": 109253227,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1589344694,
                "post_id": 61766505,
                "comment_id": 109253243,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7858185,
                    "reputation": 13,
                    "user_id": 5939343,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8574bfe25e0b0da5fbb5f230869e0972?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Morphie",
                    "link": "https://stackoverflow.com/users/5939343/morphie"
                },
                "reply_to_user": {
                    "account_id": 12425782,
                    "reputation": 9067,
                    "user_id": 9050514,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/UE2mV.jpg?s=256",
                    "display_name": "deadshot",
                    "link": "https://stackoverflow.com/users/9050514/deadshot"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1589346124,
                "post_id": 61766505,
                "comment_id": 109253655,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12425782,
                    "reputation": 9067,
                    "user_id": 9050514,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/UE2mV.jpg?s=256",
                    "display_name": "deadshot",
                    "link": "https://stackoverflow.com/users/9050514/deadshot"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1589346831,
                "post_id": 61766505,
                "comment_id": 109253848,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7858185,
                    "reputation": 13,
                    "user_id": 5939343,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8574bfe25e0b0da5fbb5f230869e0972?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Morphie",
                    "link": "https://stackoverflow.com/users/5939343/morphie"
                },
                "reply_to_user": {
                    "account_id": 12425782,
                    "reputation": 9067,
                    "user_id": 9050514,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/UE2mV.jpg?s=256",
                    "display_name": "deadshot",
                    "link": "https://stackoverflow.com/users/9050514/deadshot"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1589347329,
                "post_id": 61766505,
                "comment_id": 109253989,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1589347284,
                "creation_date": 1589347284,
                "answer_id": 61767001,
                "question_id": 61766505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A way of doing it:\r\n```\r\n.rows | map({(.automatic.fqdn): {Environment: .normal.environment, OS: .automatic.os}}) | add\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/SVYH5-jLGN)&lt;/sup&gt;",
                "title": "Filtering and creating a new json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1589347286,
        "creation_date": 1589344409,
        "last_edit_date": 1589347286,
        "question_id": 61766505,
        "body_markdown": "I am fetching node data from a chef server using knife search in json format. It returns huge data which is not relevant to me.\r\n\r\nI am saving the whole result in a file nodeinfo.json and able to print only required data, but not sure how to convert it into a new json file.\r\n\r\nData I am fetching\r\n\r\n``` \r\n$ cat nodeinfo.json | jq &#39;.rows[].automatic.fqdn&#39;\r\n&quot;node1&quot;\r\n&quot;node2&quot;\r\n&quot;node3&quot;\r\n&quot;node4&quot;\r\n&quot;node5&quot;\r\n\r\n\r\n$ cat nodeinfo.json | jq &#39;.rows[].normal.environment&#39;\r\n&quot;PRD&quot;\r\n&quot;PRD&quot;\r\n&quot;PRD&quot;\r\n&quot;NPR&quot;\r\n&quot;NPR&quot;\r\n\r\n$ cat nodeinfo.json | jq &#39;.rows[].automatic.os&#39;\r\n&quot;linux&quot;\r\n&quot;linux&quot;\r\n&quot;linux&quot;\r\n&quot;linux&quot;\r\n&quot;linux&quot;\r\n```\r\nWhat I want in my new json file\r\n```\r\n{\r\n&quot;node&quot;:{\r\n\t\t&quot;Environment&quot;: &quot;PRD&quot;,\r\n\t\t&quot;Os&quot;: &quot;linux&quot;\r\n\t},\r\n&quot;node2&quot;:{\r\n\t\t&quot;Environment&quot;: &quot;PRD&quot;,\r\n\t\t&quot;Os&quot;: &quot;linux&quot;\r\n\t},\r\n&quot;node3&quot;:{\r\n\t\t&quot;Environment&quot;: &quot;PRD&quot;,\r\n\t\t&quot;Os&quot;: &quot;linux&quot;\r\n\t},\r\n&quot;node4&quot;:{\r\n\t\t&quot;Environment&quot;: &quot;NPR&quot;,\r\n\t\t&quot;Os&quot;: &quot;linux&quot;\r\n\t},\t\r\n&quot;node5&quot;:{\r\n\t\t&quot;Environment&quot;: &quot;NPR&quot;,\r\n\t\t&quot;Os&quot;: &quot;linux&quot;\r\n\t}\r\n}\t\r\n\t\r\n```\r\n\r\n\r\nnodeinfo.json snippet\r\n```\r\n[{\r\n        &quot;results&quot;: 10,\r\n        &quot;rows&quot;: [{\r\n                &quot;name&quot;: &quot;node1&quot;,\r\n                &quot;chef_environment&quot;: &quot;npr&quot;,\r\n                &quot;json_class&quot;: &quot;Chef::Node&quot;,\r\n                &quot;automatic&quot;: {\r\n                    &quot;kernel&quot;: {\r\n                        &quot;name&quot;: &quot;Linux&quot;,\r\n                        &quot;release&quot;: &quot;3.10.0-1062.12.1.el7.x86_64&quot;,\r\n                        &quot;version&quot;: &quot;#1 SMP Thu Dec 12 06:44:49 EST 2019&quot;,\r\n                        &quot;machine&quot;: &quot;x86_64&quot;,\r\n\t\t\t\t\t\t-\r\n\t\t\t\t\t\t-\r\n\t\t\t\t\t\t-\r\n\t\t\t\t\t&quot;hostname&quot;: &quot;hostnamevalue&quot;,\r\n                    &quot;machinename&quot;: &quot;machinenamevalue&quot;,\r\n                    &quot;fqdn&quot;: &quot;node1&quot;\r\n\t\t\t\t\t-\r\n\t\t\t\t\t-\r\n\t\t\t\t\t} }\r\n\t\t\t   },\r\n\t\t\t   &quot;name&quot;: &quot;node2&quot;\r\n\t\t\t   -\r\n\t\t\t   -\r\n\t\t\t   -\r\n\t\t\t   -\r\n\t\t\t}]\r\n}]\t\r\n```\r\nIf anyone can help me in doing this, Thanks :)",
        "link": "https://stackoverflow.com/questions/61766505/filtering-and-creating-a-new-json-file",
        "title": "Filtering and creating a new json file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1589360087,
                "creation_date": 1589360087,
                "answer_id": 61770261,
                "question_id": 61769820,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One option slong the lines of your attempt:\r\n\r\n    jq -s add file1 file2\r\n\r\nAnother:\r\n\r\n       jq -n &#39;input+input&#39; file1 file2",
                "title": "Merge json files using jq (one input object per file -&gt; one larger output object, not a list)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1611167668,
        "creation_date": 1589358644,
        "last_edit_date": 1611167668,
        "question_id": 61769820,
        "body_markdown": "I am merging two json files using &quot;jq -s . file1 file2&quot;, but I want them to get merged without comma separation. Also it shouldn&#39;t start with []\r\n\r\n**file 1:**\r\n```\r\n{\r\n  &quot;node1&quot;: {\r\n    &quot;Environment&quot;: &quot;PRD&quot;,\r\n    &quot;OS&quot;: &quot;linux&quot;\r\n  },\r\n  &quot;node2&quot;: {\r\n    &quot;Environment&quot;: &quot;NPR&quot;,\r\n    &quot;OS&quot;: &quot;linux&quot;\r\n  }\r\n}\r\n```\r\n**file 2:**\r\n```\r\n{\r\n  &quot;node3&quot;: {\r\n    &quot;Environment&quot;: &quot;PRD&quot;,\r\n    &quot;OS&quot;: &quot;linux&quot;\r\n  },\r\n  &quot;node4&quot;: {\r\n    &quot;Environment&quot;: &quot;NPR&quot;,\r\n    &quot;OS&quot;: &quot;linux&quot;\r\n  }\r\n}\r\n```\r\n\r\n**Output using jq -s . file 1 file 2**\r\n```\r\n[\r\n\t{\r\n\t  &quot;node1&quot;: {\r\n\t\t&quot;Environment&quot;: &quot;PRD&quot;,\r\n\t\t&quot;OS&quot;: &quot;linux&quot;\r\n\t  },\r\n\t  &quot;node2&quot;: {\r\n\t\t&quot;Environment&quot;: &quot;NPR&quot;,\r\n\t\t&quot;OS&quot;: &quot;linux&quot;\r\n\t  }\r\n\t},\r\n\t{\r\n\t  &quot;node3&quot;: {\r\n\t\t&quot;Environment&quot;: &quot;PRD&quot;,\r\n\t\t&quot;OS&quot;: &quot;linux&quot;\r\n\t  },\r\n\t  &quot;node4&quot;: {\r\n\t\t&quot;Environment&quot;: &quot;NPR&quot;,\r\n\t\t&quot;OS&quot;: &quot;linux&quot;\r\n\t  }\r\n\t}\r\n]\r\n```\r\n**Required output:**\r\n```\r\n{\r\n  &quot;node1&quot;: {\r\n    &quot;Environment&quot;: &quot;PRD&quot;,\r\n    &quot;OS&quot;: &quot;linux&quot;\r\n  },\r\n  &quot;node2&quot;: {\r\n    &quot;Environment&quot;: &quot;NPR&quot;,\r\n    &quot;OS&quot;: &quot;linux&quot;\r\n  },\r\n    &quot;node3&quot;: {\r\n    &quot;Environment&quot;: &quot;PRD&quot;,\r\n    &quot;OS&quot;: &quot;linux&quot;\r\n  },\r\n  &quot;node4&quot;: {\r\n    &quot;Environment&quot;: &quot;NPR&quot;,\r\n    &quot;OS&quot;: &quot;linux&quot;\r\n  }\r\n} \r\n```\r\n\r\nCan anyone help me finding solution to this, Thank you!",
        "link": "https://stackoverflow.com/questions/61769820/merge-json-files-using-jq-one-input-object-per-file-one-larger-output-object",
        "title": "Merge json files using jq (one input object per file -&gt; one larger output object, not a list)"
    },
    {
        "tags": [
            "yaml",
            "jq",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 12,
                "is_accepted": true,
                "score": 12,
                "last_activity_date": 1589395781,
                "last_edit_date": 1589395781,
                "creation_date": 1589388775,
                "answer_id": 61780374,
                "question_id": 61779277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need to use `--yaml-output` flag, which tries to parse the output of the filter defined as a YAML entity. For getting the raw strings, use a filter in the JSON context itself\r\n\r\n    yq -r &#39;.images.tags[]&#39;\r\n",
                "title": "yq to get values from key value pair"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1589389081,
                "creation_date": 1589389081,
                "answer_id": 61780471,
                "question_id": 61779277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Found the answer, Inian kind of posted an answer but there was a small change\r\n\r\n`\r\nyq -r &#39;.images.tags | to_entries[].value | split(&quot;:&quot;)[0]&#39; values.yaml\r\n`\r\n",
                "title": "yq to get values from key value pair"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1740023979,
                "last_edit_date": 1740023979,
                "creation_date": 1740023696,
                "answer_id": 79453310,
                "question_id": 61779277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In my research of decoding all base64-ed Kubernetes Secret key-value pairs, this is my solution (obviously based on Arora&#39;s answer):\r\n\r\n    kubectl -n &lt;namespace&gt; get secrets &lt;secret_name&gt; -o yaml | \\\r\n      yq &#39;.data | to_entries | .[].value&#39; | \\\r\n      while read line; do echo $line | base64 -d -; done",
                "title": "yq to get values from key value pair"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 7,
        "last_activity_date": 1740023979,
        "creation_date": 1589385536,
        "last_edit_date": 1589388633,
        "question_id": 61779277,
        "body_markdown": "I have a simple values.yaml file which has below data:\r\n```\r\nimages:\r\n  tags:\r\n    one: abc:v0.3-16-07\r\n    two: xyz:ng-0.23.0\r\n    pq: qaa:0df1e21e752b3d3.2020-04-27_1\r\n```\r\nUsing \r\n\r\n    yq -r --yaml-output &quot;.images.tags&quot; values.yaml\r\n\r\nI can get below output\r\n```\r\none: abc:v0.3-16-07\r\ntwo: xyz:ng-0.23.0\r\npq: qaa:0df1e21e752b3d3.2020-04-27_1\r\n```\r\nBut how can i get the values from the above?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61779277/yq-to-get-values-from-key-value-pair",
        "title": "yq to get values from key value pair"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "ifs"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1589422154,
                "post_id": 61787932,
                "comment_id": 109290686,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1589422239,
                "post_id": 61787932,
                "comment_id": 109290706,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1589424007,
                "post_id": 61787932,
                "comment_id": 109291164,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1589424969,
                "post_id": 61787932,
                "comment_id": 109291385,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1589424104,
                "last_edit_date": 1589424104,
                "creation_date": 1589423333,
                "answer_id": 61788275,
                "question_id": 61787932,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an easier way to reproduce your problem:\r\n\r\n    var=( $(IFS=&#39;,&#39;; echo &quot;foo,bar&quot; ) )\r\n    declare -p var\r\n\r\nWhat you expect is `declare -a var=([0]=&quot;foo&quot; [1]=&quot;bar&quot;)` but what you get is `declare -a var=([0]=&quot;foo,bar&quot;)`\r\n\r\nThis happens because IFS affects word splitting and not program output. Since there is no word splitting in the scope of your variable, it doesn&#39;t affect anything.\r\n\r\nIf you instead define it in the scope that does word splitting, i.e. the scope in which the `$(..)` expansion happens:\r\n\r\n    IFS=&#39;,&#39;\r\n    var=( $(echo &quot;foo,bar&quot;) )\r\n\r\nthen you get the result you expect.\r\n",
                "title": "Why bash does not json split array with jq -r bash IFS explicitly defined variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1589424104,
        "creation_date": 1589421223,
        "question_id": 61787932,
        "body_markdown": "I am reading an array from a file\r\n\r\nfile.json\r\n```\r\n{\r\n  &quot;content&quot;: [&quot;string with spaces&quot;, &quot;another string with spaces&quot;, &quot;yet another string with spaces&quot;]\r\n}\r\n```\r\n\r\n```\r\n#!/bin/bash\r\nGROUP_ID_TEMP=( $(IFS=&#39;,&#39;; jq -r &#39;.content&#39; file.json) )\r\n```\r\n\r\nwhy does jq read content print or echo content as space separated array for the below codeblock at the whitespace rather than the comma &#39;,&#39; as explicitly stated?\r\n\r\n\r\n```\r\nfor each in &quot;${GROUP_ID_TEMP[@]}&quot;\r\ndo\r\n    echo &quot;$each&quot; &gt;&gt; &quot;file.txt&quot;\r\ndone\r\n```",
        "link": "https://stackoverflow.com/questions/61787932/why-bash-does-not-json-split-array-with-jq-r-bash-ifs-explicitly-defined-variab",
        "title": "Why bash does not json split array with jq -r bash IFS explicitly defined variable"
    },
    {
        "tags": [
            "arrays",
            "json",
            "object",
            "jq",
            "transpose"
        ],
        "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": 1589442279,
                "post_id": 61791902,
                "comment_id": 109297023,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1616424,
                    "reputation": 1994,
                    "user_id": 1493981,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/dad603609d5015a0489fab48c3650d46?s=256&d=identicon&r=PG",
                    "display_name": "Lukas Grebe",
                    "link": "https://stackoverflow.com/users/1493981/lukas-grebe"
                },
                "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": 1589442596,
                "post_id": 61791902,
                "comment_id": 109297189,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1589446519,
                "last_edit_date": 1589446519,
                "creation_date": 1589442886,
                "answer_id": 61792119,
                "question_id": 61791902,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one solution:\r\n\r\n```\r\n[range(0; .columnA|length) as $i\r\n | {columnA: .columnA[$i], columnB: .columnB[$i]}]\r\n```\r\n\r\nAnd here&#39;s another that is keyname-neutral and should work for any number of &quot;columns&quot;:\r\n```\r\ndef objectify($template):\r\n  . as $in\r\n  | ($template|keys_unsorted) as $k\r\n  | reduce range(0; $k|length) as $i (null; . + {($k[$i]): $in[$i]});\r\n\r\n. as $in\r\n| [.[]]\r\n| transpose\r\n| map(objectify($in))\r\n```\r\n",
                "title": "convert column arrays to array of row objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1589443252,
                "creation_date": 1589443252,
                "answer_id": 61792211,
                "question_id": 61791902,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `transpose` builtin:\r\n```\r\n[ [{columnA: .columnA[]}],\r\n  [{columnB: .columnB[]}]\r\n] | transpose | map(add)\r\n```",
                "title": "convert column arrays to array of row objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1589443714,
                "creation_date": 1589443714,
                "answer_id": 61792344,
                "question_id": 61791902,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "i figured it out:\r\n\r\n`[.columnA,.columnB] | transpose | map({&quot;columnA&quot;:.[0], &quot;columnB&quot;: .[1]})`\r\n\r\n1. Convert to array of arrays\r\n2. transpose\r\n3. convert back to objects",
                "title": "convert column arrays to array of row objects"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1589523053,
        "creation_date": 1589442140,
        "last_edit_date": 1589523053,
        "question_id": 61791902,
        "body_markdown": "i have a json file representing a table with two columns.\r\n\r\nthe Column values are in an array\r\n\r\n`{\r\n&#39;columnA&#39;:[1,2,3],\r\n&#39;columnB&#39;:[6,7,8]\r\n}`\r\n\r\ni need to convert it to an array of rows:\r\n\r\n`[\r\n{&#39;columnA&#39;:1, &#39;columnB&#39;:6},\r\n{&#39;columnA&#39;:2, &#39;columnB&#39;:7},\r\n{&#39;columnA&#39;:3, &#39;columnB&#39;:8},\r\n]`",
        "link": "https://stackoverflow.com/questions/61791902/convert-column-arrays-to-array-of-row-objects",
        "title": "convert column arrays to array of row objects"
    },
    {
        "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": 1589494419,
                "post_id": 61794706,
                "comment_id": 109325734,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1589470090,
                "last_edit_date": 1589470090,
                "creation_date": 1589451363,
                "answer_id": 61794810,
                "question_id": 61794706,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were really close. Drop `\\r`s at the end, split by ` = `, transform resulting arrays into objects, put them into an array and pass it to `add`.\r\n```\r\n[ inputs\r\n  | gsub(&quot;\\r$&quot;; &quot;&quot;)\r\n  | split(&quot; = &quot;; &quot;&quot;)\r\n  | select(length == 2)\r\n  | {(.[0]): .[1]}\r\n] | add\r\n```\r\nYou need `--raw-input`/`-R` and `--null-input`/`-n` options specified on the command line in order for this to work.",
                "title": "Convert key = value pairs to JSON"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1589535325,
                "last_edit_date": 1589535325,
                "creation_date": 1589493607,
                "answer_id": 61808175,
                "question_id": 61794706,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If one of the &quot;values&quot; contains an &quot;=&quot; then using `split(&quot;=&quot;)` naively will produce incorrect results. If your jq supports `capture`, then here is a solution that avoids that issue:\r\n```\r\njq -nR &#39;\r\n  def trim: sub(&quot;^ +&quot;;&quot;&quot;) | sub(&quot; +$&quot;;&quot;&quot;);\r\n  [inputs\r\n   | select(index(&quot;=&quot;))\r\n   | sub(&quot;\\r$&quot;; &quot;&quot;)\r\n   | capture( &quot;(?&lt;key&gt;[^=]*)=(?&lt;value&gt;.*)&quot; )\r\n   | ( (.key |= trim) | (.value |= trim)) ]\r\n  | from_entries&#39;\r\n```",
                "title": "Convert key = value pairs to JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1751328001,
        "creation_date": 1589451059,
        "last_edit_date": 1589461012,
        "question_id": 61794706,
        "body_markdown": "I am trying to convert a file containing key = value pairs into JSON.\r\nThis file might contain Windows EOL (```\\r\\n```) and empty lines.\r\n\r\nGiven the following input (mind the empty lines):\r\n```\r\nfoo = aa\r\nbar = bb\r\n\r\nqux = cc\r\nwhite space = white space\r\n* = special-char\r\n\r\n\r\n```\r\nThis is the expected result:\r\n```\r\n{\r\n  &quot;foo&quot;: &quot;aa&quot;,\r\n  &quot;bar&quot;: &quot;bb&quot;,\r\n  &quot;qux&quot;: &quot;cc&quot;,\r\n  &quot;white space&quot;: &quot;white space&quot;,\r\n  &quot;*&quot;: &quot;special-char&quot;\r\n}\r\n```\r\nI managed to go this far:\r\n```\r\n{\r\n  &quot;foo&quot;: &quot;aa&quot;\r\n}\r\n{\r\n  &quot;bar&quot;: &quot;bb&quot;\r\n}\r\n{\r\n  &quot;qux&quot;: &quot;cc&quot;\r\n}\r\n{\r\n  &quot;white space&quot;: &quot;white space&quot;\r\n}\r\n{\r\n  &quot;*&quot;: &quot;special-char&quot;\r\n}\r\n```\r\nUsing the following command:\r\n```\r\n jq --raw-input &#39;split(&quot;\\n&quot;) | map(split(&quot; = &quot;) | { (.[0]): .[1] }) | .[]&#39; \r\n```\r\nBut I can not figure out the missing bit. What is missing or is this a better way to achieve this?\r\n\r\n**Edit:** added constraint about empty line and Windows EOL",
        "link": "https://stackoverflow.com/questions/61794706/convert-key-value-pairs-to-json",
        "title": "Convert key = value pairs to JSON"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1589481113,
                "last_edit_date": 1589481113,
                "creation_date": 1589476120,
                "answer_id": 61803274,
                "question_id": 61803107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Select partitions whose name start with `topicA-`, populate an array with their sizes and feed it to `add`.\r\n```\r\n[.brokers[].logDirs[].partitions[] | select(.partition|startswith(&quot;topicA-&quot;)) .size] | add\r\n```\r\n&lt;sup&gt;[demo at jqplay.org](https://jqplay.org/s/RF3dvnoSpU)&lt;/sup&gt;\r\n\r\nBut if you want to calculate the sum for all *topic*s without specifying a name, and produce a report in JSON format, you can do something like this:\r\n```\r\nreduce .brokers[].logDirs[].partitions[] as $p ({};\r\n  .[($p.partition/&quot;-&quot;)[0]] += $p.size\r\n)\r\n```\r\n&lt;sup&gt;[demo at jqplay.org](https://jqplay.org/s/1kU56ePWh7)&lt;/sup&gt;",
                "title": "Filter JSON of nested array by regex and sum using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1589478866,
                "last_edit_date": 1589478866,
                "creation_date": 1589477071,
                "answer_id": 61803570,
                "question_id": 61803107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nOK, here&#39;s a pure jq solution:\r\n\r\n    jq  &#39;(\r\n             [\r\n                 .brokers[].logDirs[].partitions[]\r\n                 | .partition[0:(.partition | index(&quot;-&quot;))]\r\n             ]\r\n             | unique | .[]\r\n         ) as $topic\r\n         | [.brokers[].logDirs[].partitions[]\r\n         | select(.partition | startswith($topic))\r\n         | .size] | $topic, add&#39; &lt; file.json\r\n\r\nI&#39;m not sure it&#39;s readable, I&#39;d probably stop when jq outputs topics and sizes and do the maths in Perl:\r\n\r\n    jq -r &#39;.brokers[].logDirs[].partitions[]\r\n          | .partition as $p\r\n          | $p[0:($p | index(&quot;-&quot;))], .size&#39; &lt; file.json |\r\n    perl -lnwE &#39;$h{$_} += &lt;&gt; ; END {say &quot;$_: $h{$_}&quot; for keys %h}&#39;\r\n",
                "title": "Filter JSON of nested array by regex and sum using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1589481113,
        "creation_date": 1589475657,
        "question_id": 61803107,
        "body_markdown": "I have a JSON of nested array that I would like to filter and then sum the `size` field values for all partitions of a particular topic/prefix. So, for topicA, I want to add the 70, 45 and 100 for topicA-0, topicA-1, topicA-2 sizes to get 215.\r\n\r\n```\r\n{\r\n  &quot;version&quot;: 1,\r\n  &quot;brokers&quot;: [\r\n    {\r\n      &quot;broker&quot;: 1,\r\n      &quot;logDirs&quot;: [\r\n        {\r\n          &quot;logDir&quot;: &quot;/var/lib/kafka/data&quot;,\r\n          &quot;error&quot;: null,\r\n          &quot;partitions&quot;: [\r\n            {\r\n              &quot;partition&quot;: &quot;topicA-0&quot;,\r\n              &quot;size&quot;: 70,\r\n              &quot;offsetLag&quot;: 0,\r\n              &quot;isFuture&quot;: false\r\n            },\r\n            {\r\n              &quot;partition&quot;: &quot;topicB-0&quot;,\r\n              &quot;size&quot;: 40,\r\n              &quot;offsetLag&quot;: 0,\r\n              &quot;isFuture&quot;: false\r\n            },\r\n            {\r\n              &quot;partition&quot;: &quot;topicC-0&quot;,\r\n              &quot;size&quot;: 20,\r\n              &quot;offsetLag&quot;: 0,\r\n              &quot;isFuture&quot;: false\r\n            },\r\n            {\r\n              &quot;partition&quot;: &quot;topicD-0&quot;,\r\n              &quot;size&quot;: 30,\r\n              &quot;offsetLag&quot;: 0,\r\n              &quot;isFuture&quot;: false\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;broker&quot;: 2,\r\n      &quot;logDirs&quot;: [\r\n        {\r\n          &quot;logDir&quot;: &quot;/var/lib/kafka/data&quot;,\r\n          &quot;error&quot;: null,\r\n          &quot;partitions&quot;: [\r\n            {\r\n              &quot;partition&quot;: &quot;topicA-1&quot;,\r\n              &quot;size&quot;: 45,\r\n              &quot;offsetLag&quot;: 0,\r\n              &quot;isFuture&quot;: false\r\n            },\r\n            {\r\n              &quot;partition&quot;: &quot;topicB-1&quot;,\r\n              &quot;size&quot;: 50,\r\n              &quot;offsetLag&quot;: 0,\r\n              &quot;isFuture&quot;: false\r\n            },\r\n            {\r\n              &quot;partition&quot;: &quot;topicC-1&quot;,\r\n              &quot;size&quot;: 10,\r\n              &quot;offsetLag&quot;: 0,\r\n              &quot;isFuture&quot;: false\r\n            },\r\n            {\r\n              &quot;partition&quot;: &quot;topicD-1&quot;,\r\n              &quot;size&quot;: 20,\r\n              &quot;offsetLag&quot;: 0,\r\n              &quot;isFuture&quot;: false\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;broker&quot;: 3,\r\n      &quot;logDirs&quot;: [\r\n        {\r\n          &quot;logDir&quot;: &quot;/var/lib/kafka/data&quot;,\r\n          &quot;error&quot;: null,\r\n          &quot;partitions&quot;: [\r\n            {\r\n              &quot;partition&quot;: &quot;topicA-2&quot;,\r\n              &quot;size&quot;: 100,\r\n              &quot;offsetLag&quot;: 0,\r\n              &quot;isFuture&quot;: false\r\n            },\r\n            {\r\n              &quot;partition&quot;: &quot;topicB-2&quot;,\r\n              &quot;size&quot;: 60,\r\n              &quot;offsetLag&quot;: 0,\r\n              &quot;isFuture&quot;: false\r\n            },\r\n            {\r\n              &quot;partition&quot;: &quot;topicC-2&quot;,\r\n              &quot;size&quot;: 80,\r\n              &quot;offsetLag&quot;: 0,\r\n              &quot;isFuture&quot;: false\r\n            },\r\n            {\r\n              &quot;partition&quot;: &quot;topicD-2&quot;,\r\n              &quot;size&quot;: 5,\r\n              &quot;offsetLag&quot;: 0,\r\n              &quot;isFuture&quot;: false\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nHow can I achieve this in `jq`? I tried `jq -c &#39;select( any(.brokers[].logDirs[].partitions[].partition; test(&quot;topicA-&quot;)) | .size? | numbers ] | add)&#39;` but didn&#39;t work. Thanks in advance",
        "link": "https://stackoverflow.com/questions/61803107/filter-json-of-nested-array-by-regex-and-sum-using-jq",
        "title": "Filter JSON of nested array by regex and sum using jq"
    },
    {
        "tags": [
            "bash",
            "filenames",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1104421,
                    "reputation": 1163,
                    "user_id": 1096140,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/5rFfC.jpg?s=256",
                    "display_name": "hesham_EE",
                    "link": "https://stackoverflow.com/users/1096140/hesham-ee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1589492340,
                "post_id": 61807377,
                "comment_id": 109324933,
                "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": 2,
                "creation_date": 1589494087,
                "post_id": 61807377,
                "comment_id": 109325606,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1589492210,
                "creation_date": 1589492210,
                "answer_id": 61807834,
                "question_id": 61807377,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one option that assumes both jq and a bash or bash-like shell:\r\n```\r\nwhile read -r d\r\ndo\r\n  (cd &quot;$d&quot;; find . -type f -maxdepth 1) | while read -r f ; do\r\n      echo $d $&#39;\\t&#39; $(sed &#39;s,^./,,&#39; &lt;&lt;&lt; &quot;$f&quot;)\r\n  done\r\ndone | jq -Rn &#39;[inputs | split(&quot;\\t&quot;) | {(.[0]): .[1]}] | add&#39;\r\n```",
                "title": "in bash, create json object of key=filename and value=file-contents given sequence of pathed filenames on stdin"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1589493611,
                "creation_date": 1589493611,
                "answer_id": 61808176,
                "question_id": 61807377,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For reference, if you don&#39;t want to use jq:\r\n\r\n    #!/bin/bash\r\n\r\n    gulp() {\r\n        echo $(sed -E &#39;:a;N;$!ba;s/\\r{0,1}\\n/\\\\n/g&#39; $1)\r\n    }\r\n\r\n    while read f1 &amp;&amp; read f2; do\r\n        key=$(gulp $f1)\r\n        val=$(gulp $f2)\r\n        echo &quot;{\\&quot;$f1\\&quot;:\\&quot;$key\\&quot;,\\&quot;$f2\\&quot;:\\&quot;$val\\&quot;}&quot;\r\n    done\r\n\r\nThe &quot;gulp&quot; subroutine reads a file and converts newlines to literal &#39;\\n&#39;.  Then the main part of the script just reads two lines at a time from stdin.",
                "title": "in bash, create json object of key=filename and value=file-contents given sequence of pathed filenames on stdin"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1589526073,
                "last_edit_date": 1589526073,
                "creation_date": 1589497420,
                "answer_id": 61808888,
                "question_id": 61807377,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here it is:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\nfiles=(&#39;alpha.txt&#39; &#39;beta.txt&#39; &#39;delta with space name.txt&#39;)\r\n\r\n# Filling sample files\r\nprintf &#39;wibble&#39; &gt;&#39;alpha.txt&#39;\r\nprintf &#39;fu\\nbar&#39; &gt;&#39;beta.txt&#39;\r\ncat &gt;&#39;delta with space name.txt&#39; &lt;&lt;&#39;EOF&#39;\r\nLorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.\r\nUt enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\r\nDuis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.\r\nExcepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\r\nEOF\r\n\r\n# Stream the test files names (1 per line)\r\nprintf &#39;%s\\n&#39; &quot;${files[@]}&quot; |\r\n  xargs -L 1 -I {} jq -sR --arg key {} &#39;{ ($key): .}&#39; {} | jq -s &#39;add&#39;\r\n```\r\n\r\n`xargs -L 1 -I {}`: Executes a command by passing each line from `stdin` while substituting curly braces by the file name.\r\n\r\n`xargs` then runs the `jq` command to create the filename key and value content of file objects:\r\n\r\n`jq -sR --arg key {} &#39;{ ($key): .}&#39; {}`\r\n\r\n\r\nFinally, the stream of JSON objects is piped into a final `jq -s &#39;add&#39;\r\n` to re-assemble it, into a merged object with `&quot;key&quot;: &quot;value&quot;` pairs:\r\n\r\n```sh\r\njq -s &#39;add&#39;\r\n```\r\n\r\nAnd finally the actual output of all this:\r\n```json\r\n{\r\n  &quot;alpha.txt&quot;: &quot;wibble&quot;,\r\n  &quot;beta.txt&quot;: &quot;fu\\nbar&quot;,\r\n  &quot;delta with space name.txt&quot;: &quot;Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.\\nUt enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\nDuis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.\\nExcepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n&quot;\r\n}\r\n```\r\n\r\n### Processing all files with a single `jq`:\r\n\r\n```sh\r\nxargs -I {} jq -sR &#39;{(input_filename):.}&#39; {} | jq -s add\r\n```\r\n\r\nThe caution about using `input_filename` from `man jq`:\r\n\r\n&gt; **input_filename**\r\n&gt;\r\n&gt; Returns the name of the file whose input is currently being filtered. Note that this will not work well unless jq is running in a UTF-8 locale.\r\n",
                "title": "in bash, create json object of key=filename and value=file-contents given sequence of pathed filenames on stdin"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1589526073,
        "creation_date": 1589490356,
        "last_edit_date": 1589524673,
        "question_id": 61807377,
        "body_markdown": "For example, if the list of the filenames on `stdin` is `/etc/alpha.txt` and `/tmp/beta.txt`\r\n\r\nAnd `/etc/alpha.txt` contains `wibble`\r\n\r\nAnd `/tmp/beta.txt` contains `fu\\nbar`\r\n\r\nThen what I&#39;d like to generate is\r\n\r\n```{&quot;/etc/alpha.txt&quot;:&quot;wibble&quot;,&quot;/tmp/beta.txt&quot;:&quot;fu\\nbar&quot;}```\r\n\r\nI don&#39;t have access to any programming languages.\r\nThis is on a Linux OS.\r\nI can install utilities like `jq`.\r\n\r\nThe solution from L&#233;a Gris looks spot on. Thank you L&#233;a. Alas my question has been closed as not being focused enough. Sorry about that. This is only my second question on StackOverflow! I&#39;m struggling to make it more focused. This really is my exact issue. I&#39;m trying to make the core runner service in https://cyber-dojo.org a little faster.\r\n\r\nMy attempts had got stuck at what to put before the `jq -s add`.",
        "link": "https://stackoverflow.com/questions/61807377/in-bash-create-json-object-of-key-filename-and-value-file-contents-given-sequen",
        "title": "in bash, create json object of key=filename and value=file-contents given sequence of pathed filenames on stdin"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1589557333,
                "post_id": 61823091,
                "comment_id": 109350674,
                "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": 1589557601,
                "post_id": 61823091,
                "comment_id": 109350834,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1589557454,
        "creation_date": 1589557195,
        "question_id": 61823091,
        "body_markdown": "I am callig and endpoint and am trying to get some of the values in it using bash. \r\n\r\nI was able to perform the operation using python&#39;s json and dict functions but I am having trouble figuring out how to convert it to a bash based script that is using `jq` to parse and process the requests response.\r\n\r\n    r = requests.get(\r\n        &quot;url&quot;,\r\n        headers={\r\n            &quot;Authorization&quot; : &quot;Bot {}&quot;.format(bot_token)\r\n        }\r\n    )\r\n    for val in r.json():\r\n        if val[&#39;name&#39;] == &quot;val_name&quot;:\r\n            return val[&#39;id&#39;]\r\n    return &quot;null&quot;\r\n\r\nthe response I get from that api call is\r\n\r\n    [\r\n        {\r\n            &quot;id&quot;: &quot;1123&quot;,\r\n            &quot;last_message_id&quot;: &quot;1123&quot;,\r\n            &quot;last_pin_timestamp&quot;: &quot;2020-03-02T20:12:59.378000+00:00&quot;,\r\n            &quot;type&quot;: 0,\r\n            &quot;name&quot;: &quot;daName&quot;,\r\n            &quot;position&quot;: 4,\r\n            &quot;parent_id&quot;: &quot;544433&quot;,\r\n            &quot;topic&quot;: &quot;theTopic&quot;,\r\n            &quot;guild_id&quot;: &quot;123322&quot;,\r\n            &quot;permission_overwrites&quot;: [\r\n                {\r\n                    &quot;id&quot;: &quot;1231232&quot;,\r\n                    &quot;type&quot;: &quot;role&quot;,\r\n                    &quot;allow&quot;: 0,\r\n                    &quot;deny&quot;: 213123\r\n                }\r\n            ],\r\n            &quot;nsfw&quot;: false,\r\n            &quot;rate_limit_per_user&quot;: 0\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;123123123&quot;,\r\n            &quot;type&quot;: 2,\r\n            &quot;name&quot;: &quot;daName2&quot;,\r\n            &quot;position&quot;: 0,\r\n            &quot;parent_id&quot;: &quot;123123123&quot;,\r\n            &quot;bitrate&quot;: 64000,\r\n            &quot;user_limit&quot;: 0,\r\n            &quot;guild_id&quot;: &quot;234141232&quot;,\r\n            &quot;permission_overwrites&quot;: [\r\n                {\r\n                    &quot;id&quot;: &quot;2345242342&quot;,\r\n                    &quot;type&quot;: &quot;role&quot;,\r\n                    &quot;allow&quot;: 0,\r\n                    &quot;deny&quot;: 0\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;`12123123&quot;,\r\n                    &quot;type&quot;: &quot;role&quot;,\r\n                    &quot;allow&quot;: 0,\r\n                    &quot;deny&quot;: 402663472\r\n                }\r\n            ],\r\n            &quot;nsfw&quot;: false\r\n        },",
        "link": "https://stackoverflow.com/questions/61823091/how-do-i-use-jq-as-a-replacement-for-the-following-operation",
        "title": "how do I use jq as a replacement for the following operation?"
    },
    {
        "tags": [
            "json",
            "regex",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1022874,
                    "reputation": 35264,
                    "user_id": 1032785,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/30816b3d787c2bd9d6f036318304f225?s=256&d=identicon&r=PG",
                    "display_name": "jordanm",
                    "link": "https://stackoverflow.com/users/1032785/jordanm"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1589565063,
                "post_id": 61825385,
                "comment_id": 109354688,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1589565162,
                "post_id": 61825385,
                "comment_id": 109354732,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1589609634,
                "last_edit_date": 1589609634,
                "creation_date": 1589568033,
                "answer_id": 61826200,
                "question_id": 61825385,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the following input:\r\n\r\n    {&quot;監&quot;:[&quot;gaam1&quot;],&quot;參&quot;:[&quot;caam1&quot;],&quot;三&quot;:[&quot;saam1&quot;]}\r\n\r\nthe following filter would do the job:\r\n\r\n    map_values( map(sub( &quot;aam1$&quot;; &quot;āam&quot;) ))\r\n\r\n\r\nFor additional substitutions, you could just extend the `sub` pipeline as far as necessary, along the lines of:\r\n\r\n    map_values( map( sub(_;_) | sub(_;_) | sub(_;_) ))\r\n\r\nIf the `sub` pipeline is very long, it might be better to construct a long if/then/else/end \r\nstatement:\r\n\r\n    if endswith(&quot;aam1&quot;) then sub(&quot;aam1$&quot;; &quot;āam&quot;)\r\n    elif ....\r\n    else .\r\n    end\r\n\r\n## More ambitious regexes\r\n\r\nConsider for example:\r\n\r\n    sub( &quot;aa(?&lt;x&gt;[a-z])1&quot;; &quot;āa\\(.x)&quot;)",
                "title": "Modify value in json in bulk with regex"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1589609634,
        "creation_date": 1589564870,
        "last_edit_date": 1589577416,
        "question_id": 61825385,
        "body_markdown": "I am quite new to using terminal, so I hope you can bear with my novice question.  I have a set of data, containing pronunciation of words in Cantonese:\r\n\r\n    {\r\n        監: [gaam1],\r\n        參: [caam1],\r\n        三: [saam1],\r\n        ...\r\n    }\r\n\r\nAnd I want to search and modify them to the following:\r\n\r\n    {\r\n        監: [gāam],\r\n        參: [cāam],\r\n        三: [sāam],\r\n        ...\r\n    }\r\n\r\n\r\nI know I can work with all objects one by one with built-in function `map` in jq, but how should I write the regex part to get this result?  As the value in each object is different and value I want to replace is different for each object, can this be done with regex?",
        "link": "https://stackoverflow.com/questions/61825385/modify-value-in-json-in-bulk-with-regex",
        "title": "Modify value in json in bulk with regex"
    },
    {
        "tags": [
            "json",
            "pipe",
            "jq",
            "pipeline"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1589594525,
                "creation_date": 1589594525,
                "answer_id": 61830981,
                "question_id": 61830348,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In a nutshell, use &#39;|&#39; instead of &#39;,&#39;.\r\n\r\nE.g.\r\n```\r\n.products[].attributes.artifactDetails.url = &quot;abc&quot;\r\n| .products[].cookbookName = &quot;cookbook&quot;\r\n```\r\n\r\n",
                "title": "jq: one jq command to update multiple values in Json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1589960453,
        "creation_date": 1589588585,
        "last_edit_date": 1589960453,
        "question_id": 61830348,
        "body_markdown": "i have below json file, i need to update all the key values using one jq command.\r\n\r\n    {\r\n\t&quot;changeDetails&quot;: {\r\n\t\t&quot;chgNumber&quot;: &quot;$ASKNOW_CRQ&quot;\r\n\t},\r\n\t&quot;environmentType&quot;: &quot;$ENV_TYPE&quot;,\r\n\t&quot;fqdn&quot;: &quot;$FQDN.visa.com&quot;,\r\n\t&quot;products&quot;: [{\r\n\t\t&quot;action&quot;: &quot;deploy&quot;,\r\n\t\t&quot;attributes&quot;: {\r\n\t\t\t&quot;artifactDetails&quot;: {\r\n\t\t\t\t&quot;url&quot;: &quot;$ARTIFACT_URL&quot;\r\n\t\t\t},\r\n\t\t\t&quot;containers&quot;: &quot;$CONTAINER_NAME&quot;\r\n\t\t},\r\n\t\t&quot;productName&quot;: &quot;$PACKAGE_ID&quot;,\r\n\t\t&quot;cookbookName&quot;: &quot;visa_springboot&quot;\r\n\t}],\r\n\t&quot;tpg&quot;: &quot;O&amp;I&quot;}\r\n\r\nBelow jq command works and able to update only below keys in json file\r\n\r\n    . + {environmentType:&quot;xz&quot;, fqdn:&quot;abc&quot;, tpg:&quot;mnop&quot; }\r\n\r\nusing below sample, i am able to update all the keys by running multiple jq commands\r\n\r\n    contents=&quot;$(jq &#39;.products.action = &quot;abcde&quot;&#39; test.json)&quot;\r\n    echo &quot;${contents}&quot; &gt; test.json\r\n\r\nUsing below command it is creating multiple json file for each value update.\r\n\r\n    .products[].attributes.artifactDetails.url = &quot;abc&quot;, .products[].cookbookName = &quot;cookbook&quot;\r\n\r\n\r\nI need only one JQ command to update all the values in Json file and output should be redirect  to final.json file.\r\n\r\n\r\n  [1]: https://jqplay.org/s/X5MI2D4YrH",
        "link": "https://stackoverflow.com/questions/61830348/jq-one-jq-command-to-update-multiple-values-in-json-file",
        "title": "jq: one jq command to update multiple values in Json file"
    },
    {
        "tags": [
            "random",
            "jq",
            "uuid"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1589684400,
                "last_edit_date": 1589684400,
                "creation_date": 1589666713,
                "answer_id": 61844199,
                "question_id": 61842926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq currently has no support for UUID generation, so your best bet would be to feed UUIDs in to jq, e.g. along these lines:\r\n\r\n```\r\nruby -e &#39;require &quot;securerandom&quot;; p SecureRandom.uuid&#39; | jq &#39;{uuid: .}&#39;\r\n{\r\n  &quot;uuid&quot;: &quot;5657dd65-a495-4487-9887-c7f0e01645c9&quot;\r\n}\r\n```\r\n\r\nThe PRNG contributions for jq have unfortunately not yet made their way into an official release.  For examples of PRNG generators written in jq, see e.g. rosettacode:\r\n\r\nhttps://rosettacode.org/wiki/Linear_congruential_generator#jq \r\n\r\n## Reading from an unbounded stream of UUIDs\r\n\r\nAssuming the availability of a uuid generator such as uuidgen, you could use `input` or `inputs` along the following lines:\r\n\r\n    jq -nR &#39;[range(0;10) | input]&#39; &lt; &lt;(while true; do uuidgen ; done)\r\n\r\n(Notice that an OS pipe has been avoided here.)\r\n",
                "title": "jq : Generate UUID in field"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1625135219,
                "last_edit_date": 1625135219,
                "creation_date": 1625045749,
                "answer_id": 68192205,
                "question_id": 61842926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is possible to generate pseudo-random numbers in `jq` if you provide _one_ initial random number (`--argjson initialRandomNumber`).\r\nPassing `$RANDOM$RANDOM` instead of `$RANDOM` is intended to increase the range for the initial pseudo-random value.\r\n\r\nI used a slightly modified version of the function `nextRandomNumber` from Rosettacode [jq: random numbers](http://rosettacode.org/wiki/Random_numbers#jq)\r\nto generate random numbers, Strings and UUIDs as shown in the following code.\r\n\r\nEach function takes a parameter `$state` and delivers a `newState` in the response for a subsequent call.\r\n\r\nBecause you ask how to generate a\r\n\r\n 1. random number\r\n 2. random string\r\n 3. UUID\r\n\r\nyou can find 6 functions in my code to generate a single instance and an array of them.\r\n\r\nYou can pick the function you need and use it as a filter in `jq`.\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\njq -c -r -n --argjson initialRandomNumber &quot;$RANDOM$RANDOM&quot; &#39;\r\n  # 15-bit integers generated using the same formula as rand() from the Microsoft C Runtime.\r\n  # The random numbers are in [0 -- 32767] inclusive.\r\n  #\r\n  # Input: \r\n  #   first call:      $state = a random number provided to jq by parameter\r\n  #   subsequent call: $state = &quot;newState&quot; from last response\r\n  #\r\n  # Output: \r\n  #   object with pseudo-random number and &quot;newState&quot; for a subsequent call.\r\n  def nextRandomNumber($state):\r\n    ( (214013 * $state) + 2531011) % 2147483648 # mod 2^31\r\n    | { newState: .,\r\n        randomNumber: (. / 65536 | floor) };\r\n\r\n  def nextRandomNumbers($state; $count):\r\n    [foreach range($count) as $x (nextRandomNumber($state); nextRandomNumber(.newState); .)]\r\n    | { newState: .[-1].newState,\r\n        randomNumbers: map(.randomNumber) };\r\n\r\n\r\n# ----- random UUID ---------------\r\n\r\n  def hexByte:\r\n    [. / 256 % 16, . % 16]\r\n    | map(if . &lt; 10 then . + 48 else . + 87 end)   # ASCII: 0...9: 48-57, a...f: 97-102\r\n    | implode;\r\n\r\n  def nextRandomUUID($state):\r\n    nextRandomNumbers($state; 16)\r\n    | .newState as $newState\r\n    | .randomNumbers\r\n    | map(hexByte)\r\n    | &quot;\\(.[0:4] | join(&quot;&quot;))-\\(.[4:6] | join(&quot;&quot;))-\\(.[6:8] | join(&quot;&quot;))-\\(.[8:10] | join(&quot;&quot;))-\\(.[10:] | join(&quot;&quot;))&quot;\r\n    | { newState: $newState,\r\n        randomUUID: . };\r\n\r\n  def nextRandomUUIDs($state; $count):\r\n    [foreach range($count) as $x (nextRandomUUID($state); nextRandomUUID(.newState); .)]\r\n    | { newState: .[-1].newState,\r\n        randomUUIDs: map(.randomUUID) };\r\n\r\n\r\n# ----- random String ---------------\r\n\r\n  def letter:\r\n    . % 52\r\n    | [if . &lt; 26 then . + 65 else . + 71 end]   # ASCII: A...Z: 65-90, a...z: 97-122\r\n    | implode;\r\n\r\n  def nextRandomString($state; $minLength; $maxLength):\r\n    nextRandomNumber($state)\r\n    | (try (.randomNumber % ($maxLength - $minLength + 1) + $minLength) catch $minLength) as $length\r\n    | nextRandomNumbers(.newState; $length)\r\n    | .newState as $newState\r\n    | .randomNumbers\r\n    | map(letter)\r\n    | join(&quot;&quot;)\r\n    | { newState: $newState,\r\n        randomString: . };\r\n\r\n  def nextRandomStrings($state; $count; $minLength; $maxLength):\r\n    [foreach range($count) as $x (nextRandomString($state; $minLength; $maxLength); nextRandomString(.newState; $minLength; $maxLength); .)]\r\n    | { newState: .[-1].newState,\r\n        randomStrings: map(.randomString) };\r\n\r\n\r\n# ----- example usage ---------------\r\n\r\n  nextRandomNumber($initialRandomNumber)               # see output 1\r\n# nextRandomNumbers($initialRandomNumber; 3)           # see output 2\r\n# nextRandomUUID($initialRandomNumber)                 # see output 3\r\n# nextRandomUUIDs($initialRandomNumber; 3)             # see output 4\r\n# nextRandomString($initialRandomNumber; 10; 15)       # see output 5\r\n# nextRandomStrings($initialRandomNumber; 3; 6; 10)    # see output 6\r\n# nextRandomNumber($initialRandomNumber) | nextRandomNumbers(.newState; 3)   # see output 7\r\n&#39;\r\n```\r\n\r\n## Outputs\r\n\r\n`output 1`: generate pseudo-random number\r\n```json\r\n{&quot;newState&quot;:912028498,&quot;randomNumber&quot;:13916}\r\n``` \r\n---\r\n`output 2`: generate 3 pseudo-random numbers\r\n```json\r\n{&quot;newState&quot;:677282016,&quot;randomNumbers&quot;:[10202,20943,6980]}`\r\n``` \r\n---\r\n`output 3`: generate random UUID\r\n```json\r\n{&quot;newState&quot;:1188119770,&quot;randomUUID&quot;:&quot;cdcda95b-af57-1303-da72-d21c6e7b1861&quot;}\r\n``` \r\n---\r\n`output 4`: generate 3 random UUIDs\r\n```json\r\n{&quot;newState&quot;:907540185,&quot;randomUUIDs&quot;:[&quot;855c1445-b529-4301-a535-20cb298feaff&quot;,&quot;5b685e49-8596-830e-f56a-0a22c43c4c32&quot;,&quot;35fed6d8-d72b-2833-fd6f-f99154358067&quot;]}\r\n``` \r\n---\r\n`output 5`: generate random Strings with length 10-15\r\n```json\r\n{&quot;newState&quot;:1037126684,&quot;randomString&quot;:&quot;SJadqPGkERAu&quot;}`\r\n``` \r\n---\r\n`output 6`: generate 3 random Strings with length 6-10\r\n```json\r\n{&quot;newState&quot;:316121190,&quot;randomStrings&quot;:[&quot;eNKxechu&quot;,&quot;XPkvNg&quot;,&quot;TIABHbYCxB&quot;]}`\r\n``` \r\n---\r\n`output 7`: using `newState` for a second call to generate 3 random numbers \r\n```json\r\n{&quot;newState&quot;:808494511,&quot;randomNumbers&quot;:[26045,16811,12336]}`\r\n``` \r\n",
                "title": "jq : Generate UUID in field"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1711658981,
                "creation_date": 1711658981,
                "answer_id": 78240807,
                "question_id": 61842926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If using Linux (MacOS?), you can use the content of `/proc/sys/kernel/random/uuid`:\r\n\r\n```\r\n❯ jq -n --arg uuid &quot;$(cat /proc/sys/kernel/random/uuid)&quot;  &#39;{&quot;id&quot;: $uuid}&#39;\r\n\r\n{\r\n  &quot;id&quot;: &quot;26b8054a-9020-4290-8e77-f52a86e3933e&quot;\r\n}\r\n```",
                "title": "jq : Generate UUID in field"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1718142869,
                "creation_date": 1718142869,
                "answer_id": 78609874,
                "question_id": 61842926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Old question, but I recently ran into the same problem and came up with a somewhat general way of handling this. You could combine jq&#39;s compact format (`-c` option) and read each item in shell, generate a uuid externally, then feed that to jq again to insert it. Also, if you&#39;re handling really large files, chances are you might benefit from jq&#39;s streaming mode (`--stream` option). Here&#39;s an example (using `uuidgen`) if you have a big array file:\r\n\r\n```bash\r\njq --stream -cn &#39;fromstream(1 | truncate_stream(inputs))&#39; big-array.json | while read -r item; do\r\n  jq &#39;.id |= $uuid&#39; --arg uuid &quot;$(uuidgen)&quot; &lt;&lt;&lt;&quot;$item&quot;\r\ndone\r\n```\r\n\r\nYou could also slurp the output to get the array back with `jq -s .` if needed.",
                "title": "jq : Generate UUID in field"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 6,
        "last_activity_date": 1718142869,
        "creation_date": 1589659828,
        "last_edit_date": 1589697003,
        "question_id": 61842926,
        "body_markdown": "I have a requirement to tag records uniquely with UUIDs (for a correlation id). I cant see a direct way to do this via the options, is such a thing possible? If not, is there some kind of workaround that might be able to do this?\r\n\r\nIs it even possible to generate a random number or string in jq?",
        "link": "https://stackoverflow.com/questions/61842926/jq-generate-uuid-in-field",
        "title": "jq : Generate UUID in field"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1589696835,
                "creation_date": 1589696835,
                "answer_id": 61847828,
                "question_id": 61847629,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The jq filter shown in the Q has incorrect positioning of the quotation marks.\r\n\r\nWith your input data in input.json, the following invocation succeeds:\r\n```\r\njq --arg CONTR_CLUSTER_NAME &quot;My-${StackName}&quot; --arg CONTR_CLUSTER_REGION &quot;${Region}&quot;  --arg ZONES &quot;${Zones}&quot; --arg PREFERRED_ZONE &quot;${Region}-a&quot; &#39;\r\n  .metadata.name = $CONTR_CLUSTER_NAME\r\n  | .metadata.region = $CONTR_CLUSTER_REGION\r\n  | .availabilityZones = ($ZONES|split(&quot;,&quot;))\r\n  | (.managedNodeGroups[] | .preferredZone ) = $PREFERRED_ZONE\r\n&#39; input.json\r\n\r\n```\r\n",
                "title": "change a particular element inside array of json objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1589696835,
        "creation_date": 1589695172,
        "last_edit_date": 1589695912,
        "question_id": 61847629,
        "body_markdown": "I have the following json:\r\n\r\n    {\r\n        &quot;kind&quot;: &quot;ClusterConfig&quot;,\r\n        &quot;managedNodeGroups&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;default-nodegroup&quot;,\r\n            &quot;instanceType&quot;: &quot;t3.medium&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;elk-master-nodegroup&quot;,\r\n            &quot;instanceType&quot;: &quot;t3.medium&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;elk-data-nodegroup&quot;,\r\n            &quot;instanceType&quot;: &quot;t3.medium&quot;\r\n          }\r\n        ]\r\n    }\r\n\r\nThe above json is a valid subset of a big json file with some other details, which are suppressed for brevity. Now I want to add an item `availabiltyZone: $PREFERRED_ZONE` to each of the array elements of `managedNodeGroups`. For example, I want the output to be:\r\n\r\n    {\r\n        &quot;kind&quot;: &quot;ClusterConfig&quot;,\r\n        &quot;managedNodeGroups&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;default-nodegroup&quot;,\r\n            &quot;instanceType&quot;: &quot;t3.medium&quot;,\r\n            &quot;availabilityZone&quot;: &quot;us-east-1a&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;elk-master-nodegroup&quot;,\r\n            &quot;instanceType&quot;: &quot;t3.medium&quot;,\r\n            &quot;availabilityZone&quot;: &quot;us-east-1a&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;elk-data-nodegroup&quot;,\r\n            &quot;instanceType&quot;: &quot;t3.medium&quot;,\r\n            &quot;availabilityZone&quot;: &quot;us-east-1a&quot;\r\n          }\r\n        ]\r\n    }\r\n\r\nThe jq command that I am trying and the error is:\r\n\r\n    $ jq --arg CONTR_CLUSTER_NAME &quot;My-${StackName}&quot; --arg CONTR_CLUSTER_REGION &quot;${Region}&quot;  --arg ZONES ${Zones} --arg PREFERRED_ZONE &quot;${Region}-a&quot; &#39;.metadata.name = $CONTR_CLUSTER_NAME | .metadata.region = $CONTR_CLUSTER_REGION | .availabilityZones = ($ZONES|split(&quot;,&quot;))&#39; | (.managedNodeGroups[] | .preferredZone ) = $PREFERRED_ZONE tmp.json \r\n    bash: syntax error near unexpected token `=&#39;\r\n\r\nThe `Region` env variable is set to `us-east-1`, and `Zones` is set to `&quot;\\&quot;us-east-1a\\&quot;,\\&quot;us-east-1c\\&quot;&quot;`, and `StackName` is set to `example`.\r\n\r\nIf I remove just the last part of the command and execute it, the command executes fine. So, it is the appending `PREFERRED_ZONE` to each element of the `managedNodeGroups` array that is causing an issue. For example, the below command, works fine:\r\n\r\n    jq --arg CONTR_CLUSTER_NAME &quot;My-${StackName}&quot; --arg CONTR_CLUSTER_REGION &quot;${Region}&quot;  --arg ZONES ${Zones} --arg PREFERRED_ZONE &quot;${Region}-a&quot; &#39;.metadata.name = $CONTR_CLUSTER_NAME | .metadata.region = $CONTR_CLUSTER_REGION | .availabilityZones = ($ZONES|split(&quot;,&quot;))&#39; tmp.json \r\n    {\r\n        &quot;kind&quot;: &quot;ClusterConfig&quot;,\r\n        &quot;managedNodeGroups&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;default-nodegroup&quot;,\r\n            &quot;instanceType&quot;: &quot;t3.medium&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;elk-master-nodegroup&quot;,\r\n            &quot;instanceType&quot;: &quot;t3.medium&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;elk-data-nodegroup&quot;,\r\n            &quot;instanceType&quot;: &quot;t3.medium&quot;\r\n          }\r\n        ]\r\n    }\r\n\r\nWhat am I doing wrong here ? I am missing some kind of `foreach` for iterating through the array element but can&#39;t figure it out from the docs. I tried with even `map, select` options but could not find a solution.\r\n",
        "link": "https://stackoverflow.com/questions/61847629/change-a-particular-element-inside-array-of-json-objects-using-jq",
        "title": "change a particular element inside array of json objects using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1589736523,
                "post_id": 61855442,
                "comment_id": 109405883,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1589739540,
                "creation_date": 1589739540,
                "answer_id": 61856608,
                "question_id": 61855442,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With a little adjustment, the accepted answer at the link @hek2mgl posted in his comment works just fine for your case.\r\n```\r\nwalk(if type == &quot;object&quot; and keys_unsorted == [&quot;d&quot;] then .d else . end)\r\n```\r\n&lt;sup&gt;[demo at jqplay.org](https://jqplay.org/s/OTACOut1wP)&lt;/sup&gt;",
                "title": "find element by sub-element and replace with sub-element&#39;s value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1629632132,
        "creation_date": 1589734375,
        "last_edit_date": 1629632132,
        "question_id": 61855442,
        "body_markdown": "To make it clear, I have the JSON array of the structure that I want to transform to different structure.\r\n```\r\n[\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 2,\r\n    &quot;c&quot;: {\r\n      &quot;d&quot;: 3\r\n    },\r\n    &quot;e&quot;: {\r\n      &quot;f&quot;: 4,\r\n      &quot;g&quot;: {\r\n        &quot;d&quot;: 8\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;a&quot;: 5,\r\n    &quot;b&quot;: 6,\r\n    &quot;c&quot;: {\r\n      &quot;d&quot;: 7\r\n    }\r\n  },\r\n  {\r\n    &quot;a&quot;: 9,\r\n    &quot;b&quot;: 10,\r\n    &quot;c&quot;: {\r\n      &quot;d&quot;: 11\r\n    },\r\n    &quot;e&quot;: {\r\n      &quot;f&quot;: 12,\r\n      &quot;g&quot;: {\r\n        &quot;d&quot;: 13\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\nI want to transform it to :\r\n```\r\n[\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 2,\r\n    &quot;c&quot;: 3,\r\n    &quot;e&quot;: {\r\n      &quot;f&quot;: 4,\r\n      &quot;g&quot;: 8\r\n    }\r\n  },\r\n  {\r\n    &quot;a&quot;: 5,\r\n    &quot;b&quot;: 6,\r\n    &quot;c&quot;: 7\r\n  },\r\n  {\r\n    &quot;a&quot;: 9,\r\n    &quot;b&quot;: 10,\r\n    &quot;c&quot;: 11,\r\n    &quot;e&quot;: {\r\n      &quot;f&quot;: 12,\r\n      &quot;g&quot;: 13\r\n    }\r\n  }\r\n]\r\n```\r\nSo each element that is of form :\r\n```\r\n&quot;c&quot;: {\r\n    &quot;d&quot;: 3\r\n}\r\n```\r\nI want to transform to:\r\n```\r\n&quot;c&quot;: 3\r\n```\r\nIt is guaranteed that the JSON will not have &#39;d&#39; element in the root object. \r\n\r\nI tried \r\n```\r\njq  \\\r\n            &#39;map(\r\n                with_entries(\r\n                    .value = if .value.&quot;$oid&quot; ? then &quot;ObjectId(&quot; + .value.&quot;$oid&quot;+ &quot;)&quot; else .value end\r\n                    )\r\n                )&#39;\r\n```\r\nbut it&#39;s not working for inner elements.",
        "link": "https://stackoverflow.com/questions/61855442/find-element-by-sub-element-and-replace-with-sub-elements-value",
        "title": "find element by sub-element and replace with sub-element&#39;s value"
    },
    {
        "tags": [
            "json",
            "regex",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1589757613,
                "creation_date": 1589757613,
                "answer_id": 61860077,
                "question_id": 61859923,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a simple solution using `walk`:\r\n```\r\nwalk(if type==&quot;object&quot;\r\n     then with_entries(select(.key | test(&quot;^foo&quot;) | not))\r\n     else . end)\r\n```",
                "title": "Using jq, remove keys that match a regular expression"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1589759340,
        "creation_date": 1589756519,
        "last_edit_date": 1589759340,
        "question_id": 61859923,
        "body_markdown": "I&#39;d like to remove any fields that match a regular expression, while preserving all other fields and the structure of the JSON.\r\nFor example, suppose the JSON looks like this.\r\n```\r\n{\r\n  &quot;this&quot;: {\r\n    &quot;foobar&quot;: {\r\n      &quot;that&quot;: &quot;too&quot;\r\n    },\r\n    &quot;baz&quot;: 3,\r\n    &quot;foo&quot;: 1\r\n    &quot;morefoo&quot;: {\r\n      &quot;foosball&quot;: &quot;hi&quot;\r\n    }\r\n  }\r\n}\r\n```\r\nThen the desired output would be\r\n```\r\n{\r\n  &quot;this&quot;: {\r\n    &quot;baz&quot;: 3,\r\n    &quot;morefoo&quot;: {}\r\n  }\r\n}\r\n```\r\nIt&#39;s possible to do this cleanly by explicitly naming the fields as discussed here:\r\n\r\nhttps://stackoverflow.com/questions/47371280/delete-objects-and-arrays-with-jq-which-match-a-key\r\n\r\n```\r\njq &#39;del(.. | .foo?, .foobar?, .foosball?)&#39;\r\n```\r\nbut I would like to do this with a regular expression, something like\r\n```\r\njq &#39;del(.. | .(&quot;^foo&quot;)?)&#39;  # This does not work\r\n```\r\nSuggestions?  If possible, I&#39;d rather avoid `with_entries`, but if that&#39;s the only way, then so be it.",
        "link": "https://stackoverflow.com/questions/61859923/using-jq-remove-keys-that-match-a-regular-expression",
        "title": "Using jq, remove keys that match a regular expression"
    },
    {
        "tags": [
            "json",
            "csv",
            "multiple-columns",
            "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": 1589766148,
                "post_id": 61860347,
                "comment_id": 109415014,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1589775501,
                "last_edit_date": 1589775501,
                "creation_date": 1589766014,
                "answer_id": 61861156,
                "question_id": 61860347,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The requested format is a bit odd in a couple of respects, so let&#39;s start with a simpler and perhaps more useful goal -- to produce a more regular format:\r\n\r\n```\r\nwww.column.com\texample1.com\twww.column2.com\twww.example1.com\r\nwww.column.com\texample2.com\twww.column2.com\twww.example2.com\r\nwww.column.com\texample3.com\twww.column2.com\twww.example3.com\r\nwww.column.com\texample4.com\twww.column2.com\twww.example4.com\r\n```\r\nThis can be done using the filter:\r\n```\r\n[ [.enrollments[0].csr |  {cn, sans: .sans[]} | [.cn, .sans] ],\r\n  [.enrollments[1].csr |  {cn, sans: .sans[]} | [.cn, .sans] ] ]\r\n| transpose\r\n| map(add)\r\n| .[]\r\n| @csv\r\n```\r\n\r\n## Blanking out the first and third columns in all but the first row\r\n\r\nThe requested format is now readily obtained by tweaking the above jq program so that it becomes:\r\n```\r\n[ [.enrollments[0].csr |  {cn, sans: .sans[]} | [.cn, .sans] ],\r\n  [.enrollments[1].csr |  {cn, sans: .sans[]} | [.cn, .sans] ] ]\r\n| transpose\r\n| map(add)\r\n| (.[0],\r\n   (.[1:][] | (.[2] = &quot;&quot; | .[0] = &quot;&quot; )))\r\n| @csv\r\n```\r\n\r\n## Generic approach\r\nThe first program above can be generalized to allow the &quot;enrollments&quot; array to be arbitrarily long as follows:\r\n```\r\n[ .enrollments[]\r\n  | [ .csr |  {cn, sans: .sans[]} | [.cn, .sans] ]]\r\n| transpose\r\n| map(add)\r\n| .[]\r\n| @tsv\r\n```\r\n\r\nThis can also be modified as before to blank out the values in all but the first row.\r\n\r\n\r\n\r\n\r\n",
                "title": "how do you use jq to create a columns based on objects and list other objects from same array under it for json to convert to csv?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1589843502,
        "creation_date": 1589759688,
        "last_edit_date": 1589843502,
        "question_id": 61860347,
        "body_markdown": "Good day Community,\r\n\r\nI am new to jq and I am trying to use it as a tool to covert json output to csv.\r\n\r\nI have the following situation.  I would like to take json data listed below and covert it to a nicely formatted csv file for other editing and auditing processes out side the format of what json can offer.\r\n\r\nI have the following json data:\r\n\r\n    {\r\n    &quot;enrollments&quot;: [\r\n        {\r\n            &quot;adminContact&quot;: {\r\n                &quot;email&quot;: &quot;admin@domain.com&quot;,\r\n                &quot;firstName&quot;: &quot;john&quot;,\r\n                &quot;lastName&quot;: &quot;doe&quot;,\r\n                &quot;phone&quot;: &quot;555-555-5555&quot;\r\n            },\r\n            &quot;certificateType&quot;: &quot;third-party&quot;,\r\n            &quot;changeManagement&quot;: true,\r\n            &quot;csr&quot;: {\r\n                &quot;c&quot;: &quot;US&quot;,\r\n                &quot;cn&quot;: &quot;www.column.com&quot;,\r\n                &quot;l&quot;: &quot;Houston&quot;,\r\n                &quot;o&quot;: &quot;A Company International Ltd.&quot;,\r\n                &quot;ou&quot;: &quot;Technology and Operations Services&quot;,\r\n                &quot;sans&quot;: [\r\n                    &quot;example1.com&quot;,\r\n                    &quot;example2.com&quot;,\r\n                    &quot;example3.com&quot;,\r\n                    &quot;example4.com&quot;\r\n                ],\r\n                &quot;st&quot;: &quot;Bermingham&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;adminContact&quot;: {\r\n                &quot;email&quot;: &quot;admin@domain.com&quot;,\r\n                &quot;firstName&quot;: &quot;john&quot;,\r\n                &quot;lastName&quot;: &quot;doe&quot;,\r\n                &quot;phone&quot;: &quot;555-555-5555&quot;\r\n            },\r\n            &quot;certificateType&quot;: &quot;third-party&quot;,\r\n            &quot;changeManagement&quot;: true,\r\n            &quot;csr&quot;: {\r\n                &quot;c&quot;: &quot;US&quot;,\r\n                &quot;cn&quot;: &quot;www.column2.com&quot;,\r\n                &quot;l&quot;: &quot;Houston&quot;,\r\n                &quot;o&quot;: &quot;A Company International Ltd.&quot;,\r\n                &quot;ou&quot;: &quot;Technology and Operations Services&quot;,\r\n                &quot;sans&quot;: [\r\n                    &quot;www.example1.com&quot;,\r\n                    &quot;www.example2.com&quot;,\r\n                    &quot;www.example3.com&quot;,\r\n                    &quot;www.example4.com&quot;\r\n                ],\r\n                &quot;st&quot;: &quot;Bermingham&quot;\r\n            },\r\n            &quot;certificateType&quot;: &quot;third-party&quot;,\r\n            &quot;changeManagement&quot;: true,\r\n            &quot;csr&quot;: {\r\n                &quot;c&quot;: &quot;US&quot;,\r\n                &quot;cn&quot;: &quot;www.column-other-additional-iterations.com&quot;,\r\n                &quot;l&quot;: &quot;Houston&quot;,\r\n                &quot;o&quot;: &quot;A Company International Ltd.&quot;,\r\n                &quot;ou&quot;: &quot;Technology and Operations Services&quot;,\r\n                &quot;sans&quot;: [\r\n                    &quot;www.example-to-infinite1.com&quot;,\r\n                    &quot;www.example-to-infinite2.com&quot;,\r\n                    &quot;www.example-to-infinite3.com&quot;,\r\n                    &quot;www.example-to-infinite4.com&quot;\r\n                ],\r\n                &quot;st&quot;: &quot;Bermingham&quot;\r\n        }\r\n    ]\r\n    }\r\n\r\nMy goal is to to covert it to a .csv file in the following format.  I would like to be able to grab any occurrence of &quot;cn&quot; and their corresponding &quot;SANs&quot; to iterate it across and create their individual columns, respectively:\r\n\r\n    Common Name      SANS            Common Name      SANS             =&gt; iterate\r\n    www.column.com   example1.com    www.column2.com  www.example1.com\r\n                     example2.com                     www.example2.com\r\n                     example3.com                     www.example3.com\r\n                     example4.com                     www.example4.com  \r\n\r\n  \r\n\r\nWhat I have been able to do so far:\r\n\r\n    jq -r &#39;.enrollments[].csr | {cn: .cn, sans: .sans[]}  | [.cn, .sans] |@csv&#39; certs.json &gt; test.csv\r\n\r\nAnd it gives me the following output:\r\n\r\n    &quot;www.column.com&quot;,&quot;example1.com&quot;\r\n    &quot;www.column.com&quot;,&quot;example2.com&quot;\r\n    &quot;www.column.com&quot;,&quot;example3.com&quot;\r\n    &quot;www.column.com&quot;,&quot;example4.com&quot;\r\n    &quot;www.column2.com&quot;,&quot;www.example1.com&quot;\r\n    &quot;www.column2.com&quot;,&quot;www.example2.com&quot;\r\n    &quot;www.column2.com&quot;,&quot;www.example3.com&quot;\r\n    &quot;www.column2.com&quot;,&quot;www.example4.com&quot;\r\n    ...iterate through all records of the same type of data that occurs\r\n\r\nSo, I was able to link the &quot;cn&quot; object to the &quot;sans&quot; array.\r\n\r\nIf the desired format I listed above is not possible, would the following output work?\r\n\r\n    Common Name      SANS\r\n    www.column.com   example1.com\r\n    www.column.com   example2.com\r\n    www.column.com   example3.com\r\n    www.column.com   example4.com\r\n    www.column2.com  www.example1.com\r\n    www.column2.com  www.example2.com\r\n    www.column2.com  www.example3.com\r\n    www.column2.com  www.example4.com\r\n    ...iterate through all records of the same type of data that occurs\r\n\r\nWhen I have been researching online I came across some techniques that others were working with but I have not been able to find a solution yet.\r\n\r\nFor the column names, i have been playing around with this within the command.  however, everything I have tried to incorporate this doesnt seem to work:\r\n\r\n    ([&quot;Common Name&quot;] + [&quot;SANS&quot;]),\r\n\r\nIn addition, a lot of posts are saying to work with the map function.\r\n\r\n    jq --raw-output &#39;(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @csv&#39;\r\n\r\n\r\nand I get the following output:\r\n\r\n    jq: error (at &lt;stdin&gt;:51): object ({&quot;adminCont...) is not valid in a csv row\r\n    0,1\r\n\r\n    exit status 5\r\n\r\nIt looked like it got stuck on the first object, I am not sure if the &quot;{&quot; is what the programming is erroring out on but I then tried the following.  I tried to replace the areas where the &quot;^&quot; are with different paths in hopes to having the program find what I am looking for:\r\n\r\n    jq --raw-output &#39;(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | \r\n                          ^                                    ^                            ^\r\n    $cols, $rows[] | @csv&#39;\r\n\r\npaths i have tried replacing it with are the following, respectively: \r\n\r\n    .enrollments[].csr\r\n    .csr.cn\r\n    .csr.sans\r\n\r\nAt this point I am not sure and decided to reach out to the community.  Again, I am new to jq and I am trying to find the connections, relationships, and learn the logic here.  I am open to any suggestions, advice, and/or if there is a better way to capture this information. I am also open to other methods or best practices for using another format output to go with instead.\r\n\r\nI apologize in advance if a similar post of this nature already exists as I was not able to find it in my searches.  If so, please let me know and I will follow the community guidelines to edit or remove this post.\r\n\r\nYour help is much appreciated.  Thank you!",
        "link": "https://stackoverflow.com/questions/61860347/how-do-you-use-jq-to-create-a-columns-based-on-objects-and-list-other-objects-fr",
        "title": "how do you use jq to create a columns based on objects and list other objects from same array under it for json to convert to csv?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1589795487,
                "creation_date": 1589795487,
                "answer_id": 61866880,
                "question_id": 61866465,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "START and END are not visible to JQ as they&#39;re shell variables. You need to pass them to JQ as arguments or environment variables.\r\n```\r\njq -n --argjson START 1 --argjson END 100 &#39;reduce range($START; $END) as $data (.; . + [{&quot;field&quot;: { &quot;empID&quot;: $data, &quot;location&quot;: &quot;India&quot;}}])&#39; &gt; test.json\r\n```",
                "title": "jq -n reduce range fails with shell variable input"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1589795711,
        "creation_date": 1589794096,
        "last_edit_date": 1589795711,
        "question_id": 61866465,
        "body_markdown": "I have a bash function like below.\r\n\r\n    function createJson\r\n    {\r\n    START=1\r\n    END=100    \r\n    jq -n &#39;reduce range($START; $END) as $data (.; . + [{&quot;field&quot;: { &quot;empID&quot;: $data, &quot;location&quot;: &quot;India&quot;}}])&#39;  &gt; test.json    \r\n    }\r\n\r\nThe above script works fine If I mention the direct numeric value in &quot;reduce range&quot;.\r\nFor Example:\r\n\r\n    jq -n &#39;reduce range(0; 100) as $data (.; . + [{&quot;field&quot;: { &quot;empID&quot;: $data, &quot;location&quot;: &quot;India&quot;}}])&#39;  &gt; test.json\r\n\r\nBut when I tried to pass the shell variable to jq -n reduce range it throws error like below.\r\n\r\n    jq: error: START/0 is not defined at &lt;top-level&gt;, line 1:\r\n    reduce range($START; $END) as $data (.; . + [{&quot;field&quot;: { &quot;empID&quot;: $data, &quot;location&quot;: &quot;India&quot;}}])\r\n    jq: error: END/0 is not defined at &lt;top-level&gt;, line 1:\r\n    reduce range($START; $END) as $data (.; . + [{&quot;field&quot;: { &quot;empID&quot;: $data, &quot;location&quot;: &quot;India&quot;}}])\r\n    jq: 2 compile errors\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61866465/jq-n-reduce-range-fails-with-shell-variable-input",
        "title": "jq -n reduce range fails with shell variable input"
    },
    {
        "tags": [
            "json",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1589811550,
                "last_edit_date": 1589811550,
                "creation_date": 1589810819,
                "answer_id": 61871455,
                "question_id": 61870396,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your expected output isn&#39;t quite matching with your description of your problem. If your requirement is to find inside `templating` list find the query containing `&quot;label_values(env)&quot;` and update the `regex` to `&quot;&quot;` you need below. To change it to `*`, use `regex = &quot;*&quot;`\r\n\r\n    .templating.list[] |= ( select(.query == &quot;label_values(env)&quot;).regex = &quot;&quot;)\r\n\r\nThe key is to use the right path and use the select operator to get the object to update using the `|=` operator\r\n\r\n[jq-play snippet](https://jqplay.org/s/Z4-MMkKRyG)",
                "title": "Modify value in the object containing a particular string using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1589811344,
                "last_edit_date": 1589811344,
                "creation_date": 1589811213,
                "answer_id": 61871593,
                "question_id": 61870396,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Position `|=` earlier to retain the original structure.\r\n```\r\n.templating.list[] |= (select(.name == &quot;env&quot;) .regex = &quot;*&quot;)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/EcYC0-_7X6)&lt;/sup&gt;",
                "title": "Modify value in the object containing a particular string using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1589871821,
        "creation_date": 1589807611,
        "last_edit_date": 1589871821,
        "question_id": 61870396,
        "body_markdown": "I am trying to modify a large json file (a Grafana dashboard), replacing a single value, then output the whole file with the change. How can I do this?\r\n\r\nYou can see the value I want to edit here. The actual file is quite large, so there are many other top-level values, but I only need to edit a specific item under the &quot;templating&quot; block.\r\n```\r\n&quot;templating&quot;: {\r\n    &quot;list&quot;: [\r\n      {\r\n        &quot;allValue&quot;: &quot;.*&quot;,\r\n        &quot;current&quot;: {},\r\n        &quot;datasource&quot;: &quot;$Source&quot;,\r\n        &quot;hide&quot;: 0,\r\n        &quot;includeAll&quot;: false,\r\n        &quot;label&quot;: null,\r\n        &quot;multi&quot;: true,\r\n        &quot;name&quot;: &quot;node&quot;,\r\n        &quot;options&quot;: [],\r\n        &quot;query&quot;: &quot;label_values(node_boot_time{env=~\\&quot;$env\\&quot;}, instance)&quot;,\r\n        &quot;refresh&quot;: 1,\r\n        &quot;regex&quot;: &quot;&quot;,\r\n        &quot;sort&quot;: 0,\r\n        &quot;tagValuesQuery&quot;: &quot;&quot;,\r\n        &quot;tags&quot;: [],\r\n        &quot;tagsQuery&quot;: &quot;&quot;,\r\n        &quot;type&quot;: &quot;query&quot;,\r\n        &quot;useTags&quot;: false\r\n      },\r\n      {\r\n        &quot;allValue&quot;: null,\r\n        &quot;current&quot;: {\r\n          &quot;tags&quot;: [],\r\n          &quot;text&quot;: &quot;&quot;,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        &quot;datasource&quot;: &quot;$Source&quot;,\r\n        &quot;definition&quot;: &quot;label_values(env)&quot;,\r\n        &quot;hide&quot;: 0,\r\n        &quot;includeAll&quot;: true,\r\n        &quot;label&quot;: &quot;env&quot;,\r\n        &quot;multi&quot;: false,\r\n        &quot;name&quot;: &quot;env&quot;,\r\n        &quot;options&quot;: [],\r\n        &quot;query&quot;: &quot;label_values(env)&quot;,\r\n        &quot;refresh&quot;: 1,\r\n        &quot;regex&quot;: &quot;&quot;,\r\n        &quot;skipUrlSync&quot;: false,\r\n        &quot;sort&quot;: 1,\r\n        &quot;tagValuesQuery&quot;: &quot;&quot;,\r\n        &quot;tags&quot;: [],\r\n        &quot;tagsQuery&quot;: &quot;&quot;,\r\n        &quot;type&quot;: &quot;query&quot;,\r\n        &quot;useTags&quot;: false\r\n      },\r\n      {\r\n        &quot;current&quot;: {\r\n          &quot;tags&quot;: [],\r\n          &quot;text&quot;: &quot;&quot;,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        &quot;hide&quot;: 0,\r\n        &quot;includeAll&quot;: false,\r\n        &quot;label&quot;: null,\r\n        &quot;multi&quot;: false,\r\n        &quot;name&quot;: &quot;Source&quot;,\r\n        &quot;options&quot;: [],\r\n        &quot;query&quot;: &quot;prometheus&quot;,\r\n        &quot;refresh&quot;: 1,\r\n        &quot;regex&quot;: &quot;&quot;,\r\n        &quot;skipUrlSync&quot;: false,\r\n        &quot;type&quot;: &quot;datasource&quot;\r\n      }\r\n    ]\r\n  },\r\n```\r\n\r\nThe piece I need to change is the block containing `&quot;query&quot;: &quot;label_values(env)&quot;,` and I just need to change the value of `&quot;regex&quot;: &quot;&quot;,`\r\n\r\n\r\nI have tried:\r\n\r\n```\r\njq &#39;.templating.list[] | select(.name == &quot;env&quot;) |= . + {regex:&quot;*&quot;}&#39; &quot;dashboard.json&quot; &gt; test.json \r\n```\r\n\r\nThe problem is then it only prints the &quot;.list[]&quot; elements instead of the whole file. I need to be able to make this change for multiple other files that will have the same block, but not necessarily in the same place so I can&#39;t just select by index number.\r\n\r\nOutput of above script:\r\n\r\n```\r\n{\r\n  &quot;allValue&quot;: &quot;.*&quot;,\r\n  &quot;current&quot;: {},\r\n  &quot;datasource&quot;: &quot;$Source&quot;,\r\n  &quot;hide&quot;: 0,\r\n  &quot;includeAll&quot;: false,\r\n  &quot;label&quot;: null,\r\n  &quot;multi&quot;: true,\r\n  &quot;name&quot;: &quot;node&quot;,\r\n  &quot;options&quot;: [],\r\n  &quot;query&quot;: &quot;label_values(node_boot_time{env=~\\&quot;$env\\&quot;}, instance)&quot;,\r\n  &quot;refresh&quot;: 1,\r\n  &quot;regex&quot;: &quot;&quot;,\r\n  &quot;sort&quot;: 0,\r\n  &quot;tagValuesQuery&quot;: &quot;&quot;,\r\n  &quot;tags&quot;: [],\r\n  &quot;tagsQuery&quot;: &quot;&quot;,\r\n  &quot;type&quot;: &quot;query&quot;,\r\n  &quot;useTags&quot;: false\r\n}\r\n{\r\n  &quot;allValue&quot;: null,\r\n  &quot;current&quot;: {\r\n    &quot;tags&quot;: [],\r\n    &quot;text&quot;: &quot;&quot;,\r\n    &quot;value&quot;: &quot;&quot;\r\n  },\r\n  &quot;datasource&quot;: &quot;$Source&quot;,\r\n  &quot;definition&quot;: &quot;label_values(env)&quot;,\r\n  &quot;hide&quot;: 0,\r\n  &quot;includeAll&quot;: true,\r\n  &quot;label&quot;: &quot;env&quot;,\r\n  &quot;multi&quot;: false,\r\n  &quot;name&quot;: &quot;env&quot;,\r\n  &quot;options&quot;: [],\r\n  &quot;query&quot;: &quot;label_values(env)&quot;,\r\n  &quot;refresh&quot;: 1,\r\n  &quot;regex&quot;: &quot;*&quot;,\r\n  &quot;skipUrlSync&quot;: false,\r\n  &quot;sort&quot;: 1,\r\n  &quot;tagValuesQuery&quot;: &quot;&quot;,\r\n  &quot;tags&quot;: [],\r\n  &quot;tagsQuery&quot;: &quot;&quot;,\r\n  &quot;type&quot;: &quot;query&quot;,\r\n  &quot;useTags&quot;: false\r\n}\r\n{\r\n  &quot;current&quot;: {\r\n    &quot;tags&quot;: [],\r\n    &quot;text&quot;: &quot;&quot;,\r\n    &quot;value&quot;: &quot;&quot;\r\n  },\r\n  &quot;hide&quot;: 0,\r\n  &quot;includeAll&quot;: false,\r\n  &quot;label&quot;: null,\r\n  &quot;multi&quot;: false,\r\n  &quot;name&quot;: &quot;Source&quot;,\r\n  &quot;options&quot;: [],\r\n  &quot;query&quot;: &quot;prometheus&quot;,\r\n  &quot;refresh&quot;: 1,\r\n  &quot;regex&quot;: &quot;&quot;,\r\n  &quot;skipUrlSync&quot;: false,\r\n  &quot;type&quot;: &quot;datasource&quot;\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61870396/modify-value-in-the-object-containing-a-particular-string-using-jq",
        "title": "Modify value in the object containing a particular string using jq"
    },
    {
        "tags": [
            "python-3.x",
            "python-requests",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1589941282,
                "creation_date": 1589941282,
                "answer_id": 61903994,
                "question_id": 61903763,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    dictionary = {&#39;last&#39;: 313.14, &#39;bidPrice&#39;: None, &#39;quoteTimestamp&#39;: &#39;2020-05-19T20:00:00+00:00&#39;, &#39;mid&#39;: None, &#39;open&#39;: 315.03, &#39;timestamp&#39;: &#39;2020-05-19T20:00:00+00:00&#39;, &#39;tngoLast&#39;: 313.14, &#39;lastSize&#39;: None, &#39;askSiz\\\r\n    e&#39;: None, &#39;ticker&#39;: &#39;AAPL&#39;, &#39;askPrice&#39;: None, &#39;low&#39;: 313.01, &#39;volume&#39;: 25189979, &#39;prevClose&#39;: 314.96, &#39;bidSize&#39;: None, &#39;lastSaleTimestamp&#39;: &#39;2020-05-19T20:00:00+00:00&#39;, &#39;high&#39;: 318.52}\r\n    \r\n    #print(dictionary[&#39;last&#39;])\r\n    for i in dictionary:\r\n        print(dictionary[&#39;last&#39;])\r\n        print(dictionary[&#39;bidPrice&#39;])\r\n        print(dictionary[&#39;quoteTimestamp&#39;])\r\n        print(dictionary[&#39;mid&#39;])\r\n        print(dictionary[&#39;open&#39;])\r\n        print(dictionary[&#39;timestamp&#39;])\r\n        print(dictionary[&#39;tngoLast&#39;])\r\n        print(dictionary[&#39;lastSize&#39;])\r\n        print(dictionary[&#39;askSize&#39;])\r\n        print(dictionary[&#39;ticker&#39;])\r\n        print(dictionary[&#39;askPrice&#39;])\r\n        print(dictionary[&#39;low&#39;])\r\n        print(dictionary[&#39;volume&#39;])\r\n        print(dictionary[&#39;prevClose&#39;])\r\n        print(dictionary[&#39;bidSize&#39;])\r\n        print(dictionary[&#39;lastSaleTimestamp&#39;])\r\n        print(dictionary[&#39;high&#39;])\r\n\r\n\r\n",
                "title": "python scrape using requests failing to be able to parse the json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1589941978,
                "creation_date": 1589941978,
                "answer_id": 61904095,
                "question_id": 61903763,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Got this answered at the nearby Inland Empire Python group tonight at:\r\n\r\nhttps://www.meetup.com/iepython/events/267124104/\r\n\r\nAt the suggestion of group member Netore, I altered to a for loop on the output dictionary and it worked perfectly:\r\n\r\n:\r\noutput = requestResponse.json()\r\n\r\nfor i in output:\r\n    print(i[&#39;last&#39;])\r\n:\r\n\r\nFun Python times.\r\n\r\nStuart\r\n\r\n",
                "title": "python scrape using requests failing to be able to parse the json"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1589941978,
        "creation_date": 1589939379,
        "question_id": 61903763,
        "body_markdown": "I have a python3 program which hits\tan API with an API Token Key but fails to get the data\r\n\r\nThe run:\r\n\r\n./mumble.py.exp\r\n\r\n    {&#39;last&#39;: 313.14, &#39;bidPrice&#39;: None, &#39;quoteTimestamp&#39;: &#39;2020-05-19T20:00:00+00:00&#39;, &#39;mid&#39;: None, &#39;open&#39;: 315.03, &#39;timestamp&#39;: &#39;2020-05-19T20:00:00+00:00&#39;, &#39;tngoLast&#39;: 313.14, &#39;lastSize&#39;: None, &#39;askSiz\\\r\n    e&#39;: None, &#39;ticker&#39;: &#39;AAPL&#39;, &#39;askPrice&#39;: None, &#39;low&#39;: 313.01, &#39;volume&#39;: 25189979, &#39;prevClose&#39;: 314.96, &#39;bidSize&#39;: None, &#39;lastSaleTimestamp&#39;: &#39;2020-05-19T20:00:00+00:00&#39;, &#39;high&#39;: 318.52}\r\n\r\nThe code:\r\n\r\n    ~/mumble$ cat mumble.py.exp\r\n\r\n    #!/usr/bin/python3\r\n\r\n    import requests\r\n    import json\r\n\r\n    headers = {\r\n        &#39;Content-Type&#39;: &#39;application/json&#39;\r\n    }\r\n\r\n    requestResponse = requests.get(&quot;https://api.foobar.com/iex/?tickers=aapl&amp;token=APITOKENKEY&quot;, headers=headers)\r\n\r\n    output = requestResponse.json()\r\n\r\n    print(output[0])\r\n\r\nAttempt to parse with jq:\r\n\r\n./mumble.py.exp | jq &quot;.&quot;\r\n\r\nparse error: Invalid numeric literal at line 1, column 8\r\n\r\nI&#39;d like to look at the\tlast field in the Python and not have to try to work it through jq but I don&#39;t know how to do it.\r\n\r\nAnyone know how?\r\n\r\nThanks.\r\n",
        "link": "https://stackoverflow.com/questions/61903763/python-scrape-using-requests-failing-to-be-able-to-parse-the-json",
        "title": "python scrape using requests failing to be able to parse the json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1589949934,
                "last_edit_date": 1589949934,
                "creation_date": 1589947075,
                "answer_id": 61904837,
                "question_id": 61904789,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This yields your expected output:\r\n```\r\n.[].fields[].id |= tonumber\r\n```\r\n`|=` takes the paths `.[].fields[].id` expands to and applies `tonumber` to their values.\r\n\r\n&lt;sup&gt;[demo at jqplay.org](https://jqplay.org/s/D8udQSEUKV)&lt;/sup&gt;",
                "title": "Convert string value contained in an array to number"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1589949934,
        "creation_date": 1589946715,
        "last_edit_date": 1589948379,
        "question_id": 61904789,
        "body_markdown": "With the following input example:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;orgid&quot;: &quot;1&quot;,\r\n    &quot;email&quot;: &quot;janedoe@aol.com&quot;,\r\n    &quot;first_name&quot;: &quot;Jane&quot;,\r\n    &quot;last_name&quot;: &quot;Doe&quot;,\r\n    &quot;phone&quot;: &quot;4045551212&quot;,\r\n    &quot;tags&quot;: [\r\n      &quot;tag1&quot;,\r\n      &quot;tag2&quot;\r\n    ],\r\n    &quot;fields&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;2&quot;,\r\n        &quot;value&quot;: &quot;IB4220&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;3&quot;,\r\n        &quot;value&quot;: &quot;1994-05-18&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;12&quot;,\r\n        &quot;value&quot;: &quot;CONSULTANT&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;13&quot;,\r\n        &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;6&quot;,\r\n        &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;7&quot;,\r\n        &quot;value&quot;: &quot;Babylon&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;8&quot;,\r\n        &quot;value&quot;: &quot;NY&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;9&quot;,\r\n        &quot;value&quot;: &quot;11702-1522&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;10&quot;,\r\n        &quot;value&quot;: &quot;US&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;11&quot;,\r\n        &quot;value&quot;: &quot;&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;5&quot;,\r\n        &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\nI am trying to convert the &quot;id&quot; field to a number using jq&#39;s &quot;tonumber&quot; function.\r\n\r\nHere is my jq filter I am working with to no avail...\r\n\r\n```\r\n.[] | {contacts:[.[] | {orgid: .[&quot;orgid&quot;],email: .[&quot;email&quot;],first_name: .[&quot;first_name&quot;],last_name: .[&quot;last_name&quot;],phone: .[&quot;phone&quot;],tags: .[&quot;tags&quot;],fields: [{id: .fields[].id|tonumber, value: .fields[].value}]}]}\r\n```\r\nIt converts the field to a number; but yields the following undesired result (the repetition of the record many times.) \r\n\r\n```\r\n{\r\n  &quot;contacts&quot;: [\r\n    {\r\n      &quot;orgid&quot;: &quot;1&quot;,\r\n      &quot;email&quot;: &quot;janedoe@aol.com&quot;,\r\n      &quot;first_name&quot;: &quot;Jane&quot;,\r\n      &quot;last_name&quot;: &quot;Doe&quot;,\r\n      &quot;phone&quot;: &quot;4045551212&quot;,\r\n      &quot;tags&quot;: [\r\n        &quot;tag1&quot;,\r\n        &quot;tag2&quot;\r\n      ],\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;value&quot;: &quot;IB4220&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;value&quot;: &quot;1994-05-18&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;value&quot;: &quot;CONSULTANT&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;value&quot;: &quot;Babylon&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;value&quot;: &quot;NY&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;value&quot;: &quot;11702-1522&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;value&quot;: &quot;US&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;value&quot;: &quot;IB4220&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;value&quot;: &quot;1994-05-18&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;value&quot;: &quot;CONSULTANT&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;value&quot;: &quot;Babylon&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;value&quot;: &quot;NY&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;value&quot;: &quot;11702-1522&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;value&quot;: &quot;US&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 12,\r\n          &quot;value&quot;: &quot;IB4220&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 12,\r\n          &quot;value&quot;: &quot;1994-05-18&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 12,\r\n          &quot;value&quot;: &quot;CONSULTANT&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 12,\r\n          &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 12,\r\n          &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 12,\r\n          &quot;value&quot;: &quot;Babylon&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 12,\r\n          &quot;value&quot;: &quot;NY&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 12,\r\n          &quot;value&quot;: &quot;11702-1522&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 12,\r\n          &quot;value&quot;: &quot;US&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 12,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 12,\r\n          &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 13,\r\n          &quot;value&quot;: &quot;IB4220&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 13,\r\n          &quot;value&quot;: &quot;1994-05-18&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 13,\r\n          &quot;value&quot;: &quot;CONSULTANT&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 13,\r\n          &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 13,\r\n          &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 13,\r\n          &quot;value&quot;: &quot;Babylon&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 13,\r\n          &quot;value&quot;: &quot;NY&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 13,\r\n          &quot;value&quot;: &quot;11702-1522&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 13,\r\n          &quot;value&quot;: &quot;US&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 13,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 13,\r\n          &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 6,\r\n          &quot;value&quot;: &quot;IB4220&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 6,\r\n          &quot;value&quot;: &quot;1994-05-18&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 6,\r\n          &quot;value&quot;: &quot;CONSULTANT&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 6,\r\n          &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 6,\r\n          &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 6,\r\n          &quot;value&quot;: &quot;Babylon&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 6,\r\n          &quot;value&quot;: &quot;NY&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 6,\r\n          &quot;value&quot;: &quot;11702-1522&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 6,\r\n          &quot;value&quot;: &quot;US&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 6,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 6,\r\n          &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 7,\r\n          &quot;value&quot;: &quot;IB4220&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 7,\r\n          &quot;value&quot;: &quot;1994-05-18&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 7,\r\n          &quot;value&quot;: &quot;CONSULTANT&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 7,\r\n          &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 7,\r\n          &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 7,\r\n          &quot;value&quot;: &quot;Babylon&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 7,\r\n          &quot;value&quot;: &quot;NY&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 7,\r\n          &quot;value&quot;: &quot;11702-1522&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 7,\r\n          &quot;value&quot;: &quot;US&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 7,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 7,\r\n          &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 8,\r\n          &quot;value&quot;: &quot;IB4220&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 8,\r\n          &quot;value&quot;: &quot;1994-05-18&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 8,\r\n          &quot;value&quot;: &quot;CONSULTANT&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 8,\r\n          &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 8,\r\n          &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 8,\r\n          &quot;value&quot;: &quot;Babylon&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 8,\r\n          &quot;value&quot;: &quot;NY&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 8,\r\n          &quot;value&quot;: &quot;11702-1522&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 8,\r\n          &quot;value&quot;: &quot;US&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 8,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 8,\r\n          &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 9,\r\n          &quot;value&quot;: &quot;IB4220&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 9,\r\n          &quot;value&quot;: &quot;1994-05-18&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 9,\r\n          &quot;value&quot;: &quot;CONSULTANT&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 9,\r\n          &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 9,\r\n          &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 9,\r\n          &quot;value&quot;: &quot;Babylon&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 9,\r\n          &quot;value&quot;: &quot;NY&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 9,\r\n          &quot;value&quot;: &quot;11702-1522&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 9,\r\n          &quot;value&quot;: &quot;US&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 9,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 9,\r\n          &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 10,\r\n          &quot;value&quot;: &quot;IB4220&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 10,\r\n          &quot;value&quot;: &quot;1994-05-18&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 10,\r\n          &quot;value&quot;: &quot;CONSULTANT&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 10,\r\n          &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 10,\r\n          &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 10,\r\n          &quot;value&quot;: &quot;Babylon&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 10,\r\n          &quot;value&quot;: &quot;NY&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 10,\r\n          &quot;value&quot;: &quot;11702-1522&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 10,\r\n          &quot;value&quot;: &quot;US&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 10,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 10,\r\n          &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 11,\r\n          &quot;value&quot;: &quot;IB4220&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 11,\r\n          &quot;value&quot;: &quot;1994-05-18&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 11,\r\n          &quot;value&quot;: &quot;CONSULTANT&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 11,\r\n          &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 11,\r\n          &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 11,\r\n          &quot;value&quot;: &quot;Babylon&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 11,\r\n          &quot;value&quot;: &quot;NY&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 11,\r\n          &quot;value&quot;: &quot;11702-1522&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 11,\r\n          &quot;value&quot;: &quot;US&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 11,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 11,\r\n          &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 5,\r\n          &quot;value&quot;: &quot;IB4220&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 5,\r\n          &quot;value&quot;: &quot;1994-05-18&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 5,\r\n          &quot;value&quot;: &quot;CONSULTANT&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 5,\r\n          &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 5,\r\n          &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 5,\r\n          &quot;value&quot;: &quot;Babylon&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 5,\r\n          &quot;value&quot;: &quot;NY&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 5,\r\n          &quot;value&quot;: &quot;11702-1522&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 5,\r\n          &quot;value&quot;: &quot;US&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 5,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 5,\r\n          &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nDesired result:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;orgid&quot;: &quot;1&quot;,\r\n    &quot;email&quot;: &quot;janedoe@aol.com&quot;,\r\n    &quot;first_name&quot;: &quot;Jane&quot;,\r\n    &quot;last_name&quot;: &quot;Doe&quot;,\r\n    &quot;phone&quot;: &quot;4045551212&quot;,\r\n    &quot;tags&quot;: [\r\n      &quot;tag1&quot;,\r\n      &quot;tag2&quot;\r\n    ],\r\n    &quot;fields&quot;: [\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;value&quot;: &quot;IB4220&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 3,\r\n        &quot;value&quot;: &quot;1994-05-18&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 12,\r\n        &quot;value&quot;: &quot;CONSULTANT&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 13,\r\n        &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 6,\r\n        &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 7,\r\n        &quot;value&quot;: &quot;Babylon&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 8,\r\n        &quot;value&quot;: &quot;NY&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 9,\r\n        &quot;value&quot;: &quot;11702-1522&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 10,\r\n        &quot;value&quot;: &quot;US&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 11,\r\n        &quot;value&quot;: &quot;&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 5,\r\n        &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/61904789/convert-string-value-contained-in-an-array-to-number",
        "title": "Convert string value contained in an array to number"
    },
    {
        "tags": [
            "json",
            "select",
            "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": 3,
                "creation_date": 1589983366,
                "post_id": 61906141,
                "comment_id": 109509263,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1589959682,
                "last_edit_date": 1589959682,
                "creation_date": 1589955697,
                "answer_id": 61906412,
                "question_id": 61906141,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For your given input data, put in an array, you could use `startswith()` function as below. Your input JSON as such isn&#39;t quite valid, the objects needs to be enclosed within the array `[..]` for `jq` to operate on it.\r\n\r\n    jq &#39;.[] | .b as $data | select(.a | startswith($data) ).a&#39;\r\n\r\n[jq playground](https://jqplay.org/s/yeFwP8HON4)\r\n\r\nOr if you want to put the result in a CSV format, do\r\n\r\n    jq --raw-output &#39;[.[] | .b as $data | select(.a | startswith($data) ).a] | @csv&#39;\r\n",
                "title": "JQ - how to select field with condition that the field&#39;s value starts with another field&#39;s value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1589984001,
        "creation_date": 1589954610,
        "last_edit_date": 1589984001,
        "question_id": 61906141,
        "body_markdown": "Suppose I have a list of json items. Each item contains field ```a``` and ```b```. I&#39;d love to get a list of values of field ```a``` such that field ```a```&#39;s value starts with field ```b```&#39;s value. For example, \r\n```\r\n{\r\n  &quot;a&quot;: &quot;1234&quot;,\r\n  &quot;b&quot;: &quot;123&quot;\r\n},\r\n{\r\n  &quot;a&quot;: &quot;1234&quot;,\r\n  &quot;b&quot;: &quot;12&quot;\r\n},\r\n{\r\n  &quot;a&quot;: &quot;foo&quot;,\r\n  &quot;b&quot;: &quot;bar&quot;\r\n}\r\n```\r\nwould result in \r\n```\r\n&quot;1234&quot;,\r\n&quot;1234&quot;\r\n```\r\n\r\nIs this achievable using jq?",
        "link": "https://stackoverflow.com/questions/61906141/jq-how-to-select-field-with-condition-that-the-fields-value-starts-with-anoth",
        "title": "JQ - how to select field with condition that the field&#39;s value starts with another field&#39;s value"
    },
    {
        "tags": [
            "jq",
            "packer"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1589969983,
                "post_id": 61910590,
                "comment_id": 109501508,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1590059657,
                "creation_date": 1590059657,
                "answer_id": 61933239,
                "question_id": 61910590,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thank you for the help, \r\n\r\nIn order to make it valid json, i had to add this attribute to my packer template.json:\r\n\r\n```\r\n &quot;post-processors&quot;: [\r\n        {\r\n            &quot;type&quot;: &quot;manifest&quot;,\r\n            &quot;output&quot;: &quot;manifest.json&quot;,\r\n            &quot;strip_path&quot;: true,\r\n            &quot;strip_time&quot;: true\r\n```\r\n\r\n&quot;strip_time&quot;: &quot;true&quot;",
                "title": "packer creating manifest.json is not valid json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1590059657,
        "creation_date": 1589969823,
        "question_id": 61910590,
        "body_markdown": "\r\nI am using packer to create a base ami and using a post proccessor to create a manifest.json file\r\n\r\nhow can i make this json valid\r\n\r\n```\r\n{\r\n  &quot;builds&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;amazon-ebs&quot;,\r\n      &quot;builder_type&quot;: &quot;amazon-ebs&quot;,\r\n      &quot;build_time&quot;: 1589466697,\r\n      &quot;files&quot;: null,\r\n      &quot;artifact_id&quot;: &quot;eu-west-1:ami-04d3331ac647e751b&quot;,\r\n      &quot;packer_run_uuid&quot;: &quot;add4c072-7ac2-f5e9-b941-6b80003c03ec&quot;,\r\n      &quot;custom_data&quot;: {\r\n        &quot;my_custom_data&quot;: &quot;example&quot;\r\n      }\r\n    }\r\n  ],\r\n  &quot;last_run_uuid&quot;: &quot;add4c072-7ac2-f5e9-b941-6b80003c03ec&quot;\r\n  2020-05-14T14:31:37.246153577Z stdout P }\r\n```\r\n\r\n```\r\nError: Parse error on line 13:\r\n...b941-6b80003c03ec&quot;\t2020 - 05 - 14 T14: \r\n----------------------^\r\nExpecting &#39;EOF&#39;, &#39;}&#39;, &#39;:&#39;, &#39;,&#39;, &#39;]&#39;, got &#39;NUMBER&#39;\r\n\r\nMy eventual goal is to save the artifact_id to a var using bash\r\n",
        "link": "https://stackoverflow.com/questions/61910590/packer-creating-manifest-json-is-not-valid-json",
        "title": "packer creating manifest.json is not valid json"
    },
    {
        "tags": [
            "json",
            "jq",
            "reformat"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1590034927,
                "last_edit_date": 1590034927,
                "creation_date": 1589994039,
                "answer_id": 61918734,
                "question_id": 61918080,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Select *blocks* whose `hex` matches one of the specific values and update `aircraft` to leave only those.\r\n```\r\n.aircraft |= map(select(.hex | IN(&quot;44b5b4&quot;, &quot;00901a&quot;)))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/TVRZW2Of_P)&lt;/sup&gt;",
                "title": "How to reformat specific data from json with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1590003322,
                "last_edit_date": 1590003322,
                "creation_date": 1589994047,
                "answer_id": 61918737,
                "question_id": 61918080,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do a `select()` on the array `aircraft`, matching only the required hex values. The `map()` function takes input the entire array and the result of the select operation i.e. filtering of objects based on the `.hex` value is updated back `|=` to the original array and the rest of the fields are kept intact.\r\n\r\n    jq &#39;.aircraft |= map(select(.hex == &quot;44b5b4&quot; or .hex == &quot;00901a&quot;))&#39; json",
                "title": "How to reformat specific data from json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1590034927,
        "creation_date": 1589991975,
        "question_id": 61918080,
        "body_markdown": "I&#39;m new to json and want to extract data (blocks) from a specific json. I&#39;ve tried to find information on how to do this with jq but so far I cannot seem to get what I want.\r\n\r\nMy json:\r\n```\r\n{\r\n   &quot;now&quot; : 1589987097.9,\r\n   &quot;aircraft&quot; : [\r\n      {\r\n         &quot;mlat&quot; : [],\r\n         &quot;rssi&quot; : -26.2,\r\n         &quot;track&quot; : 319,\r\n         &quot;speed&quot; : 354,\r\n         &quot;messages&quot; : 16,\r\n         &quot;seen&quot; : 0.7,\r\n         &quot;altitude&quot; : 38000,\r\n         &quot;vert_rate&quot; : 0,\r\n         &quot;hex&quot; : &quot;44b5b4&quot;,\r\n         &quot;tisb&quot; : []\r\n      },\r\n      {\r\n         &quot;squawk&quot; : &quot;6220&quot;,\r\n         &quot;altitude&quot; : 675,\r\n         &quot;seen&quot; : 1.1,\r\n         &quot;messages&quot; : 7220,\r\n         &quot;tisb&quot; : [],\r\n         &quot;hex&quot; : &quot;484a95&quot;,\r\n         &quot;mlat&quot; : [],\r\n         &quot;rssi&quot; : -22\r\n      },\r\n      {\r\n         &quot;hex&quot; : &quot;484846&quot;,\r\n         &quot;tisb&quot; : [],\r\n         &quot;messages&quot; : 20,\r\n         &quot;speed&quot; : 89,\r\n         &quot;seen&quot; : 0.4,\r\n         &quot;squawk&quot; : &quot;7000&quot;,\r\n         &quot;altitude&quot; : 500,\r\n         &quot;rssi&quot; : -23.7,\r\n         &quot;track&quot; : 185,\r\n         &quot;mlat&quot; : []\r\n      },\r\n      {\r\n         &quot;category&quot; : &quot;B1&quot;,\r\n         &quot;mlat&quot; : [],\r\n         &quot;rssi&quot; : -24.3,\r\n         &quot;flight&quot; : &quot;ZSGBX   &quot;,\r\n         &quot;altitude&quot; : 3050,\r\n         &quot;squawk&quot; : &quot;7000&quot;,\r\n         &quot;seen&quot; : 16.8,\r\n         &quot;messages&quot; : 37,\r\n         &quot;tisb&quot; : [],\r\n         &quot;hex&quot; : &quot;00901a&quot;\r\n      }\r\n ],\r\n   &quot;messages&quot; : 35857757\r\n} \r\n```\r\n\r\nI would like to reformat this json to *only* include &#39;blocks&#39; that contain specific hex values.\r\n\r\nSo for example, I want I would like my output to contain 44b5b4 and 00901a:\r\n\r\n```\r\n\r\n{\r\n   &quot;now&quot; : 1589987097.9,\r\n   &quot;aircraft&quot; : [\r\n      {\r\n         &quot;mlat&quot; : [],\r\n         &quot;rssi&quot; : -26.2,\r\n         &quot;track&quot; : 319,\r\n         &quot;speed&quot; : 354,\r\n         &quot;messages&quot; : 16,\r\n         &quot;seen&quot; : 0.7,\r\n         &quot;altitude&quot; : 38000,\r\n         &quot;vert_rate&quot; : 0,\r\n         &quot;hex&quot; : &quot;44b5b4&quot;,\r\n         &quot;tisb&quot; : []\r\n      },\r\n      {\r\n         &quot;category&quot; : &quot;B1&quot;,\r\n         &quot;mlat&quot; : [],\r\n         &quot;rssi&quot; : -24.3,\r\n         &quot;flight&quot; : &quot;ZSGBX   &quot;,\r\n         &quot;altitude&quot; : 3050,\r\n         &quot;squawk&quot; : &quot;7000&quot;,\r\n         &quot;seen&quot; : 16.8,\r\n         &quot;messages&quot; : 37,\r\n         &quot;tisb&quot; : [],\r\n         &quot;hex&quot; : &quot;00901a&quot;\r\n      }\r\n ],\r\n   &quot;messages&quot; : 35857757\r\n}\r\n\r\n```\r\n\r\nCan someone tell me how to remove all items not having those 2 hex identifiers but still keep the same json structure?\r\n\r\nThanks a lot!",
        "link": "https://stackoverflow.com/questions/61918080/how-to-reformat-specific-data-from-json-with-jq",
        "title": "How to reformat specific data from json with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1590067188,
                "post_id": 61934978,
                "comment_id": 109543542,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4278622,
                    "reputation": 2048,
                    "user_id": 3498667,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/07ce1e123a816ed08504262882b29504?s=256&d=identicon&r=PG",
                    "display_name": "Neekobus",
                    "link": "https://stackoverflow.com/users/3498667/neekobus"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1590486806,
                "post_id": 61934978,
                "comment_id": 109690539,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1690815097,
                "last_edit_date": 1690815097,
                "creation_date": 1590065972,
                "answer_id": 61935069,
                "question_id": 61934978,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ok I&#39;ve just find out in a single call :\r\n\r\n    cat my.json | jq &#39;.a|keys&#39; \r\n    a1, a2\r\n\r\nOr even as @Inian suggested without the `cat`\r\n\r\n    jq &#39;.a|keys&#39; my.json \r\n    a1, a2\r\n\r\n",
                "title": "Listing all keys of a nested object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1690815097,
        "creation_date": 1590065639,
        "last_edit_date": 1690815080,
        "question_id": 61934978,
        "body_markdown": "I want to list the keys of a nested object of my document. \r\nFor example, I want the keys in the `&quot;a&quot;` object: `&quot;a1&quot;, &quot;a2&quot;`\r\n\r\nThe sample document:\r\n\r\n```json\r\n{\r\n    &quot;a&quot;: {\r\n        &quot;a1&quot;: &quot;hello&quot;,\r\n        &quot;a2&quot;: &quot;world&quot;\r\n    },\r\n\r\n    &quot;b&quot;: {\r\n        &quot;b1&quot;: &quot;bonjour&quot;,\r\n        &quot;b2&quot;: &quot;monde&quot;\r\n    }\r\n}\r\n```\r\n\r\nI know I can use `keys`, but it seems to work only for the first level object: `cat my.json | jq keys` will output `a, b`.\r\n\r\nSo far I chain two calls with `jq` but I wonder if we can do it in one call ?\r\n\r\n`cat my.json | jq .a | jq keys` --&gt; `a1, a2`",
        "link": "https://stackoverflow.com/questions/61934978/listing-all-keys-of-a-nested-object-with-jq",
        "title": "Listing all keys of a nested object with jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1590068227,
                "post_id": 61935595,
                "comment_id": 109544170,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 252868,
                    "reputation": 3852,
                    "user_id": 531199,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/cf607469b78199cb8ff8d02724483bdf?s=256&d=identicon&r=PG",
                    "display_name": "SOUser",
                    "link": "https://stackoverflow.com/users/531199/souser"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1590068751,
                "post_id": 61935595,
                "comment_id": 109544423,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1590069002,
                "post_id": 61935595,
                "comment_id": 109544581,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 252868,
                    "reputation": 3852,
                    "user_id": 531199,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://www.gravatar.com/avatar/cf607469b78199cb8ff8d02724483bdf?s=256&d=identicon&r=PG",
                    "display_name": "SOUser",
                    "link": "https://stackoverflow.com/users/531199/souser"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1590119212,
                "post_id": 61935595,
                "comment_id": 109565361,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1590087043,
                "creation_date": 1590087043,
                "answer_id": 61941749,
                "question_id": 61935595,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s no need to invoke jq twice:\r\n\r\n```\r\n#!/bin/bash\r\nfunction data {\r\n    cat&lt;&lt;EOF\r\n[\r\n  { &quot;eq&quot;: &quot;$a=b^2&quot; },\r\n  { &quot;eq&quot;: &quot;$a=b**2&quot; }\r\n]\r\nEOF\r\n}\r\n\r\ndata | jq &#39;.[0].eq == .[0].eq&#39;\r\ndata | jq &#39;.[0].eq == .[1].eq&#39;\r\necho Using -e:\r\ndata | jq -e &#39;.[0].eq == .[0].eq&#39; &gt; /dev/null\r\necho $?\r\ndata | jq -e &#39;.[0].eq == .[1].eq&#39; &gt; /dev/null\r\necho $?\r\n```\r\nyields:\r\n```\r\ntrue\r\nfalse\r\nUsing -e:\r\n0\r\n1\r\n```",
                "title": "How to test equality of variables that contain dollar sign and possibly other symbols?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1590087043,
        "creation_date": 1590067606,
        "last_edit_date": 1590067944,
        "question_id": 61935595,
        "body_markdown": "mwe.json\r\n\r\n    [\r\n    { &quot;eq&quot;: &quot;$a=b^2&quot; },\r\n    { &quot;eq&quot;: &quot;$a=b**2&quot; }\r\n    ]\r\n\r\n\r\nmwe.sh\r\n\r\n    #!/bin/bash\r\n    \r\n    eq1=$( jq -r &#39;.[0].eq&#39; mwe.json )\r\n    eq2=$( jq -r &#39;.[1].eq&#39; mwe.json )\r\n    if [[ &quot;$eq1&quot; -eq &quot;$eq2&quot; ]]; then \r\n      echo &quot;same TeX equation&quot;\r\n    fi\r\n\r\nerror\r\n\r\n    $./mwe.sh\r\n    ./mwe.sh: line 5: [[: $a=b^2: syntax error: operand expected (error token is &quot;$a=b^2&quot;)\r\n\r\nmwe2.sh\r\n\r\n    #!/bin/bash\r\n    \r\n    eq1=$( jq -r &#39;.[0].eq&#39; mwe.json )\r\n    eq2=$( jq -r &#39;.[1].eq&#39; mwe.json )\r\n    if [[ &quot;&#39;&quot;&quot;$eq1&quot;&quot;&#39;&quot; -eq &quot;&#39;&quot;&quot;$eq2&quot;&quot;&#39;&quot; ]]; then \r\n      echo &quot;same equation&quot;\r\n    fi\r\n\r\nerror\r\n\r\n    $./mwe2.sh\r\n    ./mwe2.sh: line 5: [[: &#39;$a=b^2&#39;: syntax error: operand expected (error token is &quot;&#39;$a=b^2&#39;&quot;)\r\n\r\n\r\nCould you suggest how to compare the two variables that contain dollar sign and other special symbols ?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61935595/how-to-test-equality-of-variables-that-contain-dollar-sign-and-possibly-other-sy",
        "title": "How to test equality of variables that contain dollar sign and possibly other symbols?"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "terraform",
            "jq",
            "terraform-provider-aws"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1590082743,
                "post_id": 61940049,
                "comment_id": 109552766,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3153273,
                    "reputation": 1699,
                    "user_id": 4949938,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/QuDGR.jpg?s=256",
                    "display_name": "Sienna",
                    "link": "https://stackoverflow.com/users/4949938/sienna"
                },
                "reply_to_user": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1590083627,
                "post_id": 61940049,
                "comment_id": 109553225,
                "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": 1590086046,
                "post_id": 61940049,
                "comment_id": 109554392,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1590087713,
                "creation_date": 1590087713,
                "answer_id": 61941938,
                "question_id": 61940049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following script uses the .ip_prefix as the key, thus perhaps avoiding the need for the `sort|unique`.  It yields:\r\n```\r\n{\r\n  &quot;35.180.0.0/16&quot;: &quot;35.180.0.0/16&quot;,\r\n  &quot;52.94.76.0/22&quot;: &quot;52.94.76.0/22&quot;\r\n}\r\n```\r\n### Script\r\n```\r\n#!/bin/bash\r\n\r\nfunction data {\r\n    cat &lt;&lt;EOF\r\n{\r\n  &quot;syncToken&quot;: &quot;1589917992&quot;,\r\n  &quot;createDate&quot;: &quot;2020-05-19-19-53-12&quot;,\r\n  &quot;prefixes&quot;: [\r\n    {\r\n      &quot;ip_prefix&quot;: &quot;35.180.0.0/16&quot;,\r\n      &quot;region&quot;: &quot;eu-west-3&quot;,\r\n      &quot;service&quot;: &quot;AMAZON&quot;,\r\n      &quot;network_border_group&quot;: &quot;eu-west-3&quot;\r\n    },\r\n    {\r\n      &quot;ip_prefix&quot;: &quot;52.94.76.0/22&quot;,\r\n      &quot;region&quot;: &quot;us-west-2&quot;,\r\n      &quot;service&quot;: &quot;AMAZON&quot;,\r\n      &quot;network_border_group&quot;: &quot;us-west-2&quot;\r\n    }\r\n    ]\r\n}\r\nEOF\r\n}\r\n\r\ndata | jq &#39;\r\n  .prefixes \r\n  | map(select(.region | test(&quot;west&quot;))\r\n        | {(.ip_prefix): .ip_prefix} )\r\n  | add &#39;\r\n```",
                "title": "Convert an array of strings to a dictionary with JQ?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1590139896,
                "creation_date": 1590139896,
                "answer_id": 61951912,
                "question_id": 61940049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s a better option to get at the AWS IP ranges data in Terraform, which is to use the [`aws_ip_ranges` data source][1], instead of trying to mangle things with the `external` data source and `jq`.\r\n\r\nThe example in the above linked documentation shows a similar, but also slightly more complex, thing to what you&#39;re trying to do here:\r\n\r\n```hcl\r\ndata &quot;aws_ip_ranges&quot; &quot;european_ec2&quot; {\r\n  regions  = [&quot;eu-west-1&quot;, &quot;eu-central-1&quot;]\r\n  services = [&quot;ec2&quot;]\r\n}\r\n\r\nresource &quot;aws_security_group&quot; &quot;from_europe&quot; {\r\n  name = &quot;from_europe&quot;\r\n\r\n  ingress {\r\n    from_port        = &quot;443&quot;\r\n    to_port          = &quot;443&quot;\r\n    protocol         = &quot;tcp&quot;\r\n    cidr_blocks      = data.aws_ip_ranges.european_ec2.cidr_blocks\r\n    ipv6_cidr_blocks = data.aws_ip_ranges.european_ec2.ipv6_cidr_blocks\r\n  }\r\n\r\n  tags = {\r\n    CreateDate = data.aws_ip_ranges.european_ec2.create_date\r\n    SyncToken  = data.aws_ip_ranges.european_ec2.sync_token\r\n  }\r\n}\r\n```\r\n\r\nTo do your exact thing you would do something like this:\r\n\r\n```hcl\r\ndata &quot;aws_ip_ranges&quot; &quot;us_west_2_amazon&quot; {\r\n  regions  = [&quot;us_west_2&quot;]\r\n  services = [&quot;amazon&quot;]\r\n}\r\n\r\nresource &quot;aws_default_security_group&quot; &quot;allow-mysql&quot; {\r\n  vpc_id = aws_vpc.main.id\r\n\r\n  ingress {\r\n    description = &quot;MySQL&quot;\r\n    from_port   = 0\r\n    to_port     = 0\r\n    protocol    = &quot;-1&quot;\r\n    cidr_blocks = data.aws_ip_ranges.us_west_2_amazon.cidr_blocks\r\n  }\r\n}\r\n```\r\n\r\nHowever, there are 2 things that are bad here.\r\n\r\nThe first, and most important, is that you&#39;re allowing access to your database from every IP address that AWS has in US-West-2 across all services. That means that anyone in the world is able to spin up an EC2 instance or Lambda function in US-West-2 and then have network access to your database. This is a very bad idea.\r\n\r\nThe second is that if that returns more than 60 CIDR blocks you are going to end up with more than 60 rules in your security group. AWS security groups have a limit of 60 security group rules per IP address type (IPv4 vs IPv6) and per ingress/egress:\r\n\r\n&gt; You can have 60 inbound and 60 outbound rules per security group (making a total of 120 rules). This quota is enforced separately for IPv4 rules and IPv6 rules; for example, a security group can have 60 inbound rules for IPv4 traffic and 60 inbound rules for IPv6 traffic. A rule that references a security group or prefix list ID counts as one rule for IPv4 and one rule for IPv6.\r\n\r\nFrom https://docs.aws.amazon.com/vpc/latest/userguide/amazon-vpc-limits.html#vpc-limits-security-groups\r\n\r\nThis is technically a soft cap and you can ask AWS to raise this limit in exchange for reducing the amount of security groups that can be applied to a network interface to keep the maximum amount of security group rules at or below 1000 per network interface. It&#39;s probably not something you want to mess around with though.\r\n\r\n\r\n  [1]: https://www.terraform.io/docs/providers/aws/d/ip_ranges.html",
                "title": "Convert an array of strings to a dictionary with JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1590139914,
        "creation_date": 1590081308,
        "last_edit_date": 1590139914,
        "question_id": 61940049,
        "body_markdown": "I have trying to convert the AWS public IP ranges into a format that can be used with the Terraform `external` data provider so I can create a security group rule based off the AWS public CIDRs. The provider requires a single JSON object with this format:\r\n\r\n```json\r\n{&quot;string&quot;: &quot;string&quot;}\r\n```\r\n\r\n[Here](https://ip-ranges.amazonaws.com/ip-ranges.json) is a snippet of the public ranges JSON document:\r\n\r\n```json\r\n{\r\n  &quot;syncToken&quot;: &quot;1589917992&quot;,\r\n  &quot;createDate&quot;: &quot;2020-05-19-19-53-12&quot;,\r\n  &quot;prefixes&quot;: [\r\n    {\r\n      &quot;ip_prefix&quot;: &quot;35.180.0.0/16&quot;,\r\n      &quot;region&quot;: &quot;eu-west-3&quot;,\r\n      &quot;service&quot;: &quot;AMAZON&quot;,\r\n      &quot;network_border_group&quot;: &quot;eu-west-3&quot;\r\n    },\r\n    {\r\n      &quot;ip_prefix&quot;: &quot;52.94.76.0/22&quot;,\r\n      &quot;region&quot;: &quot;us-west-2&quot;,\r\n      &quot;service&quot;: &quot;AMAZON&quot;,\r\n      &quot;network_border_group&quot;: &quot;us-west-2&quot;\r\n    },\r\n    // ...\r\n]\r\n```\r\n\r\nI can successfully extract the ranges I care about with this, `[.prefixes[] | select(.region == &quot;us-west-2&quot;) | .ip_prefix] | sort | unique`, and it gives me this:\r\n\r\n```json\r\n[\r\n  &quot;100.20.0.0/14&quot;,\r\n  &quot;108.166.224.0/21&quot;,\r\n  &quot;108.166.240.0/21&quot;,\r\n  &quot;13.248.112.0/24&quot;,\r\n  ...\r\n]\r\n```\r\n\r\nI can&#39;t figure out how to convert this to an arbitrarily-keyed object with jq. In order to properly use the array object, I need to convert it to a dictionary, something like `{&quot;arbitrary-key&quot;: &quot;100.20.0.0/14&quot;}`, so that I can use it in Terraform like this:\r\n\r\n```hcl\r\ndata &quot;external&quot; &quot;amazon-ranges&quot; {\r\n  program = [\r\n    &quot;cat&quot;,\r\n    &quot;${path.cwd}/aws-ranges.json&quot;\r\n    ]\r\n}\r\n\r\nresource &quot;aws_default_security_group&quot; &quot;allow-mysql&quot; {\r\n  vpc_id = aws_vpc.main.id\r\n\r\n  ingress {\r\n    description = &quot;MySQL&quot;\r\n    from_port   = 0\r\n    to_port     = 0\r\n    protocol    = &quot;-1&quot;\r\n    cidr_blocks = [\r\n      values(data.external.amazon-ranges.result)\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nWhat is the most effective way to extract the the AWS public IP ranges document into a single object with arbitrary keys?",
        "link": "https://stackoverflow.com/questions/61940049/convert-an-array-of-strings-to-a-dictionary-with-jq",
        "title": "Convert an array of strings to a dictionary with JQ?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17626801,
                    "reputation": 35,
                    "user_id": 12791710,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mBmLMKKSvyWfCZUp5I3iRMHaoOWcEhd1X9maFW2dA=k-s256",
                    "display_name": "Txiki PerPar",
                    "link": "https://stackoverflow.com/users/12791710/txiki-perpar"
                },
                "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": 1590147971,
                "post_id": 61953604,
                "comment_id": 109576897,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17626801,
                    "reputation": 35,
                    "user_id": 12791710,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mBmLMKKSvyWfCZUp5I3iRMHaoOWcEhd1X9maFW2dA=k-s256",
                    "display_name": "Txiki PerPar",
                    "link": "https://stackoverflow.com/users/12791710/txiki-perpar"
                },
                "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": 1590148029,
                "post_id": 61953604,
                "comment_id": 109576921,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17626801,
                    "reputation": 35,
                    "user_id": 12791710,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mBmLMKKSvyWfCZUp5I3iRMHaoOWcEhd1X9maFW2dA=k-s256",
                    "display_name": "Txiki PerPar",
                    "link": "https://stackoverflow.com/users/12791710/txiki-perpar"
                },
                "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": 1590148120,
                "post_id": 61953604,
                "comment_id": 109576972,
                "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": 1590148182,
                "post_id": 61953604,
                "comment_id": 109577002,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1590148370,
                "last_edit_date": 1590148370,
                "creation_date": 1590148013,
                "answer_id": 61954308,
                "question_id": 61953604,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JQ has `group_by` as a builtin, use that and do `map(.cash) | add` to sum `cash` values for each group.\r\n```\r\ngroup_by(.name)[] | [.[0].name, (map(.cash) | add)] | @csv\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/CKeDDEj9va)&lt;/sup&gt;",
                "title": "group objects by a field and sum another, then produce a CSV report"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1590148417,
        "creation_date": 1590145606,
        "last_edit_date": 1590148417,
        "question_id": 61953604,
        "body_markdown": "How can I create a csv from this json? I have:\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;John&quot;,\r\n    &quot;cash&quot;: 5\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Anna&quot;,\r\n    &quot;cash&quot;: 4\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Anna&quot;,\r\n    &quot;cash&quot;: 3\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;John&quot;,\r\n    &quot;cash&quot;: 8\r\n  }\r\n]\r\n```\r\nI need group by name and sum the cash and send the result a .csv like:\r\n\r\n    John,13\r\n    Anna,7\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/61953604/group-objects-by-a-field-and-sum-another-then-produce-a-csv-report",
        "title": "group objects by a field and sum another, then produce a CSV report"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1590189321,
                "creation_date": 1590189321,
                "answer_id": 61965270,
                "question_id": 61964573,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given the JSON shown, you could add the following to your pipeline:\r\n```\r\njq -c &#39;map({(.name): (if .type == &quot;int&quot; then 1234567890 else &quot;xxxxxxxxxx&quot; end)})|add&#39;\r\n```\r\n\r\nWith that JSON, the output would be:\r\n\r\n    {&quot;id&quot;:1234567890,&quot;test_string&quot;:&quot;xxxxxxxxxx&quot;}\r\n\r\n\r\n\r\nHowever, it would be far better if you combined the three calls to jq into one.",
                "title": "How do I concatenate dummy values in JQ based on field value, and then CSV-aggregate these concatenations?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1590189321,
        "creation_date": 1590185079,
        "last_edit_date": 1590185509,
        "question_id": 61964573,
        "body_markdown": "In my bash script, when I run the following jq against my curl result:  \r\n```curl -u someKey:someSecret someURL 2&gt;/dev/null | jq -r &#39;.schema&#39; | jq -r -c &#39;.fields&#39;```\r\n\r\nI get back a JSON array as follows:  \r\n```[{&quot;name&quot;:&quot;id&quot;,&quot;type&quot;:&quot;int&quot;,&quot;doc&quot;:&quot;Documentation for the id field.&quot;},{&quot;name&quot;:&quot;test_string&quot;,&quot;type&quot;:&quot;string&quot;,&quot;doc&quot;:&quot;Documentation for the test_string field&quot;}]```\r\n\r\nMy goal is to do a call with jq applied to return the following (given the example above):  \r\n```{&quot;id&quot;:1234567890,&quot;test_string&quot;:&quot;xxxxxxxxxx&quot;}```  \r\n*NB: I am trying to automatically generate templated values that match the &quot;schema&quot; JSON shown above.*\r\n\r\nSo just to clarify, that is:\r\n\r\n - all array objects (there could be more than 2 shown above) returned in a single comma-delimited row\r\n\r\n - doc fields are ignored\r\n - the values for &quot;name&quot; (including their surrounding double-quotes) are concatenated with either:\r\n   * :1234567890   ...when the &quot;type&quot; for that object is &quot;int&quot;\r\n   * &quot;:xxxxxxxxxx&quot;   ...when the &quot;type&quot; for that object is &quot;string&quot;  \r\nNB: these will be the only types we ever get for now\r\n\r\n**Can someone show me how I can expand upon my initial jq to return this?**\r\n\r\nNB: I tried working down the following path but am failing beyond this...  \r\n```curl -u someKey:someSecret someURL 2&gt;/dev/null | jq -r &#39;.schema&#39; | jq -r -c &#39;.fields&#39; | &quot;\\(.name):xxxxxxxxxxx&quot;&#39;```\r\n\r\nIf it&#39;s not possible in pure JQ (my preference) I&#39;m also happy for a solution that mixes in a bit of sed/awk magic :)\r\n\r\nCheers,\r\n\r\nStan",
        "link": "https://stackoverflow.com/questions/61964573/how-do-i-concatenate-dummy-values-in-jq-based-on-field-value-and-then-csv-aggre",
        "title": "How do I concatenate dummy values in JQ based on field value, and then CSV-aggregate these concatenations?"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "jq",
            "pathname"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1590188641,
                "creation_date": 1590188641,
                "answer_id": 61965167,
                "question_id": 61964866,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq -nR &#39;\r\n      [inputs | capture(&quot;.*/(?&lt;dirname&gt;[^/]*)/[^/]+$&quot;) + { filname: .}]&#39;",
                "title": "Converting a list of files to json map"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1590190383,
        "creation_date": 1590186742,
        "last_edit_date": 1590190383,
        "question_id": 61964866,
        "body_markdown": "I&#39;ve been sturggling to figure out how to use `jq` to map a list of files to a given JSON structure.  I have the following list of files:\r\n\r\n```\r\n/tmp/jboss/ejb-jar_3_2.xsd\r\n/tmp/jboss/example.crt\r\n/tmp/jboss/example.key\r\n/tmp/jboss/incomingrunasidentityloginmodule.zip\r\n/tmp/jboss/jboss-eap-7.0.0.zip\r\n/tmp/jboss/jboss-eap-7.0.8-patch.zip\r\n/tmp/jboss/keystore.jks\r\n/tmp/jboss/logger-api.sh\r\n/tmp/jboss/mgmt-api-example.txt\r\n/tmp/jboss/wildfly-dist-10.1.0.Final.zip\r\n/tmp/jboss/wildfly-dist-7.1.0.GA-redhat-8.jar\r\n```\r\n\r\nthat I would like to convert to the following JSON structure, where the dirname is the final path in the directory structure.\r\n```\r\n[ \r\n  { dirname: &quot;jboss&quot;, filename: &quot;/tmp/jboss/ejb-jar_3_2.xsd&quot; },\r\n  { dirname: &quot;jboss&quot;, filename: &quot;/tmp/jboss/example.crt&quot; },\r\n...\r\n...\r\n]\r\n```\r\n\r\nI figure the regex I can use to extract the path is fairly simple: `.*/(.*)/` or something close to that.  However, I can&#39;t figure out how to structure the `jq` filter.  I figure it needs to be something like:\r\n\r\n```\r\ncat /tmp/files.txt | jq --raw-input &#39;. |  { dirname: .match(regex).capture[0], filename: .}&#39;\r\n```\r\nis as close as I&#39;ve gotten, but that has several issues.  1) I can&#39;&#39;t figure out how to use a regex for the dirname, and 2) this doesn&#39;t actually build the list of objects - it just generates multiple objects.\r\n\r\nIs there an easy `jq` filter that I can use for this?",
        "link": "https://stackoverflow.com/questions/61964866/converting-a-list-of-files-to-json-map",
        "title": "Converting a list of files to json map"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1590223799,
                "post_id": 61969556,
                "comment_id": 109603579,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17626801,
                    "reputation": 35,
                    "user_id": 12791710,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mBmLMKKSvyWfCZUp5I3iRMHaoOWcEhd1X9maFW2dA=k-s256",
                    "display_name": "Txiki PerPar",
                    "link": "https://stackoverflow.com/users/12791710/txiki-perpar"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1590254612,
                "post_id": 61969556,
                "comment_id": 109614539,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1590254839,
                "post_id": 61969556,
                "comment_id": 109614628,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1590225556,
                "creation_date": 1590225556,
                "answer_id": 61969885,
                "question_id": 61969556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is very similar to [your previous question](/questions/61953604/group-objects-by-a-field-and-sum-another-then-produce-a-csv-report). You just need to group by `Genre` after `Level`.\r\n```\r\n  group_by(.Level)[]\r\n| group_by(.Genre)[]\r\n| [.[0].Level, .[0].Genre, (map(.pupils) | add)]\r\n| @csv\r\n```",
                "title": "group by two fields and sum another for each group"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1590255621,
        "creation_date": 1590223685,
        "last_edit_date": 1590255621,
        "question_id": 61969556,
        "body_markdown": "I&#39;m interested doing a jq grouped columns by sum. \r\n\r\nI tried with arrays but I could&#39;t. I need to add pupils grouped by Level and Genre.\r\n\r\nMy json is like this:\r\n\r\n  \r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Maths&quot;,\r\n        &quot;Level&quot;: &quot;One&quot;,\r\n        &quot;Genre&quot;: &quot;Boys&quot;,\r\n        &quot;pupils&quot;: 5\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;English&quot;,\r\n        &quot;Level&quot;: &quot;Two&quot;,\r\n        &quot;Genre&quot;: &quot;Boys&quot;,\r\n        &quot;pupils&quot;: 3\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Maths&quot;,\r\n        &quot;Level&quot;: &quot;One&quot;,\r\n        &quot;Genre&quot;: &quot;Girls&quot;,\r\n        &quot;pupils&quot;: 7\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;English&quot;,\r\n        &quot;Level&quot;: &quot;One&quot;,\r\n        &quot;Genre&quot;: &quot;Girls&quot;,\r\n        &quot;pupils&quot;: 6\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Social&quot;,\r\n        &quot;Level&quot;: &quot;One&quot;,\r\n        &quot;Genre&quot;: &quot;Boys&quot;,\r\n        &quot;pupils&quot;: 4\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Social&quot;,\r\n        &quot;Level&quot;: &quot;Two&quot;,\r\n        &quot;Genre&quot;: &quot;Girls&quot;,\r\n        &quot;pupils&quot;: 0\r\n      }\r\n    ]\r\n\r\nAnd I need to convert to csv like:\r\n\r\n    One, Boys, 9\r\n    One, Girls, 13\r\n    Two, Boys, 3\r\n    Two, Girls, 0\r\n\r\nThanks a lot!",
        "link": "https://stackoverflow.com/questions/61969556/group-by-two-fields-and-sum-another-for-each-group",
        "title": "group by two fields and sum another for each group"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1590242290,
                "creation_date": 1590242290,
                "answer_id": 61973132,
                "question_id": 61972797,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To generate a report in CSV format you need to put column values into an array and pass it to `@csv` filter.\r\n```\r\n$ jq -r &#39;[.firstName] + (.Product[] | [.productId]) | @csv&#39; file\r\n&quot;Jam&quot;,&quot;5e09ad38986b7c30f339c5c0&quot;\r\n&quot;Jam&quot;,&quot;5e09407b986b7c30f339c18e&quot;\r\n&quot;Jam&quot;,&quot;5e094c2a986b7c30f339c1d2&quot;\r\n```",
                "title": "Generate CSV pairing a field and multiple array elements"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1590305838,
        "creation_date": 1590240694,
        "last_edit_date": 1590305838,
        "question_id": 61972797,
        "body_markdown": "Example input:\r\n```\r\n{\r\n  &quot;firstName&quot;: &quot;Jam&quot;,\r\n  &quot;Product&quot;: [\r\n    {\r\n      &quot;productId&quot;: &quot;5e09ad38986b7c30f339c5c0&quot;\r\n    },\r\n    {\r\n      &quot;productId&quot;: &quot;5e09407b986b7c30f339c18e&quot;\r\n    },\r\n    {\r\n      &quot;productId&quot;: &quot;5e094c2a986b7c30f339c1d2&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nExpected output:\r\n```\r\nJam,5e09ad38986b7c30f339c5c0\r\nJam,5e09407b986b7c30f339c18e\r\nJam,5e094c2a986b7c30f339c1d2\r\n```\r\n\r\nCurrent command is producing the output but on the same row comma seperated:\r\n```\r\njq -rc &#39;.firstName,.Product[0] .productId&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/61972797/generate-csv-pairing-a-field-and-multiple-array-elements",
        "title": "Generate CSV pairing a field and multiple array elements"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1590248484,
                "last_edit_date": 1592644375,
                "creation_date": 1590247935,
                "answer_id": 61974429,
                "question_id": 61974393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "No need for `sed`; it&#39;s easy to do in just `jq`:\n\n    $ jq &#39;{ productaname: .product_name }&#39; &lt;&lt;&lt;&#39;{ &quot;product_name&quot;:&quot;kl&quot; }&#39;\n    {&quot;productaname&quot;:&quot;kl&quot;}\n\nIf you want to replace underscores with a&#39;s in all keys of an object:\n\n    $ jq &#39;with_entries(.key |= gsub(&quot;_&quot;; &quot;a&quot;))&#39; &lt;&lt;&lt;&#39;{ &quot;product_name&quot;:&quot;kl&quot;, &quot;foo_bar&quot;:12 }&#39;\n    {&quot;productaname&quot;:&quot;kl&quot;,&quot;fooabar&quot;:12}\n\nFrom the documentation for `with_entries`:\n\n&gt; `to_entries, from_entries, with_entries`\n&gt;\n&gt;These functions convert between an object and an array of key-value pairs. If `to_entries` is passed an object, then for each k: v entry in the input, the output array includes `{&quot;key&quot;: k, &quot;value&quot;: v}`.\n&gt;\n&gt;`from_entries` does the opposite conversion, and `with_entries(foo)` is a shorthand for `to_entries | map(foo) | from_entries`, useful for doing some operation to all keys and values of an object. `from_entries` accepts key, Key, name, Name, value and Value as keys.\n",
                "title": "Use sed with jq in bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1590250132,
        "creation_date": 1590247761,
        "question_id": 61974393,
        "body_markdown": "How to use sed with jq to replace _ in key name with symbol a \r\n\r\n&gt; { &quot;product_name&quot;:&quot;kl&quot; }\r\n\r\nshould become \r\n\r\n &gt; { &quot;productaname&quot;:&quot;kl&quot; }\r\n\r\nin a bash script",
        "link": "https://stackoverflow.com/questions/61974393/use-sed-with-jq-in-bash-script",
        "title": "Use sed with jq in bash script"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1590316042,
                "last_edit_date": 1590316042,
                "creation_date": 1590312870,
                "answer_id": 61984055,
                "question_id": 61983958,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[JQ manual](https://stedolan.github.io/jq/manual/v1.6/#Update-assignment:|=) explains that behavior as follows:\r\n&gt; The left-hand side can be any general path expression; see [`path()`](https://stedolan.github.io/jq/manual/v1.6/?#path(path_expression), ).\r\n&gt;\r\n&gt; Note that **the left-hand side of `|=` refers to a value in `.`**. Thus `$var.foo |= . + 1` won&#39;t work as expected (`$var.foo` is not a valid or useful path expression in `.`); use `$var | .foo |= . + 1` instead.\r\n\r\nSince the underlying builtin ([`_modify`](https://github.com/stedolan/jq/blob/ccc79e592cfe1172db5f2def5a24c2f7cfd418bf/src/builtin.jq#L14)) is implemented using [`setpath`](https://stedolan.github.io/jq/manual/v1.6/?#setpath(PATHS;VALUE)), [`getpath`](https://stedolan.github.io/jq/manual/v1.6/?#getpath(PATHS)), and [`delpaths`](https://stedolan.github.io/jq/manual/v1.6/?#delpaths(PATHS)); the LHS of `|=` must be a valid path expression that can be represented as an array; in other words, `path(LHS)` must not fail. See below examples.\r\n```\r\n$ jq -n &#39;path(1)&#39;\r\njq: error (at &lt;unknown&gt;): Invalid path expression with result 1\r\n$ jq -n &#39;1 |= . + 1&#39;\r\njq: error (at &lt;unknown&gt;): Invalid path expression with result 1\r\n$ jq -n &#39;1 | path(.)&#39;\r\n[]\r\n$ jq -n &#39;1 | . |= . + 1&#39;\r\n2\r\n```",
                "title": "Identity operator needed in the middle of jq pipeline when using |= update-assignment"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1590316042,
        "creation_date": 1590312182,
        "question_id": 61983958,
        "body_markdown": "I was checking the jq tutorial at https://programminghistorian.org/en/lessons/json-and-jq\r\n\r\nIt makes some json reshaping, extracting some data from a json file, found at https://programminghistorian.org/assets/jq_twitter.json\r\n\r\nAt some point it makes a group_by, grouping data with the same user, extracting some user data and adding its corresponding tweet ids with the command\r\n\r\n``` \r\njq -s &#39;. | group_by(.user) | .[] | {user_id: .[0].user.id, user_name: .[0].user.screen_name, user_followers: .[0].user.followers_count, tweet_ids: [.[].id]}&#39; \r\n```\r\n\r\nso far, so good... the response looks like this (just a part is extracted):\r\n\r\n\r\n```\r\n{\r\n  &quot;user_id&quot;: 18270633,\r\n  &quot;user_name&quot;: &quot;ahhthatswhy&quot;,\r\n  &quot;user_followers&quot;: 559,\r\n  &quot;tweet_ids&quot;: [\r\n    501064204661850100\r\n  ]\r\n}\r\n{\r\n  &quot;user_id&quot;: 27202261,\r\n  &quot;user_name&quot;: &quot;Dushan41&quot;,\r\n  &quot;user_followers&quot;: 1201,\r\n  &quot;tweet_ids&quot;: [\r\n    619172281751711700,\r\n    619172321564098600\r\n  ]\r\n}\r\n{\r\n  &quot;user_id&quot;: 2500422674,\r\n  &quot;user_name&quot;: &quot;pecanEgba74318&quot;,\r\n  &quot;user_followers&quot;: 17,\r\n  &quot;tweet_ids&quot;: [\r\n    619172331592773600\r\n  ]\r\n}\r\n```\r\n\r\nBut then I would like to add a {&quot;multiple_tweets&quot;: true} to all the objects that have more than one tweet_ids.\r\n\r\nIf I plainly pipe, like this, it works fine:\r\n\r\n```\r\njq -s &#39;. | group_by(.user) | .[] | {user_id: .[0].user.id, user_name: .[0].user.screen_name, user_followers: .[0].user.followers_count, tweet_ids: [.[].id]} | (select(.tweet_ids | length &gt; 1) .multiple_tweets = true)&#39;\r\n```\r\n\r\na part of the result:\r\n\r\n```\r\n{\r\n  &quot;user_id&quot;: 1653718716,\r\n  &quot;user_name&quot;: &quot;OAnnie8&quot;,\r\n  &quot;user_followers&quot;: 315,\r\n  &quot;tweet_ids&quot;: [\r\n    501064215160172540\r\n  ]\r\n}\r\n{\r\n  &quot;user_id&quot;: 356854246,\r\n  &quot;user_name&quot;: &quot;DrJLMooreIII&quot;,\r\n  &quot;user_followers&quot;: 4888,\r\n  &quot;tweet_ids&quot;: [\r\n    501064202904404000,\r\n    501064231387947000\r\n  ],\r\n  &quot;multiple_tweets&quot;: true\r\n}\r\n{\r\n  &quot;user_id&quot;: 117155917,\r\n  &quot;user_name&quot;: &quot;rebekahwsm&quot;,\r\n  &quot;user_followers&quot;: 5069,\r\n  &quot;tweet_ids&quot;: [\r\n    501064233186893800\r\n  ]\r\n}\r\n```\r\n\r\nBut if (for whatever reason, in this example is not really needed, in fact I was doing it just to understand the update-assignment) I want to use the |= operator,\r\n\r\n```\r\njq -s &#39;. | group_by(.user) | .[] | {user_id: .[0].user.id, user_name: .[0].user.screen_name, user_followers: .[0].user.followers_count, tweet_ids: [.[].id]} |= (select(.tweet_ids | length &gt; 1) .multiple_tweets = true)&#39;\r\n```\r\nI get the error &#39; jq: error (at &lt;stdin&gt;:30259): Invalid path expression with result {&quot;user_id&quot;:1330235048,&quot;use... &#39;\r\n\r\n\r\nNow the thing that I really can&#39;t understand. If instead of using the operator |= directly, I pipe through the identity operator first, it works fine. \r\nWhat is the reason of this behaviour? Why does  |.|= behave differently than |=  ?\r\n\r\nWhy does this change anything? \r\n```\r\njq -s &#39;. | group_by(.user) | .[] | {user_id: .[0].user.id, user_name: .[0].user.screen_name, user_followers: .[0].user.followers_count, tweet_ids: [.[].id]} | . |= (select(.tweet_ids | length &gt; 1) .multiple_tweets = true)&#39;\r\n```\r\n\r\nI guess I&#39;m still not understanding how the |= operator really works.\r\n\r\nThank you for your help.",
        "link": "https://stackoverflow.com/questions/61983958/identity-operator-needed-in-the-middle-of-jq-pipeline-when-using-update-assig",
        "title": "Identity operator needed in the middle of jq pipeline when using |= update-assignment"
    },
    {
        "tags": [
            "kubernetes",
            "annotations",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1590346666,
                "post_id": 61989556,
                "comment_id": 109640466,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1590360464,
                "creation_date": 1590360464,
                "answer_id": 61993352,
                "question_id": 61989556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Starting with the original JSON and using jq&#39;s -r command-line option, the following jq filter yields the output shown below:\r\n\r\n```\r\n.[]\r\n| .metadata.annotations[]\r\n| (fromjson? // empty)\r\n| .[]\r\n| select(has(&quot;mac&quot;))\r\n| {mac}\r\n```\r\n\r\nOutput:\r\n```\r\n{&quot;mac&quot;:&quot;0a:2d:40:c6:f8:ea&quot;}\r\n{&quot;mac&quot;:&quot;0a:52:8a:62:5d:f4&quot;}\r\n{&quot;mac&quot;:&quot;0a:2d:40:c6:f8:ea&quot;}\r\n{&quot;mac&quot;:&quot;0a:52:8a:62:5d:f4&quot;}\r\n```",
                "title": "How to extract Kubernestes PODS mac addresses from annotations object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1590364592,
                "creation_date": 1590364592,
                "answer_id": 61993863,
                "question_id": 61989556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Please try the below command and should get the expected output.\r\n\r\n```\r\ncat abc.json | jq -r  &#39;.metadata.annotations.&quot;k8s.v1.cni.cncf.io/networks-status&quot; | fromjson | .[].mac &#39; \r\n```\r\n\r\nwhere `abc.json` is your son file.",
                "title": "How to extract Kubernestes PODS mac addresses from annotations object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1740186155,
                "creation_date": 1740186155,
                "answer_id": 79458919,
                "question_id": 61989556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I just had to solve a similar problem, the solutions above do the job, however I needed to be able to identify the pod. I&#39;m sharing the command used here:\r\n\r\n```\r\nkubectl get po -o json -A | jq -r &#39;.items[] | {name: .metadata.name, mac: (.metadata.annotations[&quot;k8s.v1.cni.cncf.io/network-status&quot;] // &quot;[]&quot; | fromjson | .[0].mac)}&#39;\r\n```\r\n(note the output includes the pod&#39;s name)",
                "title": "How to extract Kubernestes PODS mac addresses from annotations object"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1740186155,
        "creation_date": 1590340462,
        "question_id": 61989556,
        "body_markdown": "I am trying to extract the mac or ips addresses under metadata.annotations using either kubectl get po in json filter or using jq. other objects are easy to manipulate to get those values.\r\n\r\nkubectl get po -o json -n multus|jq -r .items\r\nUnder annotations, there is duplication CNI info but it is ok. I like to extract those MAC addresses using jq. it seems to be tricky on this one. \r\n\r\n```\r\n[\r\n  {\r\n    &quot;apiVersion&quot;: &quot;v1&quot;,\r\n    &quot;kind&quot;: &quot;Pod&quot;,\r\n    &quot;metadata&quot;: {\r\n      &quot;annotations&quot;: {\r\n        &quot;k8s.v1.cni.cncf.io/network-status&quot;: &quot;[{\\n    \\&quot;name\\&quot;: \\&quot;eps-cni\\&quot;,\\n    \\&quot;ips\\&quot;: [\\n        \\&quot;172.31.83.216\\&quot;\\n    ],\\n    \\&quot;default\\&quot;: true,\\n    \\&quot;dns\\&quot;: {}\\n},{\\n    \\&quot;name\\&quot;: \\&quot;ipvlan1-busybox1\\&quot;,\\n    \\&quot;interface\\&quot;: \\&quot;net1\\&quot;,\\n    \\&quot;ips\\&quot;: [\\n        \\&quot;172.31.230.70\\&quot;\\n    ],\\n    \\&quot;mac\\&quot;: \\&quot;0a:2d:40:c6:f8:ea\\&quot;,\\n    \\&quot;dns\\&quot;: {}\\n},{\\n    \\&quot;name\\&quot;: \\&quot;ipvlan2-busybox1\\&quot;,\\n    \\&quot;interface\\&quot;: \\&quot;net2\\&quot;,\\n    \\&quot;ips\\&quot;: [\\n        \\&quot;172.31.232.70\\&quot;\\n    ],\\n    \\&quot;mac\\&quot;: \\&quot;0a:52:8a:62:5d:f4\\&quot;,\\n    \\&quot;dns\\&quot;: {}\\n}]&quot;,\r\n        &quot;k8s.v1.cni.cncf.io/networks&quot;: &quot;ipvlan1-busybox1, ipvlan2-busybox1&quot;,\r\n        &quot;k8s.v1.cni.cncf.io/networks-status&quot;: &quot;[{\\n    \\&quot;name\\&quot;: \\&quot;eps-cni\\&quot;,\\n    \\&quot;ips\\&quot;: [\\n        \\&quot;172.31.83.216\\&quot;\\n    ],\\n    \\&quot;default\\&quot;: true,\\n    \\&quot;dns\\&quot;: {}\\n},{\\n    \\&quot;name\\&quot;: \\&quot;ipvlan1-busybox1\\&quot;,\\n    \\&quot;interface\\&quot;: \\&quot;net1\\&quot;,\\n    \\&quot;ips\\&quot;: [\\n        \\&quot;172.31.230.70\\&quot;\\n    ],\\n    \\&quot;mac\\&quot;: \\&quot;0a:2d:40:c6:f8:ea\\&quot;,\\n    \\&quot;dns\\&quot;: {}\\n},{\\n    \\&quot;name\\&quot;: \\&quot;ipvlan2-busybox1\\&quot;,\\n    \\&quot;interface\\&quot;: \\&quot;net2\\&quot;,\\n    \\&quot;ips\\&quot;: [\\n        \\&quot;172.31.232.70\\&quot;\\n    ],\\n    \\&quot;mac\\&quot;: \\&quot;0a:52:8a:62:5d:f4\\&quot;,\\n    \\&quot;dns\\&quot;: {}\\n}]&quot;,\r\n        &quot;kubernetes.io/psp&quot;: &quot;eps.privileged&quot;\r\n      },\r\n      &quot;creationTimestamp&quot;: &quot;2020-05-24T17:09:10Z&quot;,\r\n      &quot;generateName&quot;: &quot;busybox1-f476958bd-&quot;,\r\n      &quot;labels&quot;: {\r\n        &quot;app&quot;: &quot;busybox&quot;,\r\n        &quot;pod-template-hash&quot;: &quot;f476958bd&quot;\r\n      },\r\n      &quot;name&quot;: &quot;busybox1-f476958bd-hds4w&quot;,\r\n      &quot;namespace&quot;: &quot;multus&quot;,\r\n      &quot;ownerReferences&quot;: [\r\n        {\r\n          &quot;apiVersion&quot;: &quot;apps/v1&quot;,\r\n          &quot;blockOwnerDeletion&quot;: true,\r\n          &quot;controller&quot;: true,\r\n          &quot;kind&quot;: &quot;ReplicaSet&quot;,\r\n          &quot;name&quot;: &quot;busybox1-f476958bd&quot;,\r\n          &quot;uid&quot;: &quot;5daf9b52-e1b3-4df7-b5a1-028b48e7fcc0&quot;\r\n        }\r\n      ],\r\n      &quot;resourceVersion&quot;: &quot;965176&quot;,\r\n      &quot;selfLink&quot;: &quot;/api/v1/namespaces/multus/pods/busybox1-f476958bd-hds4w&quot;,\r\n      &quot;uid&quot;: &quot;0051b85d-9774-4f89-8658-f34065222bf0&quot;\r\n    },\r\n\r\n```\r\n\r\n**for basic jq,** \r\n```\r\n[root@ip-172-31-103-214 ~]# kubectl get po -o json -n multus|jq -r &#39;.items[] | .spec.volumes&#39;\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;test-busybox1-token-f6bdj&quot;,\r\n    &quot;secret&quot;: {\r\n      &quot;defaultMode&quot;: 420,\r\n      &quot;secretName&quot;: &quot;test-busybox1-token-f6bdj&quot;\r\n    }\r\n  }\r\n]\r\n```\r\nI can switch the get pod to yaml format then using normal grep cmd.\r\n```\r\nkubectl get po -o yaml  -n multus|egrep &#39;mac&#39;|sort -u\r\n&quot;mac&quot;: &quot;0a:2d:40:c6:f8:ea&quot;,\r\n&quot;mac&quot;: &quot;0a:52:8a:62:5d:f4&quot;,\r\n```\r\n\r\nThanks\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61989556/how-to-extract-kubernestes-pods-mac-addresses-from-annotations-object",
        "title": "How to extract Kubernestes PODS mac addresses from annotations object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1590387557,
                "last_edit_date": 1590387557,
                "creation_date": 1590386146,
                "answer_id": 61996576,
                "question_id": 61996457,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [`walk` builtin](https://stedolan.github.io/jq/manual/v1.6/?#walk(f)) for applying filters to values at arbitrary depths without changing the overall structure.\r\n```\r\nwalk(select(.Id? == 4) .Children += $a)\r\n```\r\n&lt;sup&gt;[demo at jqplay.org](https://jqplay.org/s/tjsiMN9BcD)&lt;/sup&gt;",
                "title": "how to add values to JSON array without full path?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1590387557,
        "creation_date": 1590385310,
        "last_edit_date": 1590386529,
        "question_id": 61996457,
        "body_markdown": "I have a problem with &#39;jq&#39; I could not solve after searching for a few hours. Let&#39;s take this simple JSON as an example with &quot;Category4&quot; nested within &quot;Category2&quot;:\r\n\r\n    {\r\n      &quot;categories&quot;: [\r\n        {\r\n          &quot;Id&quot;: 1,\r\n          &quot;Name&quot;: &quot;Category1&quot;,\r\n          &quot;Children&quot;: []\r\n        },\r\n        {\r\n          &quot;Id&quot;: 2,\r\n          &quot;Name&quot;: &quot;Category2&quot;,\r\n          &quot;Children&quot;: [\r\n            {\r\n              &quot;Id&quot;: 4,\r\n              &quot;Name&quot;: &quot;Category4&quot;,\r\n              &quot;Children&quot;: []\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;Id&quot;: 3,\r\n          &quot;Name&quot;: &quot;Category3&quot;,\r\n          &quot;Children&quot;: []\r\n        }\r\n      ]\r\n    }\r\n\r\nI would like to add a &quot;Category5&quot; child within the &quot;Category4&quot; object such as:\r\n\r\n    {\r\n      &quot;categories&quot;: [\r\n        {\r\n          &quot;Id&quot;: 1,\r\n          &quot;Name&quot;: &quot;Category1&quot;,\r\n          &quot;Children&quot;: []\r\n        },\r\n        {\r\n          &quot;Id&quot;: 2,\r\n          &quot;Name&quot;: &quot;Category2&quot;,\r\n          &quot;Children&quot;: [\r\n            {\r\n              &quot;Id&quot;: 4,\r\n              &quot;Name&quot;: &quot;Category4&quot;,\r\n              &quot;Children&quot;: [\r\n                {\r\n                  &quot;Id&quot;: 5,\r\n                  &quot;Name&quot;: &quot;Category5&quot;,\r\n                  &quot;Children&quot;: []\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;Id&quot;: 3,\r\n          &quot;Name&quot;: &quot;Category3&quot;,\r\n          &quot;Children&quot;: []\r\n        }\r\n      ]\r\n    }\r\n\r\nI can do it by using the full path of the &quot;Category4&quot; object with:\r\n\r\n    jq --argjson a &#39;[{&quot;Id&quot;:5,&quot;Name&quot;:&quot;Category5&quot;,&quot;Children&quot;:[]}]&#39; &#39;.categories[1].Children[0].Children += $a&#39; &quot;myfile.json&quot;\r\n\r\n\r\nBut how can I achieve the same result if I don&#39;t know the position of &quot;Category4&quot; (which could be at root level or nested deep inside other objects)? This command was my best guess:\r\n\r\n    jq --argjson a &#39;[{&quot;Id&quot;:5,&quot;Name&quot;:&quot;Category5&quot;,&quot;Children&quot;:[]}]&#39; &#39;.. | select(.Id?==4) | .Children += $a&#39; &quot;myfile&quot;\r\n\r\nbut it only retrieves &quot;Category4&quot; and &quot;Category5&quot; objects (Category1, 2 and 3 are missing from the output). I feel like I am missing something stupid...\r\n\r\nThanks for any help!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/61996457/how-to-add-values-to-json-array-without-full-path",
        "title": "how to add values to JSON array without full path?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1590426087,
                "last_edit_date": 1590426087,
                "creation_date": 1590425662,
                "answer_id": 62007085,
                "question_id": 62006972,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Put them into an array and pair that with `Devices` key in an object.\r\n```\r\n$ jq &#39;{Devices:[.Results[].Attributes.rhasspyName]}&#39; file\r\n{\r\n  &quot;Devices&quot;: [\r\n    &quot;TV&quot;,\r\n    &quot;radio&quot;,\r\n    &quot;pc&quot;\r\n  ]\r\n}\r\n```\r\nTo create a new file with that JSON value, redirect JQ&#39;s stdout to a file, like:\r\n```\r\njq &#39;{Devices:[.Results[].Attributes.rhasspyName]}&#39; file &gt; newfile\r\n```",
                "title": "Create new JSON value out of strings extracted from another"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1590426087,
        "creation_date": 1590425244,
        "last_edit_date": 1590425834,
        "question_id": 62006972,
        "body_markdown": "I have a json file with the following input\r\n\r\n```\r\n{\r\n  &quot;Arg&quot;:&quot;room=Rhasspy rhasspyName&quot;,\r\n  &quot;Results&quot;: [\r\n  {\r\n    &quot;Name&quot;:&quot;TV&quot;,\r\n    &quot;Internals&quot;: { },\r\n    &quot;Readings&quot;: { },\r\n    &quot;Attributes&quot;: {      &quot;rhasspyName&quot;: &quot;TV&quot; }\r\n  },\r\n  {\r\n    &quot;Name&quot;:&quot;dyTest01&quot;,\r\n    &quot;Internals&quot;: { },\r\n    &quot;Readings&quot;: { },\r\n    &quot;Attributes&quot;: {      &quot;rhasspyName&quot;: &quot;radio&quot; }\r\n  },\r\n  {\r\n    &quot;Name&quot;:&quot;enoAcPC01&quot;,\r\n    &quot;Internals&quot;: { },\r\n    &quot;Readings&quot;: { },\r\n    &quot;Attributes&quot;: {      &quot;rhasspyName&quot;: &quot;pc&quot; }\r\n  }  ],\r\n  &quot;totalResultsReturned&quot;:3\r\n}\r\n```\r\n\r\nWith ```jq &#39;.Results | .[] | .[&quot;Attributes&quot;] | .rhasspyName&#39; -r``` I can get a list like\r\n```\r\nTV\r\nradio\r\npc\r\n```\r\n\r\nHow can I take this input and create a new json looking like\r\n\r\n```{&quot;Devices&quot;:[&quot;TV&quot;,&quot;radio&quot;,&quot;pc&quot;]}```",
        "link": "https://stackoverflow.com/questions/62006972/create-new-json-value-out-of-strings-extracted-from-another",
        "title": "Create new JSON value out of strings extracted from another"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1590430198,
                "last_edit_date": 1590430198,
                "creation_date": 1590429576,
                "answer_id": 62008066,
                "question_id": 62007673,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You almost had it, but the right filter should have been to use the `select()` function on the `.value.vendor_version` and pick out the key name \r\n\r\n    jq -r &#39;.vendors | to_entries[] | select(.value.vendor_version==&quot;LSGS-2002-RC&quot;).key&#39;\r\n\r\nAlso don&#39;t pass in dynamic strings to the function, use placeholders like variables \r\n\r\n    jq -r --arg vendor &quot;LSGS-2002-RC&quot; &#39;.vendors | to_entries[] | select(.value.vendor_version == $vendor).key&#39;\r\n\r\nAn alternate, _less_ readable version than `select()` would be to use `keys[]`\r\n\r\n    .vendors | keys[] as $k | if .[$k].vendor_version == &quot;LSGS-2002-RC&quot; then $k else empty end",
                "title": "Find out parent key when a certain child value is met with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1590430198,
        "creation_date": 1590428059,
        "last_edit_date": 1590428983,
        "question_id": 62007673,
        "body_markdown": "Here&#39;s the json:\r\n```\r\n{\r\n\t&quot;vendors&quot;: {\r\n\t\t&quot;vendor1&quot;: {\r\n\t\t\t&quot;vendor_version&quot;: &quot;LS TT1706-POL&quot;,\r\n\t\t\t&quot;vendor_name&quot;: &quot;toyota&quot;\r\n\t\t},\r\n\t\t&quot;vendor2&quot;: {\r\n\t\t\t&quot;vendor_version&quot;: &quot;LSGS-2002-RC&quot;,\r\n\t\t\t&quot;vendor_name&quot;: &quot;honda&quot;\r\n\t\t},\r\n\t\t&quot;vendor3&quot;: {\r\n\t\t\t&quot;vendor_version&quot;: &quot;LS1903&quot;,\r\n\t\t\t&quot;vendor_name&quot;: &quot;suzuki&quot;\r\n\t\t}\r\n\t}\r\n}\r\n```\r\nI basically need the jq expression to get &quot;vendor2&quot; when I am given LSGS-2002-RC. I&#39;ve tried using select, map, variables, and every combination thereof. \r\nhere is something that didnt work:\r\n\r\n`jq -r &#39;.vendors|to_entries[]|.value|select(.vendor_version==&quot;LSGS-2002-RC&quot;)&#39;`\r\n\r\nBasically I always end up with the keys vendor1, vendor2, etc... stripped\r\n\r\nI am a little stumped. Note that the json structure or values cannot be altered. Thanks",
        "link": "https://stackoverflow.com/questions/62007673/find-out-parent-key-when-a-certain-child-value-is-met-with-jq",
        "title": "Find out parent key when a certain child value is met with jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1052295,
                    "reputation": 676,
                    "user_id": 1055891,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/DFhaB.png?s=256",
                    "display_name": "shox",
                    "link": "https://stackoverflow.com/users/1055891/shox"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1590430900,
                "post_id": 62007725,
                "comment_id": 109671308,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1590432153,
                "last_edit_date": 1590432153,
                "creation_date": 1590429122,
                "answer_id": 62007959,
                "question_id": 62007725,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given your sample input what that program does is basically this:\r\n```\r\n.first_level.second_level |= (\r\n    delpaths([[0]]) # apple != pear\r\n  | delpaths([[1]]) # banana != pear\r\n  | delpaths([[2]]) # null != pear\r\n  | delpaths([[3]]) # null != pear\r\n)\r\n```\r\nSee how the underlying builtin for `|=` is implemented [here](https://github.com/stedolan/jq/blob/ccc79e592cfe1172db5f2def5a24c2f7cfd418bf/src/builtin.jq#L14); when the righthand side of `|=` applied to a path&#39;s value, if the result is `empty`, that path is deleted by means of `delpaths`. So the problem is clear, when `.[0]` (apple) is deleted, `.[1]` (pear) becomes `.[0]`; but `_modify` doesn&#39;t take that change into account as it takes the list of paths to be modified once at the beginning and doesn&#39;t update again, and continues with `.[1]` (banana).\r\n\r\nYou can use this instead:\r\n```\r\ndel(.first_level.second_level[] | select(.fruit != &quot;pear&quot;))\r\n```\r\nOr if you insist on a solution involving `|=`:\r\n```\r\n.first_level.second_level |= map(select(.fruit == &quot;pear&quot;))\r\n```\r\n",
                "title": "Select items in array based on a property value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1590487791,
        "creation_date": 1590428235,
        "last_edit_date": 1590487791,
        "question_id": 62007725,
        "body_markdown": "As a developper, when I use the following JQ command:\r\n\r\n&gt; .first_level.&quot;second_level&quot;[] |= select(.fruit == &quot;pear&quot;)\r\n\r\nAnd I apply it to this JSON:\r\n\r\n```JSON\r\n{\r\n  &quot;first_level&quot;: {\r\n    &quot;second_level&quot;: [\r\n      {\r\n        &quot;fruit&quot;: &quot;apple&quot;\r\n      },\r\n      {\r\n        &quot;fruit&quot;: &quot;pear&quot;\r\n      },\r\n      {\r\n        &quot;fruit&quot;: &quot;banana&quot;\r\n      },\r\n      {\r\n        &quot;fruit&quot;: &quot;donuts&quot;\r\n      }\r\n    ]\r\n  }\r\n\r\n}\r\n```\r\n\r\nThen I would like to have this output (only keep the items that have the property `fruit` equal to `pear`):\r\n```JSON\r\n{\r\n  &quot;first_level&quot;: {\r\n    &quot;second_level&quot;: [\r\n      {\r\n        &quot;fruit&quot;: &quot;pear&quot;\r\n      }\r\n    ]\r\n  }\r\n\r\n}\r\n```\r\n\r\nBut the current value that is returned is (can also be seen in JQ Play [here](https://jqplay.org/s/78zotLbF0y)):\r\n```JSON\r\n{\r\n  &quot;first_level&quot;: {\r\n    &quot;second_level&quot;: [\r\n      {\r\n        &quot;fruit&quot;: &quot;pear&quot;\r\n      },\r\n      {\r\n        &quot;fruit&quot;: &quot;donuts&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n--&gt; It keeps the value with `donuts` and what I don&#39;t understand is that from the JQ documentation, the `|=` should assign the value of the selection but when running:\r\n\r\n&gt; .first_level.&quot;second_level&quot;[] | select(.fruit == &quot;pear&quot;)\r\n\r\nI&#39;ve the following result:\r\n\r\n```JSON\r\n{\r\n  &quot;fruit&quot;: &quot;pear&quot;\r\n}\r\n```\r\n\r\n--&gt; It seems to select succesfully but the affectation doesn&#39;t behave as I expect (it adds the `donuts`).\r\n\r\nAny help with this issue would be greatly appreciated. Thanks in advance! :)",
        "link": "https://stackoverflow.com/questions/62007725/select-items-in-array-based-on-a-property-value",
        "title": "Select items in array based on a property value"
    },
    {
        "tags": [
            "terraform",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1590456776,
                "last_edit_date": 1590456776,
                "creation_date": 1590453538,
                "answer_id": 62012871,
                "question_id": 62012671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I managed to find a working solution with terraform&#39;s `join` then manually append the port to the last IP, but will be happy to find a cleaner solution\r\n\r\nterraform snippet\r\n```\r\nformat(&quot;%s:%s&quot;, \r\n      join(\r\n         format(&quot;:%s,&quot;, port),\r\n         ips\r\n       ),\r\n      port)\r\n```",
                "title": "Join an array with a single element in terraform or jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1590460754,
                "creation_date": 1590460754,
                "answer_id": 62013769,
                "question_id": 62012671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the output format of jq is ok for you as well, then you can use this :\r\n\r\n    jq &#39;[ .ips[] + &quot;:&quot; + .port ]&#39; input\r\n    \r\n---\r\n\r\n    [\r\n      &quot;192.168.0.1:8080&quot;,\r\n      &quot;192.168.0.2:8080&quot;,\r\n      &quot;192.168.0.3:8080&quot;\r\n    ]\r\n\r\n`.ips[]` iterates over the ip array while keeping the root object as input, so that `.port` is available. Then the `... + &quot;:&quot; + .port` expression is applied to each element, producing a stream of transformed values.",
                "title": "Join an array with a single element in terraform or jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1590460754,
        "creation_date": 1590451875,
        "last_edit_date": 1590452053,
        "question_id": 62012671,
        "body_markdown": "I have the following json data which I get from `data &quot;external&quot;` in terraform\n\n```\n{\n  &quot;ips&quot;: [&quot;192.168.0.1&quot;,\n          &quot;192.168.0.2&quot;,\n          &quot;192.168.0.3&quot;],\n\n  &quot;port&quot;: &quot;8080&quot;\n}\n```\n\nI want to construct the target address in the format `ip:port`\n\nThe desired output as follows:\n```\n[&quot;192.168.0.1:8080&quot;,\n&quot;192.168.0.2:8080&quot;,\n&quot;192.168.0.3:8080&quot;]\n```\n\nI am trying to do this in `terraform` but I am fine with a solution that uses `jq`\n\nThe closest thing I could find is the string `join` function that takes a separator but it won&#39;t add the port to the last element",
        "link": "https://stackoverflow.com/questions/62012671/join-an-array-with-a-single-element-in-terraform-or-jq",
        "title": "Join an array with a single element in terraform or jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1590479830,
                "creation_date": 1590479830,
                "answer_id": 62017215,
                "question_id": 62017112,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Put new `key=value` pairs into an array, and add that array to the original one.\r\n```\r\n$ jq &#39;. + [&quot;EnvType=dev&quot;, &quot;KMSID=xxxxx-yyyyyy-ffffff&quot;]&#39; config.json\r\n[\r\n  &quot;ECSClusterName=cluster&quot;,\r\n  &quot;VPCID=vpc-xxxx&quot;,\r\n  &quot;ALBName=ALB&quot;,\r\n  &quot;EnvType=dev&quot;,\r\n  &quot;KMSID=xxxxx-yyyyyy-ffffff&quot;\r\n]\r\n```",
                "title": "Add new elements to JSON array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1590481037,
        "creation_date": 1590479496,
        "last_edit_date": 1590481037,
        "question_id": 62017112,
        "body_markdown": "I have a config file that is like\r\n\r\n    [\r\n      &quot;ECSClusterName=cluster&quot;,\r\n      &quot;VPCID=vpc-xxxx&quot;,\r\n      &quot;ALBName=ALB&quot;\r\n    ]\r\n  \r\nAnd with `jq` (or something else bash-native), I&#39;d like to add 2 values - `EnvType` and `KMSID` - (doesn&#39;t matter where in the config file) so that the end result would look like\r\n\r\n    [\r\n      &quot;EnvType=dev&quot;,\r\n      &quot;KMSID=xxxxx-yyyyyy-ffffff&quot;,\r\n      &quot;ECSClusterName=cluster&quot;,\r\n      &quot;VPCID=vpc-xxxx&quot;,\r\n      &quot;ALBName=ALB&quot;\r\n    ]\r\n\r\nThe closest I have been for one value is \r\n```\r\ncat config.json | jq &#39;.[-1] += &quot;, test=test&quot;&#39;\r\n```\r\n\r\nBut that outputs\r\n\r\n    [\r\n      &quot;ECSClusterName=cluster&quot;,\r\n      &quot;VPCID=vpc-xxxx&quot;,\r\n      &quot;ALBName=ALB, test=test&quot;\r\n    ] \r\n\r\nAny help greatly appreciated!\r\n",
        "link": "https://stackoverflow.com/questions/62017112/add-new-elements-to-json-array",
        "title": "Add new elements to JSON array"
    },
    {
        "tags": [
            "json",
            "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": 1590524910,
                "post_id": 62025896,
                "comment_id": 109711345,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18685540,
                    "reputation": 3,
                    "user_id": 13621132,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-Yun7xgx7Z2U/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuck_7EkP5fIZqDaSyDQ-BPZ2NcJ3cQ/s256-rj/photo.jpg",
                    "display_name": "MDS",
                    "link": "https://stackoverflow.com/users/13621132/mds"
                },
                "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": 1590982636,
                "post_id": 62025896,
                "comment_id": 109876228,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1590828777,
                "last_edit_date": 1590828777,
                "creation_date": 1590517719,
                "answer_id": 62028931,
                "question_id": 62025896,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    env $(cat .env) jq -n &#39;$ENV | with_entries(select(.key | index(&quot;APP_&quot;) == 0))&#39;\r\n\r\nThe above command runs `jq` in an environment modified according to the `.env` file and then selects the subset of the environment where variable names start with `APP_`.\r\n\r\nThe jq manual has explanation about `$ENV`, `with_entries`, `select`, and `index` functions which I used.\r\n\r\nhttps://stedolan.github.io/jq/manual/\r\n\r\nA smaller solution:\r\n\r\n    env -i $(cat .env) $(which jq) -n &#39;$ENV&#39;\r\n\r\nThe `env -i` command runs `jq` in an environment which is otherwise empty except for the values in `.env`. `jq` then only dumps the environment. This method removes restrictions on prefixes to start in some particular way.\r\n\r\n`$(which jq)` places the absolute path of `jq` binary in command, which is necessary because there is no `PATH` environment variable where it can look for programs. Remember that `env -i` starts with an empty environment.\r\n\r\nHere the running of `jq` requires no input text. So I used `jq -n` which assumes the input to be `null`.",
                "title": "Converting text file in key value format to a JSON object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1590982850,
                "creation_date": 1590982850,
                "answer_id": 62125351,
                "question_id": 62025896,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "adapted from https://stackoverflow.com/q/51115902/5291015\r\n\r\n    jq -sR &#39;{&quot;Environment&quot;: [ split(&quot;\\n&quot;)[:-1][] | rtrimstr(&quot;\\\\r&quot;) | split(&quot;=&quot;) | {name:.[0],value:.[1]}]}&#39; env",
                "title": "Converting text file in key value format to a JSON object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1590982850,
        "creation_date": 1590507410,
        "last_edit_date": 1590519298,
        "question_id": 62025896,
        "body_markdown": "I have a .env file with this content:\r\n\r\n    APP_ENV=local\r\n    APP_DEBUG=true\r\n    APP_URL=http://example.com.br\r\n\r\nAnd I need to transform in something like this:\r\n\r\n    &quot;environment&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;APP_ENV&quot;,\r\n            &quot;value&quot;: &quot;local&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;APP_DEBUG&quot;,\r\n            &quot;value&quot;: &quot;true&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;APP_URL&quot;,\r\n            &quot;value&quot;: &quot;http://example.com.br&quot;\r\n        }\r\n    ]\r\n\r\nI try to transform the file into a bash array, then convert to json with jq, but without success.\r\nCan anybody give a tip?",
        "link": "https://stackoverflow.com/questions/62025896/converting-text-file-in-key-value-format-to-a-json-object",
        "title": "Converting text file in key value format to a JSON object"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1590529276,
                "last_edit_date": 1590529276,
                "creation_date": 1590528316,
                "answer_id": 62031684,
                "question_id": 62031471,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to &quot;split&quot; your object into an array of entries, e.g.\r\n\r\n```lang-none\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;foo&quot;,\r\n    &quot;value&quot;: {\r\n      &quot;primary&quot;: true,\r\n      &quot;blah&quot;: &quot;beep&quot;\r\n    }\r\n  }\r\n  //...\r\n]\r\n```\r\n\r\nThen you can filter with `.value.primary` and map the result with `.key`:\r\n\r\n```lang-jq\r\nto_entries | map(select(.value.primary)  | .key)\r\n```\r\n\r\nReturns:\r\n\r\n```json\r\n[\r\n  &quot;foo&quot;\r\n]\r\n```\r\n\r\nOr to get just the first item of the array: (Thanks @nbari)\r\n\r\n```lang-jq\r\nto_entries | map(select(.value.primary)  | .key)[0]\r\n```",
                "title": "How do I extract a key with jq based on its child values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1663798236,
        "creation_date": 1590527428,
        "question_id": 62031471,
        "body_markdown": "I&#39;m trying to process some JSON with jq.  Specifically, I want a particular key, based on its child value.  Example, given:\r\n\r\n```json\r\n{\r\n  &quot;foo&quot;: {&quot;primary&quot;: true, &quot;blah&quot;: &quot;beep&quot;},\r\n  &quot;bar&quot;: {&quot;primary&quot;: false, &quot;blah&quot;: &quot;narf&quot;},\r\n  &quot;baz&quot;: {&quot;primary&quot;: false, &quot;blah&quot;: &quot;poink&quot;},\r\n}\r\n```\r\n\r\nI want the string &quot;foo&quot;, because that is the key whose child value &quot;primary&#39; is true.  (I can guarantee that one and only one entry will have primary = true, due to what&#39;s generating the JSON.)\r\n\r\nSo far the best I&#39;ve been able to manage is:\r\n\r\n```\r\njq -r &#39;.[] | select(.primary == true)&#39;\r\n```\r\n\r\nBut that returns the value of &quot;foo&quot;, not the string &quot;foo&quot; itself.  Digging through the manual so far I&#39;ve not found a way to grab the key specifically.\r\n\r\nAny pointers you can provide?",
        "link": "https://stackoverflow.com/questions/62031471/how-do-i-extract-a-key-with-jq-based-on-its-child-values",
        "title": "How do I extract a key with jq based on its child values"
    },
    {
        "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": 1590531843,
                "post_id": 62031931,
                "comment_id": 109714187,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9455675,
                    "reputation": 1392,
                    "user_id": 7031065,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Y0X59.jpg?s=256",
                    "display_name": "Ajay Kr Choudhary",
                    "link": "https://stackoverflow.com/users/7031065/ajay-kr-choudhary"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1590570628,
                "post_id": 62031931,
                "comment_id": 109726341,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 326697,
                    "reputation": 183,
                    "user_id": 648597,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/7f9aac2e6b7872e83947a39ddbabfd32?s=256&d=identicon&r=PG",
                    "display_name": "ozz",
                    "link": "https://stackoverflow.com/users/648597/ozz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1590576912,
                "post_id": 62031931,
                "comment_id": 109729860,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1590576959,
        "creation_date": 1590529504,
        "last_edit_date": 1590576959,
        "question_id": 62031931,
        "body_markdown": "i want to use jq to split a very large json (&gt;80GB) file into smaller parts (&lt;1GB or a fixed number of lines). \r\nI have the necessary statements together... I thought.\r\nWhat do I do so far?\r\n\r\n    jq &quot;. | length&quot; z:\\DOWNLOAD\\rows.json\r\n\r\nworks!\r\n\r\nUnder Windows this should output the first two lines.\r\n\r\n    jq &quot;.[0:1]&quot; z:\\DOWNLOAD\\rows.json\r\n\r\nbut I&#39;m getting an error\r\n\r\n&gt; jq: error (at z:\\DOWNLOAD\\rows.json:589): Cannot index object with\r\n&gt; object\r\n\r\nWhat I also haven&#39;t understood the --Steam switch\r\n\r\nyes, there are a bunch [answers][1], but they do not work under windows (double quotes instead of apostrophe, but see error above)\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/49808581/using-jq-how-can-i-split-a-very-large-json-file-into-multiple-files-each-a-spec\r\n\r\n\r\n\r\n    [{&quot;node&quot;:&quot;http://www.wikidata.org/entity/Q952111&quot;,&quot;Unterklasse_von&quot;:&quot;http://www.wikidata.org/entity/Q2095&quot;},{&quot;node&quot;:&quot;http://.....",
        "link": "https://stackoverflow.com/questions/62031931/using-jq-to-split-huge-json-under-windows",
        "title": "using jq to split huge json UNDER windows"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "join",
            "mapbox",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17454260,
                    "reputation": 193,
                    "user_id": 12653532,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9f9fc50b210df00d5be0a6b8a8cccd0c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Galen BlueTalon",
                    "link": "https://stackoverflow.com/users/12653532/galen-bluetalon"
                },
                "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": 1590559083,
                "post_id": 62035887,
                "comment_id": 109720701,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17454260,
                    "reputation": 193,
                    "user_id": 12653532,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9f9fc50b210df00d5be0a6b8a8cccd0c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Galen BlueTalon",
                    "link": "https://stackoverflow.com/users/12653532/galen-bluetalon"
                },
                "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": 1590559104,
                "post_id": 62035887,
                "comment_id": 109720709,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1590560656,
                "last_edit_date": 1590560656,
                "creation_date": 1590559952,
                "answer_id": 62036544,
                "question_id": 62035887,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A straightforward approach would be saving the second file into a variable and using it as a reference while updating the first file. E.g:\r\n```\r\njq &#39;add as $prices | input\r\n| .objects.us_counties_20m.geometries[] |= . + {PRICE: $prices[.id]}&#39; file2 file1\r\n```\r\n`add` can be substituted with `.[0]` if the array in `file2` contains only one object.\r\n \r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/MHypDS-C64)&lt;/sup&gt;",
                "title": "Merging JSON with array to create new file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1590560656,
        "creation_date": 1590556223,
        "last_edit_date": 1590560481,
        "question_id": 62035887,
        "body_markdown": "I am trying to make a map of the U.S. with Mapbox that shows median home price by county. I have a .json file that contains all the counties and is already accepted by Mapbox tileset - \r\n```\r\n{\r\n  &quot;type&quot;: &quot;Topology&quot;,\r\n  &quot;transform&quot;: {\r\n    &quot;scale&quot;: [\r\n      0.035896170617061705,\r\n      0.005347309530953095\r\n    ],\r\n    &quot;translate&quot;: [\r\n      -179.14734,\r\n      17.884813\r\n    ]\r\n  },\r\n  &quot;objects&quot;: {\r\n    &quot;us_counties_20m&quot;: {\r\n      &quot;type&quot;: &quot;GeometryCollection&quot;,\r\n      &quot;geometries&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;Polygon&quot;,\r\n          &quot;arcs&quot;: [],\r\n          &quot;id&quot;: &quot;0500000US01001&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;Polygon&quot;,\r\n          &quot;arcs&quot;: [],\r\n          &quot;id&quot;: &quot;0500000US01009&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;Polygon&quot;,\r\n          &quot;arcs&quot;: [],\r\n          &quot;id&quot;: &quot;0500000US01017&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;Polygon&quot;,\r\n          &quot;arcs&quot;: [],\r\n          &quot;id&quot;: &quot;0500000US01021&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\nBasically, it&#39;s a json file with &quot;type&quot; (Polygon), &quot;arcs&quot; (to map the county), and &quot;id&quot;, which is an ID for the county. \r\n\r\nThis is great and accepted by Mapbox Tilesets to give me a visualization by county, but I need to add in median home price by county (in order to get colors by county, based on price).\r\n\r\nI have a second json file that is more like an array, which has \r\n```\r\n[\r\n  {\r\n    &quot;0500000US01001&quot;: 51289.0,\r\n    &quot;0500000US01009&quot;: 46793.0,\r\n    &quot;0500000US01017&quot;: 39857.0,\r\n    &quot;0500000US01021&quot;: 48859.0\r\n  }\r\n]\r\n```\r\nand so on, but basically it has the ID -&gt; median home price per county. **The ID&#39;s are the same between these 2 files, and of the same quantity.** So I need get a 3rd json file out of these, which has &quot;type&quot;, &quot;arcs&quot;, &quot;id&quot;, and &quot;PRICE&quot; (the addition).\r\n\r\nThese files are huge - any suggestions? I tried using jq but received an error that\r\n```\r\njq: error ... object ({&quot;type&quot;:&quot;To...) and array ([{&quot;0500000U...) cannot be multiplied\r\n``` \r\n\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/62035887/merging-json-with-array-to-create-new-file",
        "title": "Merging JSON with array to create new file"
    },
    {
        "tags": [
            "json",
            "excel",
            "dictionary",
            "join",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1590774675,
                "last_edit_date": 1590774675,
                "creation_date": 1590601504,
                "answer_id": 62049567,
                "question_id": 62037680,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; if I had just the numbers ...\r\n\r\nThe following assumes that the first two columns have been extracted into a CSV or TSV file, e.g.\r\n```\r\n0500000US33009,51289.0\r\n0500000US38041,46793.0\r\n0500000US38043,39857.0\r\n```\r\n\r\nWith the input data in this format, it would of course be very easy to use your favorite text-processing tool to create a JSON dictionary.\r\n\r\n\r\nAssuming a simple CSV format as above, the data could also be converted into a JSON dictionary using an invocation along the lines of:\r\n\r\n    jq -Rn &#39;reduce inputs as $in ({}; \r\n      . + ($in|split(&quot;,&quot;)|{(.[0]): .[1] |  tonumber}))&#39;\r\n\r\nUsing jq 1.6 or earlier, this would produce:\r\n\r\n```\r\n{\r\n  &quot;0500000US33009&quot;: 51289,\r\n  &quot;0500000US38041&quot;: 46793,\r\n  &quot;0500000US38043&quot;: 39857\r\n}\r\n```\r\n\r\nThe change in format of the numeric values is the result of a conversion to IEEE 754 64-bit numbers, and can be avoided by using a more recent version of jq.  Using the current &quot;master&quot; version, the result would be:\r\n```\r\n{\r\n  &quot;0500000US33009&quot;: 51289.0,\r\n  &quot;0500000US38041&quot;: 46793.0,\r\n  &quot;0500000US38043&quot;: 39857.0\r\n}\r\n```\r\n\r\nSo if you&#39;re stuck with jq 1.6 or earlier and require the explicit decimal point, you might want to consider omitting `|tonumber` in the above program, and add a post-processing step if and as required.\r\n\r\n## Some words of caution\r\n1. The jq solution above assumes there are no collisions (one key having more than one value), or rather, that if there are any collisions, then the last key-value pair should prevail.\r\n\r\n2. If any of the values in the second column cannot be represented with sufficient accuracy as IEEE 754 64-bit numbers, then a significantly different strategy may be warranted.\r\n\r\n3. If the number of rows is indeed very large (e.g. in the billions), then the wisdom of constructing a single ginormous JSON dictionary might be worth reconsidering. \r\n",
                "title": "Create JSON with 2 large data sets?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1590774675,
        "creation_date": 1590564717,
        "question_id": 62037680,
        "body_markdown": "I have 2 huge sets of numbers in columns 1 and 2 in an excel sheet. I want to pair my first column with my second column to create a JSON file like this link here - https://github.com/python-visualization/folium/blob/master/examples/data/data3.json,\r\nsomething like\r\n```\r\n[{&quot;0500000US33009&quot;: 51289.0, &quot;0500000US38041&quot;: 46793.0, &quot;0500000US38043&quot;: 39857.0}]\r\n```\r\nif I had just the numbers 0500000US33009, 0500000US38041, and 0500000US38043 in column 1 and 51289.0, 46793.0, and 39857.0 in column 2. How might I do this, and make sure that the resulting JSON has quotes around the &quot;0500000US33009&quot;?\r\n\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/62037680/create-json-with-2-large-data-sets",
        "title": "Create JSON with 2 large data sets?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1590595439,
                "creation_date": 1590595439,
                "answer_id": 62047615,
                "question_id": 62047373,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the following :\r\n\r\n    map_values(select(contains([&quot;AWS2&quot;]))) | keys\r\n\r\n`map_values` lets you iterate on the key/value pairs of an object and transform them. Here we use it to remove the key/value pairs with values that do not contain &quot;AWS2&quot;. Then we simply use `keys` to retrieve the keys of those pairs from the transformed object.\r\n\r\nIf you can assume that only a single value will ever match, you can add a `[0]` to the end to retrieve the key only rather than an array containing it.\r\n\r\nYou can [try it here](https://jqplay.org/s/Wq0IH3sXkl).",
                "title": "Get Key from value using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1590596756,
        "creation_date": 1590594787,
        "last_edit_date": 1590596756,
        "question_id": 62047373,
        "body_markdown": "Dear members of support,\r\n\r\nI need to get a key by value. Specifically, I need to get the key 2 search by value AWS2. I am trying to use this example [1] without success. Could you help, please?\r\n    \r\n    {\r\n      &quot;1&quot;: [&quot;AWS1&quot;],\r\n      &quot;2&quot;: [&quot;AWS2&quot;],\r\n      &quot;3&quot;: [&quot;AWS3&quot;]\r\n    }\r\n\r\nThe entire json is this one\r\n\r\n    {\r\n    &quot;ARN&quot;: &quot;xxxxx&quot;,\r\n    &quot;Name&quot;: &quot;xxxx&quot;,\r\n    &quot;Description&quot;: &quot;xxxx&quot;,\r\n    &quot;KmsKeyId&quot;: &quot;xxxx&quot;,\r\n    &quot;RotationEnabled&quot;: true,\r\n    &quot;RotationLambdaARN&quot;: &quot;arggg&quot;,\r\n    &quot;RotationRules&quot;: {\r\n        &quot;AutomaticallyAfterDays&quot;: 30\r\n    },\r\n    &quot;LastRotatedDate&quot;: &quot;2020-05-27T12:05:56.061000-03:00&quot;,\r\n    &quot;LastChangedDate&quot;: &quot;2020-05-27T13:05:34.807000-03:00&quot;,\r\n    &quot;LastAccessedDate&quot;: &quot;2020-05-26T21:00:00-03:00&quot;,\r\n    &quot;Tags&quot;: [\r\n        {\r\n            &quot;Key&quot;: &quot;aws:cloudformation:stack-name&quot;,\r\n            &quot;Value&quot;: &quot;medusa-monitoring-alerts-role&quot;\r\n        },\r\n        {\r\n            &quot;Key&quot;: &quot;aws:cloudformation:logical-id&quot;,\r\n            &quot;Value&quot;: &quot;xxx&quot;\r\n        },\r\n        {\r\n            &quot;Key&quot;: &quot;Team&quot;,\r\n            &quot;Value&quot;: &quot;xxx xxx&quot;\r\n        },\r\n        {\r\n            &quot;Key&quot;: &quot;aws:cloudformation:stack-id&quot;,\r\n            &quot;Value&quot;: &quot;xxx&quot;\r\n        }\r\n    ],\r\n    &quot;VersionIdsToStages&quot;: {\r\n        &quot;1&quot;: [\r\n            &quot;AWS1&quot;\r\n        ],\r\n        &quot;2&quot;: [\r\n            &quot;AWS2&quot;\r\n        ],\r\n        &quot;3&quot;: [\r\n            &quot;AWS3&quot;\r\n        ]\r\n    }\r\n    }\r\n\r\nI am trying\r\n\r\n    .VersionIdsToStages|map_values(select(contains([&quot;AWS2&quot;]))) | keys[0]\r\n\r\nwithout sucess.\r\n\r\n[1] https://github.com/stedolan/jq/issues/60",
        "link": "https://stackoverflow.com/questions/62047373/get-key-from-value-using-jq",
        "title": "Get Key from value using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1590618813,
                "creation_date": 1590618813,
                "answer_id": 62053965,
                "question_id": 62052536,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `path()` function comes in handy:\r\n\r\n    $ jq -c &#39;path(.. | select(. == &quot;wetransfer@extensions.thunderbird.net&quot;))&#39; input.json\r\n    [&quot;addons&quot;,0,&quot;id&quot;]\r\n\r\nThe resulting path is interpreted as &quot;In the addons field of the initial object, the first array element&#39;s id field matches&quot;. You can use it with `getpath()`, `setpath()`, `delpaths()`, etc. to get or manipulate the value it describes.",
                "title": "How to find something in a json file using Bash"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1590649816,
                "last_edit_date": 1590649816,
                "creation_date": 1590649373,
                "answer_id": 62058846,
                "question_id": 62052536,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using your example with modifications to make it valid JSON:\r\n\r\n    &lt; input.json jq -c --arg s wetransfer@extensions.thunderbird.net &#39;\r\n      paths as $p | select(getpath($p) == $s) | null | setpath($p;$s)&#39;\r\n\r\nproduces:\r\n\r\n    {&quot;addons&quot;:[{&quot;id&quot;:&quot;wetransfer@extensions.thunderbird.net&quot;}]}\r\n\r\n\r\n\r\n## Note\r\nIf there are N paths to the given value, the above will produce N lines.  If you want only the first, you could wrap everything in `first(...)`.\r\n\r\n## Listing all the `&quot;id&quot;` values\r\n\r\n&gt; I also tried to simply list the various ids in that file\r\n\r\nAssuming that `&quot;id&quot;` values of `false` and `null` are of no interest, you can print all the &quot;id&quot; values of interest using the jq filter:\r\n\r\n    .. | .id? // empty\r\n\r\n",
                "title": "How to find something in a json file using Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1590649816,
        "creation_date": 1590612192,
        "last_edit_date": 1590639450,
        "question_id": 62052536,
        "body_markdown": "I would like to search a JSON file for some key or value, and have it print where it was found. \r\n\r\nFor example, when using `jq` to print out my Firefox&#39; extensions.json, I get something like this (using &quot;...&quot; here to skip long parts) :\r\n\r\n    {\r\n      &quot;schemaVersion&quot;: 31,\r\n      &quot;addons&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;wetransfer@extensions.thunderbird.net&quot;,\r\n          &quot;syncGUID&quot;: &quot;{e6369308-1efc-40fd-aa5f-38da7b20df9b}&quot;,\r\n          &quot;version&quot;: &quot;2.0.0&quot;,\r\n          ...\r\n        },\r\n        {\r\n          ...\r\n        }\r\n      ]\r\n    }\r\n\r\nSay I would like to search for &quot;wetransfer@extensions.thunderbird.net&quot;, and would like an output which shows me where it was found with something like this:\r\n\r\n    { &quot;addons&quot;: [ {&quot;id&quot;: &quot;wetransfer@extensions.thunderbird.net&quot;} ] }\r\n\r\nIs there a way to get that with `jq` or with some other json tool?\r\n\r\nI also tried to simply list the various `id`s in that file, and hoped that I would get it with `jq &#39;.id&#39;`, but that just returned `null`, because it apparently needs the full path.\r\n\r\nIn other words, I&#39;m looking for a command-line json parser which I could use in a way similar to Xpath tools\r\n",
        "link": "https://stackoverflow.com/questions/62052536/how-to-find-something-in-a-json-file-using-bash",
        "title": "How to find something in a json file using Bash"
    },
    {
        "tags": [
            "json",
            "bash",
            "format",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1590626101,
                "creation_date": 1590626101,
                "answer_id": 62055056,
                "question_id": 62055014,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As always when it comes to working with JSON in scripts and from the command line, `jq` to the rescue:\r\n\r\n    $ jq -c . input.json\r\n    {&quot;filename&quot;:&quot;./readme.md&quot;,&quot;line&quot;:5,&quot;rule&quot;:&quot;MD009&quot;,&quot;aliases&quot;:[&quot;no-trailing-spaces&quot;],&quot;description&quot;:&quot;Trailing spaces&quot;}\r\n    {&quot;filename&quot;:&quot;./readme.md&quot;,&quot;line&quot;:6,&quot;rule&quot;:&quot;MD009&quot;,&quot;aliases&quot;:[&quot;no-trailing-spaces&quot;],&quot;description&quot;:&quot;Trailing spaces&quot;}\r\n\r\n",
                "title": "How to format JSON objects to be on individual lines in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1590626364,
        "creation_date": 1590625740,
        "last_edit_date": 1590626055,
        "question_id": 62055014,
        "body_markdown": "I want to turn \r\n```\r\n{\r\n  &quot;filename&quot;: &quot;./readme.md&quot;,\r\n  &quot;line&quot;: 5,\r\n  &quot;rule&quot;: &quot;MD009&quot;,\r\n  &quot;aliases&quot;: [\r\n    &quot;no-trailing-spaces&quot;\r\n  ],\r\n  &quot;description&quot;: &quot;Trailing spaces&quot;\r\n}\r\n{\r\n  &quot;filename&quot;: &quot;./readme.md&quot;,\r\n  &quot;line&quot;: 6,\r\n  &quot;rule&quot;: &quot;MD009&quot;,\r\n  &quot;aliases&quot;: [\r\n    &quot;no-trailing-spaces&quot;\r\n  ],\r\n  &quot;description&quot;: &quot;Trailing spaces&quot;\r\n}\r\n```\r\ninto \r\n```\r\n{&quot;filename&quot;: &quot;./readme.md&quot;,&quot;line&quot;: 5,&quot;rule&quot;: &quot;MD009&quot;,&quot;aliases&quot;: [&quot;no-trailing-spaces&quot;],&quot;description&quot;:&quot;Trailing spaces&quot;}\r\n{&quot;filename&quot;: &quot;./readme.md&quot;,&quot;line&quot;: 6,&quot;rule&quot;: &quot;MD009&quot;,&quot;aliases&quot;: [&quot;no-trailing-spaces&quot;],&quot;description&quot;:&quot;Trailing spaces&quot;}\r\n```\r\nBasically each { } is on its own line\r\n\r\nIs there a command that could do this? (I can&#39;t use tr)\r\n\r\nMy current solution is messy (Frankensteined together):\r\n```\r\ncat in.file | sed &#39;:a;N;$!ba;s/\\n//g&#39; | sed -e $&#39;s/}{/}\\\\\\n{/g&#39; &gt; out.file\r\n```",
        "link": "https://stackoverflow.com/questions/62055014/how-to-format-json-objects-to-be-on-individual-lines-in-bash",
        "title": "How to format JSON objects to be on individual lines in bash"
    },
    {
        "tags": [
            "json",
            "path",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1590676360,
                "post_id": 62066592,
                "comment_id": 109775227,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12841220,
                    "reputation": 123,
                    "user_id": 9289213,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-4AHOUQ2QL8A/AAAAAAAAAAI/AAAAAAAABTo/tJOcSbgIwMc/s256-rj/photo.jpg",
                    "display_name": "Michiel",
                    "link": "https://stackoverflow.com/users/9289213/michiel"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1590683381,
                "post_id": 62066592,
                "comment_id": 109779579,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1590691947,
                "last_edit_date": 1590691947,
                "creation_date": 1590678989,
                "answer_id": 62068232,
                "question_id": 62066592,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This looks like a overkill to me but it does the job.\r\n\r\n    [path(.[][][].item) as $p | [$p, getpath($p)]] |\r\n    group_by( .[1] ) |\r\n    map({(.[0][1]): (. | map([.[0][0,1]]))})|\r\n    add\r\n\r\nSave the above `jq` filter in file `item_in.jq` and run it as `jq --from-file item_in.jq`. Passing your input to this gives the following output:\r\n\r\n    {\r\n      &quot;beer&quot;: [\r\n        [\r\n          &quot;lorry1&quot;,\r\n          &quot;box2&quot;\r\n        ],\r\n        [\r\n          &quot;lorry2&quot;,\r\n          &quot;box2&quot;\r\n        ]\r\n      ],\r\n      &quot;potatoes&quot;: [\r\n        [\r\n          &quot;lorry1&quot;,\r\n          &quot;box2&quot;\r\n        ]\r\n      ],\r\n      &quot;shoes&quot;: [\r\n        [\r\n          &quot;lorry1&quot;,\r\n          &quot;box1&quot;\r\n        ],\r\n        [\r\n          &quot;lorry2&quot;,\r\n          &quot;box1&quot;\r\n        ]\r\n      ],\r\n      &quot;snacks&quot;: [\r\n        [\r\n          &quot;lorry1&quot;,\r\n          &quot;box1&quot;\r\n        ],\r\n        [\r\n          &quot;lorry2&quot;,\r\n          &quot;box1&quot;\r\n        ]\r\n      ]\r\n    }\r\n\r\n\r\nThe initial transformation was to dump leaves and their paths from the input JSON tree.\r\nSee\r\nhttps://github.com/stedolan/jq/issues/78#issuecomment-17819519",
                "title": "How can I map items together in a json structure with jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1590682657,
                "creation_date": 1590682657,
                "answer_id": 62069538,
                "question_id": 62066592,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; The answer I&#39;d like to get is lorry1, box1 and lorry2, box1\r\n\r\nIn this case, you can get it with:\r\n\r\n```lang-jq\r\npath(.. | select(.item? == &quot;shoes&quot;))\r\n```\r\n\r\nWhich returns:\r\n\r\n```\r\n[&quot;lorry1&quot;,&quot;box1&quot;,0]\r\n[&quot;lorry2&quot;,&quot;box1&quot;,0]\r\n```\r\n\r\nThese are the paths in your object that will lead to an object which `.item` property is set to &quot;shoes&quot;",
                "title": "How can I map items together in a json structure with jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1590686034,
                "last_edit_date": 1590686034,
                "creation_date": 1590685384,
                "answer_id": 62070427,
                "question_id": 62066592,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a generic solution that does not assume the &quot;items&quot; are in arrays, or even that the values associated with the &quot;item&quot; keys are always strings:\r\n\r\n```\r\njq -c &#39;. as $in\r\n  | [paths as $p | select($p[-1] == &quot;item&quot;) | $p]\r\n  | group_by(. as $p | $in|getpath($p))\r\n  | .[]\r\n  | (.[0] as $p | $in | getpath($p)) as $v\r\n  | {($v|tostring):  ( map(.[:-1] | if .[-1] | type == &quot;number&quot; then .[:-1] else . end)) }\r\n&#39;\r\n```\r\n\r\n## Output\r\nWith your input:\r\n```\r\n{&quot;beer&quot;:[[&quot;lorry1&quot;,&quot;box2&quot;],[&quot;lorry2&quot;,&quot;box2&quot;]]}\r\n{&quot;potatoes&quot;:[[&quot;lorry1&quot;,&quot;box2&quot;]]}\r\n{&quot;shoes&quot;:[[&quot;lorry1&quot;,&quot;box1&quot;],[&quot;lorry2&quot;,&quot;box1&quot;]]}\r\n{&quot;snacks&quot;:[[&quot;lorry1&quot;,&quot;box1&quot;],[&quot;lorry2&quot;,&quot;box1&quot;]]}\r\n```\r\n\r\nIf you want the output as a single JSON object, then collect the above into an array and use `add`.\r\n\r\n\r\n",
                "title": "How can I map items together in a json structure with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1590716285,
        "creation_date": 1590674418,
        "last_edit_date": 1590716285,
        "question_id": 62066592,
        "body_markdown": "I have a json structure that looks like this:\r\n\r\n```\r\n{\r\n        &quot;lorry1&quot;: {\r\n                &quot;box1&quot;: [\r\n                        {&quot;item&quot;: &quot;shoes&quot;, &quot;state&quot;: &quot;new&quot;},\r\n                        {&quot;item&quot;: &quot;snacks&quot;, &quot;state&quot;: &quot;new&quot;}\r\n                ],\r\n                &quot;box2&quot;: [\r\n                        {&quot;item&quot;: &quot;beer&quot;, &quot;state&quot;: &quot;cold&quot;},\r\n                        {&quot;item&quot;: &quot;potatoes&quot;}\r\n                ]\r\n        },\r\n        &quot;lorry2&quot;: {\r\n                &quot;box1&quot;: [\r\n                        {&quot;item&quot;: &quot;shoes&quot;, &quot;state&quot;: &quot;new&quot;},\r\n                        {&quot;item&quot;: &quot;snacks&quot;, &quot;state&quot;: &quot;new&quot;}\r\n                ],\r\n                &quot;box2&quot;: [\r\n                        {&quot;item&quot;: &quot;beer&quot;, &quot;state&quot;: &quot;lukewarm&quot;}\r\n                ]\r\n        }\r\n}\r\n```\r\n\r\nNow I want to know where I can find shoes:\r\nI could come up with this jq query:\r\n```\r\nto_entries | select(.[].value | .[][].item==&quot;shoes&quot;) | map({&quot;lorry&quot;: &quot;\\(.key)&quot;  })\r\n```\r\nBut that only gives me the lorries. Useful, but not quite there yet. I&#39;d like to know the box they&#39;re in as well.\r\n\r\nI came up with this, but it obviously is not correct:\r\n```\r\nto_entries | select(.[].value | .[][].item==&quot;shoes&quot;) | keys as $box |map({&quot;lorry&quot;: &quot;\\(.key)&quot;, &quot;box&quot;: $box })\r\n```\r\nThe answer I&#39;d like to get is lorry1, box1 and lorry2, box1.\r\n\r\nEven better yet: I&#39;d like to find all items and provide the information, like this:\r\n```\r\n&quot;shoes&quot;: [ {&quot;lorry1&quot;, &quot;box1&quot;}, {&quot;lorry2&quot;, &quot;box1&quot; } ],\r\n&quot;snacks&quot;: [ {&quot;lorry1&quot;, &quot;box1&quot;}, {&quot;lorry2&quot;, &quot;box1&quot;} ],\r\n&quot;beer&quot;: [ {&quot;lorry1&quot;, &quot;box2&quot;}, {&quot;lorry2&quot;, &quot;box2&quot;} ],\r\n&quot;potatoes&quot;: [ {&quot;lorry1&quot;, &quot;box2&quot;} ]\r\n```\r\nbut that may be asking a bit too much :)\r\n",
        "link": "https://stackoverflow.com/questions/62066592/how-can-i-map-items-together-in-a-json-structure-with-jq",
        "title": "How can I map items together in a json structure with jq?"
    },
    {
        "tags": [
            "bash",
            "jq",
            "unix-timestamp",
            "strftime"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1590701509,
                "last_edit_date": 1590701509,
                "creation_date": 1590701085,
                "answer_id": 62074793,
                "question_id": 62074440,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could tweak your jq program so that it reads:\r\n\r\n```\r\ndef tod: if type==&quot;number&quot; then strftime(&quot;%B %d %Y %I:%M%p&quot;) else tostring end;\r\n\r\n.[] | .[] | .name + &quot;; &quot; + (.date1|tod) + &quot;; &quot; + (.date2|tod)\r\n```\r\n\r\nAn alternative would be:\r\n\r\n```\r\ndef tod: (tonumber? | strftime(&quot;%B %d %Y %I:%M%p&quot;)) // null;\r\n\r\n.[] | .[] | &quot;\\(.name); \\(.date1|tod); \\(.date2|tod)&quot;\r\n```\r\n",
                "title": "jq null unix timestamps parsing issue"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1590703490,
        "creation_date": 1590699623,
        "last_edit_date": 1590703490,
        "question_id": 62074440,
        "body_markdown": "I&#39;m trying to parse a big json file which I receive using curl. \r\n\r\nBy following [this answe][1]r I could parse the next file:\r\n\r\n    $ cat test.json \r\n    {&quot;items&quot;: [{&quot;id&quot;: 110, &quot;date1&quot;: 1590590723, &quot;date2&quot;: 1590110000, &quot;name&quot;: &quot;somename&quot;}]}\r\n\r\nusing the next command:\r\n\r\n    TZ=Europe/Kyiv jq -r &#39;.[] | .[] | .name + &quot;; &quot; + (.date1|strftime(&quot;%B %d %Y %I:%M%p&quot;)) + &quot;; &quot; + (.date2|strftime(&quot;%B %d %Y %I:%M%p&quot;))&#39; test.json\r\n\r\nOutput is:\r\n\r\n    somename; May 27 2020 02:45PM; May 22 2020 01:13AM\r\n\r\nBut when I try to parse the next file using the same command:\r\n\r\n    $ cat test2.json \r\n    {&quot;items&quot;: [{&quot;id&quot;: 110, &quot;date1&quot;: 1590590723, &quot;date2&quot;: null, &quot;name&quot;: &quot;somename&quot;}]}\r\n\r\nOutput is:\r\n\r\n    jq: error (at test2.json:1): strftime/1 requires parsed datetime inputs\r\n\r\nI could replace those null values using `sed` by some valid values before parsing. But maybe there is a better way to skip (ignore) those values, leaving nulls in output:\r\n\r\n    somename; May 27 2020 02:45PM; null\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/36853325/10854998",
        "link": "https://stackoverflow.com/questions/62074440/jq-null-unix-timestamps-parsing-issue",
        "title": "jq null unix timestamps parsing issue"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1590738807,
                "creation_date": 1590738807,
                "answer_id": 62081187,
                "question_id": 62081114,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `reduce`:\r\n\r\n```jq\r\nreduce .[] as $o ({}; . + $o)\r\n```\r\n\r\nreturns:\r\n\r\n```json\r\n{\r\n  &quot;a&quot;: &quot;value&quot;,\r\n  &quot;b&quot;: &quot;value&quot;,\r\n  &quot;c&quot;: &quot;value&quot;\r\n}\r\n```",
                "title": "jq how to merge array objects into single object"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1590739755,
                "last_edit_date": 1590739755,
                "creation_date": 1590739533,
                "answer_id": 62081380,
                "question_id": 62081114,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest way is just to call [`add` filter](https://stedolan.github.io/jq/manual/#add).\r\n\r\n&gt; _&quot;The filter `add` takes as input an array, and produces as output the elements of the array added together. This might mean summed, concatenated or merged depending on the types of the elements of the input array - the rules are the same as those for the `+` operator (described above).&quot;_\r\n&gt; ___\r\n&gt; &lt;sup&gt;Source: https://stedolan.github.io/jq/manual/#add&lt;/sup&gt;\r\n\r\n\r\n```\r\n$ cat test.json \r\n[ \r\n    {\r\n        &quot;a&quot;: &quot;value&quot;\r\n    },\r\n    {\r\n        &quot;b&quot;: &quot;value&quot;\r\n    },\r\n    {\r\n        &quot;c&quot;: &quot;value&quot;\r\n    }\r\n ]\r\n\r\n$ jq &#39;add&#39; test.json\r\n{\r\n  &quot;a&quot;: &quot;value&quot;,\r\n  &quot;b&quot;: &quot;value&quot;,\r\n  &quot;c&quot;: &quot;value&quot;\r\n}\r\n```\r\n\r\nAs mentioned by [peak](https://stackoverflow.com/users/997358/peak) in the comment, you can even skip wrapping `add` filter with the quotes:\r\n\r\n```\r\n$ jq add test.json\r\n{\r\n  &quot;a&quot;: &quot;value&quot;,\r\n  &quot;b&quot;: &quot;value&quot;,\r\n  &quot;c&quot;: &quot;value&quot;\r\n}\r\n```",
                "title": "jq how to merge array objects into single object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1628007735,
                "creation_date": 1628007735,
                "answer_id": 68639619,
                "question_id": 62081114,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In case you want to merge all objects in array recursively (didn&#39;t find any similar answer here):\r\n\r\n    jq &#39;reduce .[] as $x ({}; . * $x)&#39;\r\n\r\n ",
                "title": "jq how to merge array objects into single object"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1628007735,
        "creation_date": 1590738495,
        "question_id": 62081114,
        "body_markdown": "in jq its possible to add objects using the + operator\r\n\r\nif you have an array \r\n\r\n     [\r\n          {\r\n            &quot;a&quot;: &quot;value&quot;\r\n          },\r\n          {\r\n            &quot;b&quot;: &quot;value&quot;\r\n          },\r\n          {\r\n            &quot;c&quot;: &quot;value&quot;\r\n          }\r\n     ]\r\n\r\nI want to convert it into a single object { a:&quot;value&quot;, b:&quot;value&quot;, c:&quot;value&quot; }\r\nI can use the following filter .[0] + .[1] + .[2], but i want to do it for the whole array without specifying all the indexes. \r\n",
        "link": "https://stackoverflow.com/questions/62081114/jq-how-to-merge-array-objects-into-single-object",
        "title": "jq how to merge array objects into single object"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1022874,
                    "reputation": 35264,
                    "user_id": 1032785,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/30816b3d787c2bd9d6f036318304f225?s=256&d=identicon&r=PG",
                    "display_name": "jordanm",
                    "link": "https://stackoverflow.com/users/1032785/jordanm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1590765685,
                "post_id": 62089274,
                "comment_id": 109814059,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1590765884,
                "post_id": 62089274,
                "comment_id": 109814167,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1590766184,
                "post_id": 62089274,
                "comment_id": 109814339,
                "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": 1590766214,
                "post_id": 62089274,
                "comment_id": 109814361,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1590768609,
                "creation_date": 1590768609,
                "answer_id": 62090227,
                "question_id": 62089274,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you _really_ want to do it this way, that might look like:\r\n\r\n```\r\nreadarray -t permissions &lt; &lt;(jq -c &#39;.permissions[]&#39; JsonFileToTest)\r\nfor permissionSet in &quot;${permissions[@]}&quot;; do\r\n  jq -r &#39;.emailid&#39; &lt;&lt;&lt;&quot;$permissionSet&quot;\r\ndone\r\n```\r\n\r\nNote that we&#39;re telling jq to print one line per item (with `-c`), and using `readarray -t` to read each line into an array element (unlike the `array=( $(...command...) )` antipattern, which splits not just on newlines but on other whitespace as well, and expands globs in the process).\r\n\r\n---\r\n\r\nBut there&#39;s no reason whatsoever to do any of that. You&#39;ll get the _exact_ same result simply running:\r\n\r\n```\r\njq -r &#39;.permissions[].emailid&#39; JsonFileToTest\r\n```\r\n",
                "title": "bash loop error : Get JSON Object by property with jq / bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1590768609,
        "creation_date": 1590765498,
        "last_edit_date": 1590768190,
        "question_id": 62089274,
        "body_markdown": "I would like to get the values from Json file. Which is working. \r\n\r\n`JsonFileToTest`:\r\n```\r\n{\r\n  &quot;permissions&quot;: [\r\n    {\r\n      &quot;emailid&quot;: &quot;test1@test.com&quot;,\r\n      &quot;rights&quot;: &quot;read&quot;\r\n    },\r\n    {\r\n      &quot;emailid&quot;: &quot;test2@test.com&quot;,\r\n      &quot;rights&quot;: &quot;read&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n``` \r\nreadPermissions=($(jq -r &#39;.permissions&#39; JsonFileToTest))\r\n\r\n# The command below works perfectly, But when I Put it in a loop, It does not.\r\n#echo ${readPermissions[@]} | jq &#39;values[].emailid&#39;\r\n\r\nfor vals in ${readPermissions[@]}\r\ndo\r\n   # I would like o extract the email id of the user. The loop is not working atm.  \r\n    echo ${vals[@]} | jq &#39;values[].emailid&#39;\r\ndone\r\n``` \r\n\r\nwhat am I missing here?\r\nthanks ",
        "link": "https://stackoverflow.com/questions/62089274/bash-loop-error-get-json-object-by-property-with-jq-bash",
        "title": "bash loop error : Get JSON Object by property with jq / bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1590796212,
                "last_edit_date": 1590796212,
                "creation_date": 1590795501,
                "answer_id": 62096047,
                "question_id": 62095357,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get the &quot;expected&quot; output as shown, you could use the following jq filter in conjunction with the -s option:\r\n\r\n\r\n    { contacts: [.[] | [.contacts]] | add }\r\n\r\nHowever, your jq program indicates you also want to convert some strings to numbers.  That is q.e.d. along the lines you suggest and is thus left as an exercise, but a complete solution using an alternative approach is shown below.\r\n\r\n## Avoiding --slurp\r\n\r\nIn general, it&#39;s better to use -n with `inputs`:\r\n```\r\n[ [inputs.contacts \r\n   | .fields[].id |= tonumber\r\n   | .orgid |= tonumber] ]\r\n| {contacts: add}\r\n\r\n```",
                "title": "Contain .jq Filter Results Into a Single Array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1590796212,
        "creation_date": 1590790552,
        "question_id": 62095357,
        "body_markdown": "With the following input example:\r\n\r\n```\r\n{&quot;contacts&quot;:{&quot;orgid&quot;:&quot;1&quot;,&quot;email&quot;:&quot;janedoe@aol.com&quot;,&quot;first_name&quot;:&quot;Jane&quot;,&quot;last_name&quot;:&quot;Doe&quot;,&quot;phone&quot;:&quot;4045551212&quot;,&quot;tags&quot;:[&quot;tag1&quot;,&quot;tag2&quot;],&quot;fields&quot;:[{&quot;id&quot;:&quot;2&quot;,&quot;value&quot;:&quot;IB4220&quot;},{&quot;id&quot;:&quot;3&quot;,&quot;value&quot;:&quot;1994-05-18&quot;},{&quot;id&quot;:&quot;12&quot;,&quot;value&quot;:&quot;CONSULTANT&quot;},{&quot;id&quot;:&quot;13&quot;,&quot;value&quot;:&quot;janedoe@aol.com&quot;},{&quot;id&quot;:&quot;6&quot;,&quot;value&quot;:&quot;111 Main Blvd&quot;},{&quot;id&quot;:&quot;7&quot;,&quot;value&quot;:&quot;Babylon&quot;},{&quot;id&quot;:&quot;8&quot;,&quot;value&quot;:&quot;NY&quot;},{&quot;id&quot;:&quot;9&quot;,&quot;value&quot;:&quot;11702-1522&quot;},{&quot;id&quot;:&quot;10&quot;,&quot;value&quot;:&quot;US&quot;},{&quot;id&quot;:&quot;11&quot;,&quot;value&quot;:&quot;&quot;},{&quot;id&quot;:&quot;5&quot;,&quot;value&quot;:&quot;http://www.something.com/janedoe&quot;}]}}\r\n{&quot;contacts&quot;:{&quot;orgid&quot;:&quot;1&quot;,&quot;email&quot;:&quot;janedoe@aol.com&quot;,&quot;first_name&quot;:&quot;Jane&quot;,&quot;last_name&quot;:&quot;Doe&quot;,&quot;phone&quot;:&quot;4045551212&quot;,&quot;tags&quot;:[&quot;tag1&quot;,&quot;tag2&quot;],&quot;fields&quot;:[{&quot;id&quot;:&quot;2&quot;,&quot;value&quot;:&quot;IB4220&quot;},{&quot;id&quot;:&quot;3&quot;,&quot;value&quot;:&quot;1994-05-18&quot;},{&quot;id&quot;:&quot;12&quot;,&quot;value&quot;:&quot;CONSULTANT&quot;},{&quot;id&quot;:&quot;13&quot;,&quot;value&quot;:&quot;janedoe@aol.com&quot;},{&quot;id&quot;:&quot;6&quot;,&quot;value&quot;:&quot;111 Main Blvd&quot;},{&quot;id&quot;:&quot;7&quot;,&quot;value&quot;:&quot;Babylon&quot;},{&quot;id&quot;:&quot;8&quot;,&quot;value&quot;:&quot;NY&quot;},{&quot;id&quot;:&quot;9&quot;,&quot;value&quot;:&quot;11702-1522&quot;},{&quot;id&quot;:&quot;10&quot;,&quot;value&quot;:&quot;US&quot;},{&quot;id&quot;:&quot;11&quot;,&quot;value&quot;:&quot;&quot;},{&quot;id&quot;:&quot;5&quot;,&quot;value&quot;:&quot;http://www.something.com/janedoe&quot;}]}}\r\n```\r\nI am trying to contain my filter result in a single &quot;contacts&quot; array.\r\n\r\nHere is my jq filter I am working with to no avail...\r\n\r\n```\r\njq --slurp &#39;.[] | .[].fields[].id |= tonumber | .[].orgid |= tonumber | {contacts: [.[]| {orgid: .[&quot;orgid&quot;],email: .[&quot;email&quot;],first_name: .[&quot;first_name&quot;],last_name: .[&quot;last_name&quot;],phone: .[&quot;phone&quot;],tags:[ .[&quot;tags&quot;]],fields}]}&#39;\r\n```\r\nIt wraps each input line in a &quot;contacts&quot; array like follows...\r\n\r\n```\r\n{\r\n  &quot;contacts&quot;: [\r\n    {\r\n      &quot;orgid&quot;: 1,\r\n      &quot;email&quot;: &quot;janedoe@aol.com&quot;,\r\n      &quot;first_name&quot;: &quot;Jane&quot;,\r\n      &quot;last_name&quot;: &quot;Doe&quot;,\r\n      &quot;phone&quot;: &quot;4045551212&quot;,\r\n      &quot;tags&quot;: [\r\n        [\r\n          &quot;tag1&quot;,\r\n          &quot;tag2&quot;\r\n        ]\r\n      ],\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;value&quot;: &quot;IB4220&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;value&quot;: &quot;1994-05-18&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 12,\r\n          &quot;value&quot;: &quot;CONSULTANT&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 13,\r\n          &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 6,\r\n          &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 7,\r\n          &quot;value&quot;: &quot;Babylon&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 8,\r\n          &quot;value&quot;: &quot;NY&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 9,\r\n          &quot;value&quot;: &quot;11702-1522&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 10,\r\n          &quot;value&quot;: &quot;US&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 11,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 5,\r\n          &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;contacts&quot;: [\r\n    {\r\n      &quot;orgid&quot;: 1,\r\n      &quot;email&quot;: &quot;janedoe@aol.com&quot;,\r\n      &quot;first_name&quot;: &quot;Jane&quot;,\r\n      &quot;last_name&quot;: &quot;Doe&quot;,\r\n      &quot;phone&quot;: &quot;4045551212&quot;,\r\n      &quot;tags&quot;: [\r\n        [\r\n          &quot;tag1&quot;,\r\n          &quot;tag2&quot;\r\n        ]\r\n      ],\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;value&quot;: &quot;IB4220&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;value&quot;: &quot;1994-05-18&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 12,\r\n          &quot;value&quot;: &quot;CONSULTANT&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 13,\r\n          &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 6,\r\n          &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 7,\r\n          &quot;value&quot;: &quot;Babylon&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 8,\r\n          &quot;value&quot;: &quot;NY&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 9,\r\n          &quot;value&quot;: &quot;11702-1522&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 10,\r\n          &quot;value&quot;: &quot;US&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 11,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 5,\r\n          &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n... But I need it like this (1 &quot;contacts&quot; array containing all the filtered input lines)...\r\n\r\n```\r\n{\r\n    &quot;contacts&quot;: [\r\n        {\r\n            &quot;orgid&quot;: &quot;1&quot;,\r\n            &quot;email&quot;: &quot;janedoe@aol.com&quot;,\r\n            &quot;first_name&quot;: &quot;Jane&quot;,\r\n            &quot;last_name&quot;: &quot;Doe&quot;,\r\n            &quot;phone&quot;: &quot;4045551212&quot;,\r\n            &quot;tags&quot;: [\r\n                &quot;tag1&quot;,\r\n                &quot;tag2&quot;\r\n            ],\r\n            &quot;fields&quot;: [\r\n                {\r\n                    &quot;id&quot;: &quot;2&quot;,\r\n                    &quot;value&quot;: &quot;IB4220&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;3&quot;,\r\n                    &quot;value&quot;: &quot;1994-05-18&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;12&quot;,\r\n                    &quot;value&quot;: &quot;CONSULTANT&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;13&quot;,\r\n                    &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;6&quot;,\r\n                    &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;7&quot;,\r\n                    &quot;value&quot;: &quot;Babylon&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;8&quot;,\r\n                    &quot;value&quot;: &quot;NY&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;9&quot;,\r\n                    &quot;value&quot;: &quot;11702-1522&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;10&quot;,\r\n                    &quot;value&quot;: &quot;US&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;11&quot;,\r\n                    &quot;value&quot;: &quot;&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;5&quot;,\r\n                    &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;orgid&quot;: &quot;1&quot;,\r\n            &quot;email&quot;: &quot;janedoe@aol.com&quot;,\r\n            &quot;first_name&quot;: &quot;Jane&quot;,\r\n            &quot;last_name&quot;: &quot;Doe&quot;,\r\n            &quot;phone&quot;: &quot;4045551212&quot;,\r\n            &quot;tags&quot;: [\r\n                &quot;tag1&quot;,\r\n                &quot;tag2&quot;\r\n            ],\r\n            &quot;fields&quot;: [\r\n                {\r\n                    &quot;id&quot;: &quot;2&quot;,\r\n                    &quot;value&quot;: &quot;IB4220&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;3&quot;,\r\n                    &quot;value&quot;: &quot;1994-05-18&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;12&quot;,\r\n                    &quot;value&quot;: &quot;CONSULTANT&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;13&quot;,\r\n                    &quot;value&quot;: &quot;janedoe@aol.com&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;6&quot;,\r\n                    &quot;value&quot;: &quot;111 Main Blvd&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;7&quot;,\r\n                    &quot;value&quot;: &quot;Babylon&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;8&quot;,\r\n                    &quot;value&quot;: &quot;NY&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;9&quot;,\r\n                    &quot;value&quot;: &quot;11702-1522&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;10&quot;,\r\n                    &quot;value&quot;: &quot;US&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;11&quot;,\r\n                    &quot;value&quot;: &quot;&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;5&quot;,\r\n                    &quot;value&quot;: &quot;http://www.something.com/janedoe&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n``` ",
        "link": "https://stackoverflow.com/questions/62095357/contain-jq-filter-results-into-a-single-array",
        "title": "Contain .jq Filter Results Into a Single Array"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1590842122,
                "last_edit_date": 1590842122,
                "creation_date": 1590841693,
                "answer_id": 62102446,
                "question_id": 62102387,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you simply need to use the alternative operator `//`\r\n\r\n```jq\r\n. | .Results | .[] | .Persons | .[] | .PersonalInfo | .LASTNAME // .Name2\r\n```\r\n\r\nIf you need to shorten the syntax you can use:\r\n\r\n```jq\r\n.. | (.LASTNAME? // .Name2?) | select(.)\r\n```\r\n\r\nBut I&#39;m not sure whether that&#39;s either performant or advisable.",
                "title": "jq command optimization with variable keys. Two separate jq commands combined in one"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1591799856,
                "last_edit_date": 1591799856,
                "creation_date": 1591789667,
                "answer_id": 62302833,
                "question_id": 62102387,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;ve also used peak&#39;s suggestion to shorten  a `jq` command for slightly different requirement. I couldn&#39;t use the second customcommander&#39;s suggestion properly to combine values on different levels of json file:\r\n\r\n    cat question*.json | jq &#39;.Results[].Persons[] | (.Address|.City) + &quot;; &quot; + (.id|tostring) + &quot;; &quot; + (.PersonalInfo| .LASTNAME // .Name2)&#39;\r\n    &quot;Portland; 20; Pete&quot;\r\n    &quot;New York; 21; Bob&quot;\r\n    &quot;Las Vegas; 2000; Bond&quot;",
                "title": "jq command optimization with variable keys. Two separate jq commands combined in one"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1591799856,
        "creation_date": 1590841379,
        "last_edit_date": 1591797484,
        "question_id": 62102387,
        "body_markdown": "I have a lot of different json files with slightly different structures. \r\n\r\nFor example, I could access `LASTNAME`&#39;s value in the next json file\r\n\r\n    {\r\n      &quot;Results&quot;: [\r\n        {\r\n          &quot;Persons&quot;: [\r\n            {\r\n              &quot;id&quot;: 20,\r\n              &quot;Position&quot;: &quot;office employee&quot;,\r\n              &quot;Profession&quot;: &quot;Office workers&quot;,\r\n              &quot;Address&quot;: {\r\n                &quot;City&quot;: &quot;Portland&quot;,\r\n                &quot;State&quot;: &quot;Washington&quot;,\r\n                &quot;Country&quot;: &quot;USA&quot;\r\n              },\r\n              &quot;PersonalInfo&quot;: {\r\n                &quot;LASTNAME&quot;: &quot;Pete&quot;,\r\n                &quot;FIRSTNAME&quot;: &quot;Columb&quot;,\r\n                &quot;MIDNAME&quot;: &quot;George&quot;\r\n              }\r\n            },\r\n            {\r\n              &quot;id&quot;: 21,\r\n              &quot;Position&quot;: &quot;Manager&quot;,\r\n              &quot;Profession&quot;: &quot;Medicine&quot;,\r\n              &quot;Address&quot;: {\r\n                &quot;City&quot;: &quot;New York&quot;,\r\n                &quot;State&quot;: &quot;&quot;,\r\n                &quot;Country&quot;: &quot;USA&quot;\r\n              },\r\n              &quot;PersonalInfo&quot;: {\r\n                &quot;LASTNAME&quot;: &quot;Bob&quot;,\r\n                &quot;FIRSTNAME&quot;: &quot;Smith&quot;,\r\n                &quot;MIDNAME&quot;: &quot;&quot;\r\n              }\r\n            }\r\n          ],\r\n          &quot;ItemsNumber&quot;: 2,\r\n          &quot;AdditionalItems&quot;: {}\r\n        }\r\n      ]\r\n    }\r\n\r\nwith a command:\r\n\r\n    $ jq -r &#39;. | .Results | .[] | .Persons | .[] | .PersonalInfo | .LASTNAME&#39; question.json \r\n\r\nOutput:\r\n\r\n    Pete\r\n    Bob\r\n\r\nThe second json file example (`$ jq -r . question2.json`):\r\n \r\n    {\r\n      &quot;Results&quot;: [\r\n        {\r\n          &quot;Persons&quot;: [\r\n            {\r\n              &quot;id&quot;: 2000,\r\n              &quot;Position&quot;: &quot;Director&quot;,\r\n              &quot;Profession&quot;: &quot;Marketing&quot;,\r\n              &quot;Address&quot;: {\r\n                &quot;City&quot;: &quot;Las Vegas&quot;,\r\n                &quot;State&quot;: &quot;Nevada&quot;,\r\n                &quot;Country&quot;: &quot;USA&quot;\r\n              },\r\n              &quot;PersonalInfo&quot;: {\r\n                &quot;Name1&quot;: &quot;Steven&quot;,\r\n                &quot;Name2&quot;: &quot;Bond&quot;,\r\n                &quot;Name3&quot;: &quot;&quot;\r\n              }\r\n            }\r\n          ],\r\n          &quot;ItemsNumber&quot;: 1,\r\n          &quot;AdditionalItems&quot;: {}\r\n        }\r\n      ]\r\n    }\r\n\r\nCommand:\r\n\r\n    jq -r &#39;. | .Results | .[] | .Persons | .[] | .PersonalInfo | .Name2&#39; question2.json\r\n\r\nOutput:\r\n\r\n    Bond\r\n\r\n**Question:**   \r\n**Is it possible to combine these two commands in one and make it shorter** (or unique: without `.Results`, `.Persons`, `.PersonalInfo` sections accessing)?\r\n\r\nI tried the next, for example, to combine:\r\n\r\n    jq -r &#39;. | .Results | .[] | .Persons | .[] | .PersonalInfo | (.Name2 or .LASTNAME)&#39; question*.json\r\n\r\nIt outputs:\r\n\r\n    true\r\n    true\r\n    true\r\n\r\nBut I want:\r\n\r\n    Pete\r\n    Bob\r\n    Bond\r\n\r\nNumber of variable keys could be bigger than two: `LASTNAME`, `lname`, `ThirdName`, `Name2`\r\n\r\n**Update**:  \r\nI am currently unable to use the second customcommander&#39;s command properly to output required values without `&quot;; null; &quot;` lines using `jq` only:\r\n\r\n    cat question*.json | jq &#39;.. | (.Address?|.City) + &quot;; &quot; + (.id|tostring) + &quot;; &quot; + (.PersonalInfo?| .LASTNAME // .Name2) | select(.)&#39;\r\n\r\nOutput is not nice in this case:\r\n\r\n    &quot;; null; &quot;\r\n    &quot;; null; &quot;\r\n    &quot;Portland; 20; Pete&quot;\r\n    &quot;; null; &quot;\r\n    &quot;; null; &quot;\r\n    &quot;New York; 21; Bob&quot;\r\n    &quot;; null; &quot;\r\n    &quot;; null; &quot;\r\n    &quot;; null; &quot;\r\n    &quot;; null; &quot;\r\n    &quot;; null; &quot;\r\n    &quot;Las Vegas; 2000; Bond&quot;\r\n    &quot;; null; &quot;\r\n    &quot;; null; &quot;\r\n    &quot;; null; &quot;",
        "link": "https://stackoverflow.com/questions/62102387/jq-command-optimization-with-variable-keys-two-separate-jq-commands-combined-in",
        "title": "jq command optimization with variable keys. Two separate jq commands combined in one"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1590851168,
                "last_edit_date": 1590851168,
                "creation_date": 1590850355,
                "answer_id": 62104180,
                "question_id": 62103800,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The value of .reprint in each of the objects in the top-level array is strictly boolean, as can be seen by running:\r\n\r\n    jq &#39;map(.reprint)|unique&#39;\r\n\r\nSo an efficient way to select the objects for which .reprint is `false` is to use the filter:\r\n\r\n    map(select(.reprint == false))\r\n\r\nThis will preserve the array structure.  If you just want the JSON objects as a stream, you could write:\r\n\r\n    .[] | select(.reprint == false)\r\n\r\nSince .reprint is strictly boolean, there are various equivalent formulations of the condition.\r\n\r\n## Negation\r\nIf .reprint were multi-valued, then to exclude the objects for which `.reprint == true` you could use negation:\r\n\r\n    .[] | select(.reprint == true | not)\r\n\r\nNotice that in jq, `not` is a 0-ary filter -- it has no argument. \r\n\r\n## Compound conditions\r\n\r\n&gt; remove objects where either the key &quot;reprint&quot; is &quot;true&quot; or the key &quot;border_color&quot; is &quot;silver&quot;.\r\n\r\n    map(select( (.reprint == true or .border_color == &quot;silver&quot;) | not))\r\n\r\n",
                "title": "jq - how to conditionally filter out objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1590991708,
        "creation_date": 1590848632,
        "last_edit_date": 1590991708,
        "question_id": 62103800,
        "body_markdown": "I&#39;m trying to vastly simplify a large JSON file, and part of that process is conditionally filtering out some of the objects. I have a series of conditions I&#39;d like to apply, but I&#39;m not able to get even a single condition to work properly.\r\n\r\nI&#39;ve been working with the jq documentation, but I&#39;m not a pro developer so it&#39;s challenging to read it. I found an example of this in another stackoverflow thread, so I&#39;ve been trying to adapt that.\r\n\r\nMy source JSON file, while large, is clean and well-formed. It&#39;s basically one flat array of objects. A few of the keys in the objects are arrays as well, but I&#39;ll be discarding most of those anyway. Below is a sample, showing the first object:\r\n```\r\n[\r\n   {\r\n      &quot;object&quot;:&quot;card&quot;,\r\n      &quot;id&quot;:&quot;86bf43b1-8d4e-4759-bb2d-0b2e03ba7012&quot;,\r\n      &quot;oracle_id&quot;:&quot;0004ebd0-dfd6-4276-b4a6-de0003e94237&quot;,\r\n      &quot;multiverse_ids&quot;:[\r\n         15862\r\n      ],\r\n      &quot;mtgo_id&quot;:15870,\r\n      &quot;mtgo_foil_id&quot;:15871,\r\n      &quot;tcgplayer_id&quot;:3094,\r\n      &quot;name&quot;:&quot;Static Orb&quot;,\r\n      &quot;lang&quot;:&quot;en&quot;,\r\n      &quot;released_at&quot;:&quot;2001-04-11&quot;,\r\n      &quot;uri&quot;:&quot;https://api.scryfall.com/cards/86bf43b1-8d4e-4759-bb2d-0b2e03ba7012&quot;,\r\n      &quot;scryfall_uri&quot;:&quot;https://scryfall.com/card/7ed/319/static-orb?utm_source=api&quot;,\r\n      &quot;layout&quot;:&quot;normal&quot;,\r\n      &quot;highres_image&quot;:true,\r\n      &quot;mana_cost&quot;:&quot;{3}&quot;,\r\n      &quot;cmc&quot;:3.0,\r\n      &quot;type_line&quot;:&quot;Artifact&quot;,\r\n      &quot;oracle_text&quot;:&quot;As long as Static Orb is untapped, players can&#39;t untap more than two permanents during their untap steps.&quot;,\r\n      &quot;colors&quot;:[\r\n\r\n      ],\r\n      &quot;color_identity&quot;:[\r\n\r\n      ],\r\n      &quot;legalities&quot;:{\r\n         &quot;standard&quot;:&quot;not_legal&quot;,\r\n         &quot;future&quot;:&quot;not_legal&quot;,\r\n         &quot;historic&quot;:&quot;not_legal&quot;,\r\n         &quot;pioneer&quot;:&quot;not_legal&quot;,\r\n         &quot;modern&quot;:&quot;not_legal&quot;,\r\n         &quot;legacy&quot;:&quot;legal&quot;,\r\n         &quot;pauper&quot;:&quot;not_legal&quot;,\r\n         &quot;vintage&quot;:&quot;legal&quot;,\r\n         &quot;penny&quot;:&quot;not_legal&quot;,\r\n         &quot;commander&quot;:&quot;legal&quot;,\r\n         &quot;brawl&quot;:&quot;not_legal&quot;,\r\n         &quot;duel&quot;:&quot;legal&quot;,\r\n         &quot;oldschool&quot;:&quot;not_legal&quot;\r\n      },\r\n      &quot;games&quot;:[\r\n         &quot;paper&quot;,\r\n         &quot;mtgo&quot;\r\n      ],\r\n      &quot;reserved&quot;:false,\r\n      &quot;foil&quot;:true,\r\n      &quot;nonfoil&quot;:true,\r\n      &quot;oversized&quot;:false,\r\n      &quot;promo&quot;:false,\r\n      &quot;reprint&quot;:true,\r\n      &quot;variation&quot;:false,\r\n      &quot;set&quot;:&quot;7ed&quot;,\r\n      &quot;set_name&quot;:&quot;Seventh Edition&quot;,\r\n      &quot;set_type&quot;:&quot;core&quot;,\r\n      &quot;collector_number&quot;:&quot;319&quot;,\r\n      &quot;digital&quot;:false,\r\n      &quot;rarity&quot;:&quot;rare&quot;,\r\n      &quot;flavor_text&quot;:&quot;The warriors fought against the paralyzing waves until even their thoughts froze in place.&quot;,\r\n      &quot;card_back_id&quot;:&quot;0aeebaf5-8c7d-4636-9e82-8c27447861f7&quot;,\r\n      &quot;artist&quot;:&quot;Terese Nielsen&quot;,\r\n      &quot;artist_ids&quot;:[\r\n         &quot;eb55171c-2342-45f4-a503-2d5a75baf752&quot;\r\n      ],\r\n      &quot;illustration_id&quot;:&quot;6f8b3b2c-252f-4f95-b621-712c82be38b5&quot;,\r\n      &quot;border_color&quot;:&quot;white&quot;,\r\n      &quot;frame&quot;:&quot;1997&quot;,\r\n      &quot;full_art&quot;:false,\r\n      &quot;textless&quot;:false,\r\n      &quot;booster&quot;:true,\r\n      &quot;story_spotlight&quot;:false,\r\n      &quot;edhrec_rank&quot;:1836,\r\n      &quot;prices&quot;:{\r\n         &quot;usd&quot;:&quot;17.07&quot;,\r\n         &quot;usd_foil&quot;:&quot;72.02&quot;,\r\n         &quot;eur&quot;:&quot;10.73&quot;,\r\n         &quot;tix&quot;:&quot;0.79&quot;\r\n      },\r\n      &quot;related_uris&quot;:{\r\n         &quot;gatherer&quot;:&quot;https://gatherer.wizards.com/Pages/Card/Details.aspx?multiverseid=15862&quot;,\r\n         &quot;tcgplayer_decks&quot;:&quot;https://decks.tcgplayer.com/magic/deck/search?contains=Static+Orb\\u0026page=1\\u0026utm_campaign=affiliate\\u0026utm_medium=api\\u0026utm_source=scryfall&quot;,\r\n         &quot;edhrec&quot;:&quot;https://edhrec.com/route/?cc=Static+Orb&quot;,\r\n         &quot;mtgtop8&quot;:&quot;https://mtgtop8.com/search?MD_check=1\\u0026SB_check=1\\u0026cards=Static+Orb&quot;\r\n      }\r\n   }\r\n]\r\n\r\n```\r\nFirst, I&#39;m attempting to add a condition which will remove objects where the key &quot;reprint&quot; has the value true. This is what I&#39;ve got so far:\r\n\r\n```curl -s https://archive.scryfall.com/bulk-data/default-cards/default-cards-20200529170427.json | jq .[] - &quot;map(select(.reprint[] | contains (\\&quot;true\\&quot;)))&quot; &gt; reprints_removed.json```\r\n\r\nBut I keep getting this error:\r\n\r\n```jq: error: Could not open file map(select(.reprint[] | contains (&quot;true&quot;))): No such file or directory```\r\n\r\nOnce I&#39;ve got that working, I&#39;d like to start using compound conditions. So, for instance, next I&#39;ll remove objects where either the key &quot;reprint&quot; is &quot;true&quot; or the key &quot;border_color&quot; is &quot;silver&quot;.\r\n\r\nWhere am I going wrong?",
        "link": "https://stackoverflow.com/questions/62103800/jq-how-to-conditionally-filter-out-objects",
        "title": "jq - how to conditionally filter out objects"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1590859341,
                "last_edit_date": 1590859341,
                "creation_date": 1590858966,
                "answer_id": 62106070,
                "question_id": 62104704,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `-r` in `jq -r` removed quotes, this is what&#39;s needed :\r\n\r\n```\r\ndeclare VERSIONS=($(curl -s https://api.github.com/repos/humhub/humhub/releases | jq &#39;.[].name&#39;))\r\n```",
                "title": "json jq array to string with double quotes"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1590859341,
        "creation_date": 1590852692,
        "question_id": 62104704,
        "body_markdown": "I am trying to convert an array to string and would like to be: \r\n\r\n    declare -r LOCAL_VERSIONS=(\r\n        &quot;1.3.17&quot;\r\n        &quot;1.3.18&quot;\r\n        &quot;1.3.19&quot;\r\n        &quot;1.3.20&quot;\r\n        &quot;1.4.0-beta.1&quot;\r\n        &quot;1.4.0-beta.1&quot;\r\n        &quot;1.4.0-beta.2&quot;\r\n        &quot;1.4.0&quot;\r\n        &quot;1.4.1&quot;\r\n        &quot;1.4.2&quot;\r\n        &quot;1.4.3&quot;\r\n        &quot;1.4.4&quot;\r\n        &quot;1.5.0-beta.1&quot;\r\n        &quot;1.5.0&quot;\r\n        &quot;1.5.1&quot;\r\n        &quot;1.5.2&quot;\r\n    )\r\n\r\nThe best I got so far is:\r\n```bash\r\ndeclare -r VERSIONS=(=${VERSIONS:-$(curl -s https://api.github.com/repos/humhub/humhub/releases | jq -r &#39;.[] | [.name] | join(&quot; &quot;)&#39;)})\r\n\r\n```\r\nwhich outputs:\r\n\r\n```\r\n1.5.1\r\n1.5.0\r\n1.5.0-beta.1\r\n1.4.4\r\n1.4.3\r\n1.4.2\r\n1.4.1\r\n1.4.0\r\n1.3.20\r\n1.3.19\r\n1.4.0-beta.2\r\n1.3.18\r\n1.4.0-beta.1\r\n1.3.17\r\n1.3.9\r\n1.3.8\r\n1.3.7\r\n1.3.6\r\n1.3.5\r\n1.3.4\r\n1.3.3\r\n1.3.2\r\n```\r\n\r\nHow I can achieve as LOCAL_VERSIONS using curl (meaning getting versions from GitHub) ?",
        "link": "https://stackoverflow.com/questions/62104704/json-jq-array-to-string-with-double-quotes",
        "title": "json jq array to string with double quotes"
    },
    {
        "tags": [
            "bash",
            "jq",
            "aws-cli",
            "aws-codepipeline"
        ],
        "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": 1590988330,
                "post_id": 62122382,
                "comment_id": 109877418,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1715329706,
                "last_edit_date": 1715329706,
                "creation_date": 1591010826,
                "answer_id": 62131121,
                "question_id": 62122382,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can get most of the way there using the following\r\n\r\n```bash\r\nexport pipelines=$(aws codepipeline list-pipelines --query &#39;pipelines[].name&#39; --output text)\r\n\r\nfor p in $pipelines; do\r\n    aws codepipeline get-pipeline-state \\\r\n        --name $p \\\r\n        --query &#39;stageStates[?latestExecution.status==`InProgress`].{stageName:stageName,actionName:actionStates[0].actionName,token:actionStates[0].latestExecution.token}&#39;\r\ndone\r\n```\r\n\r\nThis assumes the approval action exists as the _first_ or _only_ action within a stage.\r\n\r\nYou&#39;ll get the output required for the [`put-approval-result`](https://docs.aws.amazon.com/cli/latest/reference/codepipeline/put-approval-result.html) command",
                "title": "Get a list of AWS pipelines ready for stage approval"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1715329706,
        "creation_date": 1590958669,
        "last_edit_date": 1590964016,
        "question_id": 62122382,
        "body_markdown": "\r\nI have 40+ pipelines that I need to approve from dev to QA and then QA to stage.  I am working on a script to use AWS CLI commands to do do.  I have been able to do that for a single pipeline where I know that the specific pipeline is ready to be approved. \r\n\r\n    aws codepipeline put-approval-result --cli-input-json file://TestPipeline.json \r\n\r\nThis is how I gathered the information for the approval for a single pipeline\r\n\r\n    aws codepipeline get-pipeline-state --name Pipeline-Ready-for-Approval \r\n\r\nWhat I am trying to find out is - is there a way to loop through all of the pipelines using the `get-pipeline-state` and identify the stage name and action name without manually going through output of each of the pipelines.\r\n\r\nI can try to get the pipeline names from `aws codepipeline list-pipelines` to get the list to loop through.\r\n\r\nIs it possible using bash script and awscli and jq together?\r\n\r\nThank you\r\n\r\n",
        "link": "https://stackoverflow.com/questions/62122382/get-a-list-of-aws-pipelines-ready-for-stage-approval",
        "title": "Get a list of AWS pipelines ready for stage approval"
    },
    {
        "tags": [
            "docker",
            "maven",
            "curl",
            "jq",
            "jib"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11013727,
                    "reputation": 3522,
                    "user_id": 8090174,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/T0CMP.jpg?s=256",
                    "display_name": "nischay goyal",
                    "link": "https://stackoverflow.com/users/8090174/nischay-goyal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1590994448,
                "post_id": 62127039,
                "comment_id": 109879113,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4898652,
                    "reputation": 481,
                    "user_id": 3947391,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/20a77aa762f28a56d781e5860bc1284a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "PainPoints",
                    "link": "https://stackoverflow.com/users/3947391/painpoints"
                },
                "reply_to_user": {
                    "account_id": 11013727,
                    "reputation": 3522,
                    "user_id": 8090174,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/T0CMP.jpg?s=256",
                    "display_name": "nischay goyal",
                    "link": "https://stackoverflow.com/users/8090174/nischay-goyal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1590995094,
                "post_id": 62127039,
                "comment_id": 109879334,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1591015611,
                "last_edit_date": 1591015611,
                "creation_date": 1590995473,
                "answer_id": 62127273,
                "question_id": 62127039,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Adding a reference `Dockerfile` and you can build your own base image by creating your Dockerfile and then build it. \r\n\r\n```\r\nFROM openjdk:8-jdk-alpine\r\n\r\nRUN apk add --no-cache curl tar bash procps\r\n\r\n# Downloading and installing Maven\r\nARG MAVEN_VERSION=3.6.1\r\nARG USER_HOME_DIR=&quot;/root&quot;\r\nARG SHA=b4880fb7a3d81edd190a029440cdf17f308621af68475a4fe976296e71ff4a4b546dd6d8a58aaafba334d309cc11e638c52808a4b0e818fc0fd544226d952544\r\nARG BASE_URL=https://apache.osuosl.org/maven/maven-3/${MAVEN_VERSION}/binaries\r\n\r\nRUN mkdir -p /usr/share/maven /usr/share/maven/ref \\\r\n  &amp;&amp; echo &quot;Downlaoding maven&quot; \\\r\n  &amp;&amp; curl -fsSL -o /tmp/apache-maven.tar.gz ${BASE_URL}/apache-maven-${MAVEN_VERSION}-bin.tar.gz \\\r\n  \\\r\n  &amp;&amp; echo &quot;Checking download hash&quot; \\\r\n  &amp;&amp; echo &quot;${SHA}  /tmp/apache-maven.tar.gz&quot; | sha512sum -c - \\\r\n  \\\r\n  &amp;&amp; echo &quot;Unziping maven&quot; \\\r\n  &amp;&amp; tar -xzf /tmp/apache-maven.tar.gz -C /usr/share/maven --strip-components=1 \\\r\n  \\\r\n  &amp;&amp; echo &quot;Cleaning and setting links&quot; \\\r\n  &amp;&amp; rm -f /tmp/apache-maven.tar.gz \\\r\n  &amp;&amp; ln -s /usr/share/maven/bin/mvn /usr/bin/mvn\r\n\r\nENV MAVEN_HOME /usr/share/maven\r\nENV MAVEN_CONFIG &quot;$USER_HOME_DIR/.m2&quot;\r\n\r\n# Downloading and installing Gradle\r\n# 1- Define a constant with the version of gradle you want to install\r\nARG GRADLE_VERSION=4.0.1\r\n\r\n# 2- Define the URL where gradle can be downloaded from\r\nARG GRADLE_BASE_URL=https://services.gradle.org/distributions\r\n\r\n# 3- Define the SHA key to validate the gradle download\r\n#    obtained from here https://gradle.org/release-checksums/\r\nARG GRADLE_SHA=d717e46200d1359893f891dab047fdab98784143ac76861b53c50dbd03b44fd4\r\n\r\n# 4- Create the directories, download gradle, validate the download, install it, remove downloaded file and set links\r\nRUN mkdir -p /usr/share/gradle /usr/share/gradle/ref \\\r\n  &amp;&amp; echo &quot;Downlaoding gradle hash&quot; \\\r\n  &amp;&amp; curl -fsSL -o /tmp/gradle.zip ${GRADLE_BASE_URL}/gradle-${GRADLE_VERSION}-bin.zip \\\r\n  \\\r\n  &amp;&amp; echo &quot;Checking download hash&quot; \\\r\n  &amp;&amp; echo &quot;${GRADLE_SHA}  /tmp/gradle.zip&quot; | sha256sum -c - \\\r\n  \\\r\n  &amp;&amp; echo &quot;Unziping gradle&quot; \\\r\n  &amp;&amp; unzip -d /usr/share/gradle /tmp/gradle.zip \\\r\n   \\\r\n  &amp;&amp; echo &quot;Cleaning and setting links&quot; \\\r\n  &amp;&amp; rm -f /tmp/gradle.zip \\\r\n  &amp;&amp; ln -s /usr/share/gradle/gradle-${GRADLE_VERSION} /usr/bin/gradle\r\n\r\n# 5- Define environmental variables required by gradle\r\nENV GRADLE_VERSION 4.0.1\r\nENV GRADLE_HOME /usr/bin/gradle\r\nENV GRADLE_USER_HOME /cache\r\n\r\nENV PATH $PATH:$GRADLE_HOME/bin\r\n\r\nVOLUME $GRADLE_USER_HOME\r\n\r\nCMD [&quot;&quot;]\r\n\r\n```\r\n\r\n&gt; Ref:- https://docs.docker.com/engine/reference/builder/\r\n\r\nOnce your custom image is ready, push it to Registry and then reference it in `jib` in following manner.\r\n\r\n```\r\nmvn compile jib:build \\\r\n    -Djib.from.image=customImage\r\n```",
                "title": "Can you install command-line packages in jib docker image?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1591025260,
                "creation_date": 1591025260,
                "answer_id": 62135542,
                "question_id": 62127039,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As explained in the other answer, using a base image customized with pre-installed tools that rarely change is a good solution.\r\n\r\nAlternatively, you may put `curl` using Jib&#39;s `&lt;extraDirectories&gt;` feature, which enables adding arbitrary files to the target image. Check the [Maven][1] and [Gradle][2] docs for more details. As explained in the docs, you will also need to configure `&lt;permissions&gt;` to set executable bits to `curl`.\r\n\r\n\r\nIf you prefer, you could even set up your Maven or Gradle builds to download `curl` and unpack it. Here&#39;s an [example Jib setup][3] (showing both Maven and Gradle) from the Jib repository.\r\n\r\n\r\n  [1]: https://github.com/GoogleContainerTools/jib/tree/master/jib-maven-plugin#adding-arbitrary-files-to-the-image\r\n  [2]: https://github.com/GoogleContainerTools/jib/tree/master/jib-gradle-plugin#adding-arbitrary-files-to-the-image\r\n  [3]: https://github.com/GoogleContainerTools/jib/tree/master/examples/java-agent",
                "title": "Can you install command-line packages in jib docker image?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1591025260,
        "creation_date": 1590994303,
        "question_id": 62127039,
        "body_markdown": "I need to install command line tools like jq, curl etc in the docker image created by maven jib plugin. How can I achieve this? Any help would be greatly appreciated. Thanks.",
        "link": "https://stackoverflow.com/questions/62127039/can-you-install-command-line-packages-in-jib-docker-image",
        "title": "Can you install command-line packages in jib docker image?"
    }
]