[
    {
        "tags": [
            "arrays",
            "json",
            "path",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17191,
                    "reputation": 1897,
                    "user_id": 38234,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/39ed4fb7fcfebf84b0ebbd713f96d9a3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Pedro Sobota",
                    "link": "https://stackoverflow.com/users/38234/pedro-sobota"
                },
                "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": 1626267621,
                "post_id": 68371453,
                "comment_id": 120846764,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1626283272,
                "last_edit_date": 1626283272,
                "creation_date": 1626233909,
                "answer_id": 68371710,
                "question_id": 68371453,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your expected output is not correct as `b` is not involved int he downward path of `d` from root. You can use the `paths` functions involving `setpath()` in `--null-input` mode i.e. with `jq -n`\r\n\r\n```none\r\n( inputs | paths | select(.[-1] == &quot;d&quot;)) as $f | setpath($f; $f[:-1])\r\n```\r\n\r\nThe idea is to construct the path lane upto `d` in a variable `$f` and use the set path function to set value on the same. The part `[:-1]` trims the last entry in the array leaving the leaf node.\r\n\r\n[jqplay demo](https://jqplay.org/s/N1f8LQp1eg)",
                "title": "Substituting nodes for paths from root in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1626283272,
        "creation_date": 1626231480,
        "last_edit_date": 1626277092,
        "question_id": 68371453,
        "body_markdown": "How do I substitute a certain matching node in a tree by the path to that node from the root node using jq?\r\n\r\nUsing `walk`, only the path from the current node downwards the tree is accessible:\r\n\r\nhttps://jqplay.org/s/BVOQ-xa1JM:\r\n```jq\r\nwalk(if type == &quot;object&quot; and has(&quot;d&quot;) then .d = path(.) else . end)\r\n```\r\nInput:\r\n```\r\n{&quot;a&quot;: {&quot;b&quot;: 1, &quot;c&quot;: {&quot;d&quot;: 2}}, &quot;e&quot;: {&quot;d}\r\n```\r\nResult:\r\n```\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;b&quot;: 1,\r\n    &quot;c&quot;: {\r\n      &quot;d&quot;: []\r\n    }\r\n  },\r\n  &quot;e&quot;: {\r\n    &quot;d&quot;: []\r\n  }\r\n}\r\n```\r\nThe desired result is:\r\n```\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;b&quot;: 1,\r\n    &quot;c&quot;: {\r\n      &quot;d&quot;: [&quot;a&quot;, &quot;c&quot;]\r\n    }\r\n  },\r\n  &quot;e&quot;: {\r\n    &quot;d&quot;: [&quot;e&quot;]\r\n  }\r\n}\r\n```\r\n\r\nNote: this must not cause duplication of the full tree as in:\r\n```\r\n(paths | select(.[-1] == &quot;d&quot;)) as $f | setpath($f; $f[:-1])\r\n```\r\nWhich causes:\r\n```\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;b&quot;: 1,\r\n    &quot;c&quot;: {\r\n      &quot;d&quot;: [\r\n        &quot;a&quot;,\r\n        &quot;c&quot;\r\n      ]\r\n    }\r\n  },\r\n  &quot;e&quot;: {\r\n    &quot;d&quot;: 3\r\n  }\r\n}\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;b&quot;: 1,\r\n    &quot;c&quot;: {\r\n      &quot;d&quot;: 2\r\n    }\r\n  },\r\n  &quot;e&quot;: {\r\n    &quot;d&quot;: [\r\n      &quot;e&quot;\r\n    ]\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/68371453/substituting-nodes-for-paths-from-root-in-jq",
        "title": "Substituting nodes for paths from root in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1626262607,
                "last_edit_date": 1626262607,
                "creation_date": 1626262303,
                "answer_id": 68377254,
                "question_id": 68377085,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple `if`/`else` clause like below would suffice. For a simple boolean assertion, you could use `test`/`match` or `contains` and then add the field accordingly.\r\n\r\n```none\r\n.contexts += [ &quot;aws/&quot; + .account_id ] |  \r\nif   .directory | test(&quot;monitor&quot;) \r\nthen .contexts  += [ &quot;datadog/m01&quot; ] else . end\r\n```",
                "title": "jq conditionally add a new property based on value of another"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1626262607,
        "creation_date": 1626261566,
        "question_id": 68377085,
        "body_markdown": "I jave a bunch of definitions in json format, and I&#39;d like to process them to add a new field to a json map based on the value of another field outside the map.\r\n\r\nExample data:\r\n\r\n\r\nex01.json:\r\n```\r\n{\r\n  &quot;account_id&quot;: &quot;a01&quot;,\r\n  &quot;name&quot;: &quot;example01&quot;,\r\n  &quot;directory&quot;: &quot;path/to/something&quot;\r\n}\r\n```\r\n\r\nex02.json:\r\n```\r\n{\r\n  &quot;account_id&quot;: &quot;a01&quot;,\r\n  &quot;name&quot;: &quot;example02&quot;,\r\n  &quot;directory&quot;: &quot;path/to/monitors&quot;\r\n}\r\n```\r\n\r\nI want to do two things:\r\n\r\n 1. add a field named &quot;contexts&quot; that includes the value of the account_id, eg:\r\nex01.json\r\n```\r\n{\r\n  &quot;account_id&quot;: &quot;a01&quot;,\r\n  &quot;contexts&quot;: [\r\n    &quot;aws/a01&quot;\r\n  ],\r\n  &quot;name&quot;: &quot;example01&quot;,\r\n  &quot;directory&quot;: &quot;path/to/something&quot;\r\n}\r\n```\r\n 2. If &quot;directory&quot; contains the text &quot;monitors&quot;, I&#39;d like to add another item to contexts, eg:\r\nex02.json:\r\n```\r\n{\r\n  &quot;account_id&quot;: &quot;a01&quot;,\r\n  &quot;contexts&quot;: [\r\n    &quot;aws/a01&quot;,\r\n    &quot;datadog/m01&quot;\r\n  ],\r\n  &quot;name&quot;: &quot;example02&quot;,\r\n  &quot;directory&quot;: &quot;path/to/monitors&quot;\r\n}\r\n```\r\n\r\nFor (1), I can set the contexts field from the account_id like this:\r\n```\r\njq &#39;.contexts += [&quot;aws/&quot; + .account_id]&#39; ex02.json\r\n``` \r\n\r\nHowever, I can&#39;t figure out how to do (2). In particular, I&#39;m struggling to understand the if/then/else/end construct and how to use it in assignment, especially trying to use it with `test()` to check for the text &quot;monitors&quot;.\r\n\r\nCan anyone point me in the right direction?",
        "link": "https://stackoverflow.com/questions/68377085/jq-conditionally-add-a-new-property-based-on-value-of-another",
        "title": "jq conditionally add a new property based on value of another"
    },
    {
        "tags": [
            "json",
            "bash",
            "amazon-web-services",
            "jq",
            "aws-cli"
        ],
        "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": 2,
                "creation_date": 1626270039,
                "post_id": 68379064,
                "comment_id": 120847853,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10946150,
                    "reputation": 794,
                    "user_id": 8044204,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/LGsuq.jpg?s=256",
                    "display_name": "Melih",
                    "link": "https://stackoverflow.com/users/8044204/melih"
                },
                "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": 1626270399,
                "post_id": 68379064,
                "comment_id": 120847994,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1626270302,
        "creation_date": 1626269429,
        "last_edit_date": 1626270302,
        "question_id": 68379064,
        "body_markdown": "I&#39;m not running the commands below on terminal directly, but I run them from a bash script.\r\n\r\nI need to copy tags of an rds cluster instance to its snapshot. First I&#39;m fetching the tags like this:\r\n\r\n    aws rds list-tags-for-resource --resource-name $cluster_arn\r\n\r\nWhich returns a json like this:\r\n\r\n    {&quot;TagList&quot;: [{ &quot;Key&quot;: &quot;owner&quot;, &quot;Value&quot;: &quot;me&quot; },{ &quot;Key&quot;: &quot;Project&quot;, &quot;Value&quot;: &quot;my_project&quot; }]}\r\n\r\nInstead, I pass the command above to jq to get only the list of tags:\r\n\r\n\r\n    cluster_tags=$(aws rds list-tags-for-resource --resource-name $cluster_arn | jq -r &#39;.TagList&#39;)\r\n\r\nWhich returns:\r\n\r\n    [{ &quot;Key&quot;: &quot;owner&quot;, &quot;Value&quot;: &quot;me&quot; },{ &quot;Key&quot;: &quot;Project&quot;, &quot;Value&quot;: &quot;my_project&quot; }]\r\n\r\n\r\nThen I pass these tags on creation of snapshot:\r\n\r\n    aws rds create-db-cluster-snapshot --db-cluster-identifier $cluster_id --db-cluster-snapshot-identifier $cluster_snapshot_id --tags $cluster_tags\r\n\r\nHowever, I&#39;m getting this error:\r\n\r\n    Error parsing parameter &#39;--tags&#39;: Invalid JSON:\r\n    [\r\n\r\nHow can I solve this problem *without creating a JSON file* ?",
        "link": "https://stackoverflow.com/questions/68379064/aws-cli-passing-json-object-to-tags-gives-error",
        "title": "AWS CLI - passing JSON object to --tags gives error"
    },
    {
        "tags": [
            "json",
            "unique",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 18747180,
                    "reputation": 14590,
                    "user_id": 13669048,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GhUXwT3zrZ7bWxVTcoUB4Bznit30dadkyBUeFEdSw=k-s256",
                    "display_name": "Always Helping",
                    "link": "https://stackoverflow.com/users/13669048/always-helping"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1626319973,
                "post_id": 68387526,
                "comment_id": 120862724,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7328064,
                    "reputation": 8729,
                    "user_id": 5581893,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/hnwBo.jpg?s=256",
                    "display_name": "Dan D",
                    "link": "https://stackoverflow.com/users/5581893/dan-d"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1626319975,
                "post_id": 68387526,
                "comment_id": 120862725,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1626324907,
                "post_id": 68387526,
                "comment_id": 120863584,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22213045,
                    "reputation": 23,
                    "user_id": 16451875,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJyglM_e0M2v4dbsfn-njL1MoS9A9uIhWtUZ4e-s=k-s256",
                    "display_name": "tsimmons",
                    "link": "https://stackoverflow.com/users/16451875/tsimmons"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1626985833,
                "post_id": 68387526,
                "comment_id": 121044650,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1626324206,
                "last_edit_date": 1626324206,
                "creation_date": 1626322064,
                "answer_id": 68387784,
                "question_id": 68387526,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "- Here&#39;s how it can be done using reducer.\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 input = {\r\n      &quot;data&quot;: {\r\n        &quot;results&quot;: [{\r\n            &quot;event&quot;: {\r\n              &quot;biking&quot;: {\r\n                &quot;startTime&quot;: 12,\r\n                &quot;id&quot;: &quot;a&quot;,\r\n                &quot;run&quot;: &quot;x&quot;\r\n              }\r\n            },\r\n            &quot;displayName&quot;: &quot;Alex&quot;\r\n          },\r\n          {\r\n            &quot;event&quot;: {\r\n              &quot;biking&quot;: {\r\n                &quot;startTime&quot;: 10,\r\n                &quot;id&quot;: &quot;b&quot;,\r\n                &quot;run&quot;: &quot;x&quot;\r\n              }\r\n            },\r\n            &quot;displayName&quot;: &quot;Adam&quot;\r\n          },\r\n          {\r\n            &quot;event&quot;: {\r\n              &quot;biking&quot;: {\r\n                &quot;startTime&quot;: 11,\r\n                &quot;id&quot;: &quot;c&quot;,\r\n                &quot;run&quot;: &quot;y&quot;\r\n              }\r\n            },\r\n            &quot;displayName&quot;: &quot;Aaron&quot;\r\n          }\r\n        ]\r\n      }\r\n    };\r\n    const output = {\r\n      data: {}\r\n    };\r\n    output.data.results = Object.values(input.data.results.reduce((r, o) =&gt; {\r\n      r[o.event.biking.run] =\r\n        (r[o.event.biking.run] &amp;&amp;\r\n          r[o.event.biking.run].event.biking.startTime &gt; o.event.biking.startTime) ? r[o.event.biking.run] : o\r\n      return r\r\n    }, {}));\r\n    console.log(output);\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n- Credits -&gt; https://stackoverflow.com/a/56901839/8057127",
                "title": "Remove duplicate objects in JSON array with jq based on specific criteria"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1626324334,
                "creation_date": 1626324334,
                "answer_id": 68388038,
                "question_id": 68387526,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward jq solution:\r\n```\r\n.data.results |=\r\n  (group_by(.event.biking.run)\r\n   | map(max_by(.event.biking.startTime)))\r\n```\r\nIt uses `group_by` to group by &quot;run&quot;, and then `max_by` to select the desired event.",
                "title": "Remove duplicate objects in JSON array with jq based on specific criteria"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1626451427,
                "creation_date": 1626451427,
                "answer_id": 68412074,
                "question_id": 68387526,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This would work \r\n\r\n    const result = [\r\n      ...new Map(\r\n        obj.data.results.map((item) =&gt; [item[&quot;event&quot;][&quot;biking&quot;][&quot;run&quot;], item])\r\n      ).values()\r\n    ];\r\n\r\n[DEMO][1]\r\n\r\nThis is based on [helprjs][2] removeDuplicates. \r\n\r\n\r\n  [1]: https://codesandbox.io/s/white-butterfly-eml2r?file=/src/App.js\r\n  [2]: https://www.npmjs.com/package/helprjs",
                "title": "Remove duplicate objects in JSON array with jq based on specific criteria"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1626985782,
        "creation_date": 1626319752,
        "last_edit_date": 1626985782,
        "question_id": 68387526,
        "body_markdown": "I have the following data where I want entire objects removed based on duplicate values of the `&quot;run&quot;` key, while keeping the object with the largest `&quot;startTime&quot;` number:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;results&quot;: [\r\n      {\r\n        &quot;event&quot;: {\r\n          &quot;biking&quot;: {\r\n            &quot;startTime&quot;: 12,\r\n            &quot;id&quot;: &quot;a&quot;,\r\n            &quot;run&quot;: &quot;x&quot;\r\n          }\r\n        },\r\n        &quot;displayName&quot;: &quot;Alex&quot;\r\n      },\r\n      {\r\n        &quot;event&quot;: {\r\n          &quot;biking&quot;: {\r\n            &quot;startTime&quot;: 10,\r\n            &quot;id&quot;: &quot;b&quot;,\r\n            &quot;run&quot;: &quot;x&quot;\r\n          }\r\n        },\r\n        &quot;displayName&quot;: &quot;Adam&quot;\r\n      },\r\n      {\r\n        &quot;event&quot;: {\r\n          &quot;biking&quot;: {\r\n            &quot;startTime&quot;: 11,\r\n            &quot;id&quot;: &quot;c&quot;,\r\n            &quot;run&quot;: &quot;y&quot;\r\n          }\r\n        },\r\n        &quot;displayName&quot;: &quot;Aaron&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI&#39;ve been trying to finagle `unique` with `jq` but can&#39;t quite get what I want.  My intended result is this:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;results&quot;: [\r\n      {\r\n        &quot;event&quot;: {\r\n          &quot;biking&quot;: {\r\n            &quot;startTime&quot;: 12,\r\n            &quot;id&quot;: &quot;a&quot;,\r\n            &quot;run&quot;: &quot;x&quot;\r\n          }\r\n        },\r\n        &quot;displayName&quot;: &quot;Alex&quot;\r\n      },\r\n      {\r\n        &quot;event&quot;: {\r\n          &quot;biking&quot;: {\r\n            &quot;startTime&quot;: 11,\r\n            &quot;id&quot;: &quot;c&quot;,\r\n            &quot;run&quot;: &quot;y&quot;\r\n          }\r\n        },\r\n        &quot;displayName&quot;: &quot;Aaron&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI was trying to use `unique` because I want to keep only 1 of each `&quot;run&quot;:` ids where in a larger list I might have three `x`, two `y`, and four `z`.  I&#39;d want to keep one `x`, `y`, and `z` in this case based on the largest `&quot;startTime&quot;`.",
        "link": "https://stackoverflow.com/questions/68387526/remove-duplicate-objects-in-json-array-with-jq-based-on-specific-criteria",
        "title": "Remove duplicate objects in JSON array with jq based on specific criteria"
    },
    {
        "tags": [
            "json",
            "bash",
            "dictionary",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1626373179,
                "last_edit_date": 1626373179,
                "creation_date": 1626328587,
                "answer_id": 68388630,
                "question_id": 68388431,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following solves the problem as originally stated, but the &quot;expected&quot; output as shown does not quite match the stated problem.\r\n\r\n\r\n```\r\necho ${in} | jq -c &#39;\r\n  . as $dict\r\n  | map_values(reduce (..|strings) as $v (.;\r\n                       . + $dict[$v] ))\r\n&#39;\r\n```\r\nproduces (after some manual reformatting for clarity):\r\n```\r\n{&quot;bar&quot;:[[&quot;re&quot;,&quot;de&quot;],[&quot;zoo&quot;]],\r\n  &quot;do&quot;:[[&quot;bar&quot;,&quot;baz&quot;],[&quot;re&quot;,&quot;de&quot;],[&quot;re&quot;]],\r\n &quot;baz&quot;:[[&quot;re&quot;],[&quot;zoo&quot;]],&quot;re&quot;:[[&quot;zoo&quot;]]}\r\n```\r\n\r\nIf some kind of recursive lookup is needed, then please reformulate the problem statement, being sure to avoid infinite loops.",
                "title": "jq add list to object list until condition"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1626420153,
        "creation_date": 1626327123,
        "last_edit_date": 1626372096,
        "question_id": 68388431,
        "body_markdown": "**Background**\r\n\r\nI have an object with each value being a nested list of only strings. For each string value within the nested list, look up the string value within the object and add all of its values into the current value. \r\n\r\nHere&#39;s what I have so far:\r\n\r\n```\r\n#!/bin/bash\r\n\r\nin=$(jq -n &#39;{\r\n  &quot;bar&quot;: [[&quot;re&quot;, &quot;de&quot;]],\r\n  &quot;do&quot;: [[&quot;bar&quot;,&quot;baz&quot;]],\r\n  &quot;baz&quot;: [[&quot;re&quot;]],\r\n  &quot;re&quot;: [[&quot;zoo&quot;]]\r\n}&#39;)\r\n\r\necho &quot;expected:&quot;\r\njq -n &#39;{\r\n  &quot;bar&quot;: [[&quot;re&quot;, &quot;de&quot;], [&quot;zoo&quot;]],\r\n  &quot;do&quot;: [[&quot;bar&quot;,&quot;baz&quot;], [&quot;re&quot;, &quot;de&quot;], [&quot;re&quot;], [&quot;zoo&quot;]],\r\n  &quot;baz&quot;: [[&quot;re&quot;], [&quot;zoo&quot;]],\r\n  &quot;re&quot;: [[&quot;zoo&quot;]]\r\n}&#39;\r\n\r\necho &quot;actual:&quot;\r\necho ${in} | jq &#39;. as $origin \r\n  | map_values( . + \r\n    until(\r\n      length == 0;\r\n      (. | flatten | map($origin[.]) | map(select( . != [[]] )) | add ) \r\n    )\r\n  )&#39;\r\n```\r\n\r\n**Problem:**\r\n\r\nThe output is the exact same as the input `$in`. If the `until()` function is removed from the statement, then the output correctly outputs one iteration. Although I want to recursively lookup the output strings within the object and add the lookup value until the lookup value is empty or non-existing. \r\n\r\nFor example, the key `do` has a value of `[[&quot;bar&quot;,&quot;baz&quot;]]`. If we iterate through the values of `do` we come across `baz`. The value of `baz` within the object is `[[&quot;re&quot;]]`. Add `baz`&#39;s value `[&quot;re&quot;]` to `do` so that `do` equals: `[[&quot;bar&quot;,&quot;baz&quot;], [&quot;re&quot;]]`. Since `re` IS a key within the object, add the value of `[&quot;re&quot;]` which is `[&quot;zoo&quot;]`. Since `[&quot;zoo&quot;]` is NOT a key within the object finish `baz` and continue to the next key within the object.",
        "link": "https://stackoverflow.com/questions/68388431/jq-add-list-to-object-list-until-condition",
        "title": "jq add list to object list until condition"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1626345959,
                "last_edit_date": 1626345959,
                "creation_date": 1626344480,
                "answer_id": 68392020,
                "question_id": 68391954,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The whole thing can be done in `jq` itself, which can slurp an input file and the contents of which can be used to update another file as below. The `tojson` function encodes your already existing string as JSON string with escapes added\r\n\r\n```bash\r\njq --slurpfile gc global_config.json &#39;{ config: $gc[0] | tojson }&#39; env_config.json\r\n```\r\n\r\nIf you know, there isn&#39;t a stream of objects (a static file) in the config, you could use `--argfile` and drop the `[0]` on `$gc` variable.",
                "title": "Use contents of a different JSON as an input to modify using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1626347947,
                "creation_date": 1626347947,
                "answer_id": 68392852,
                "question_id": 68391954,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can add an intermediary temp file:\r\n\r\n    jq -c &#39;.|tostring&#39; global_config.json &gt; temp.json\r\n\r\nEscape the backslashes:\r\n\r\n    sed -i &#39;s/\\\\/\\\\\\\\/g&#39; temp.json\r\n    global_config=$(cat temp.json)\r\n\r\nThen the following will work, as only one backslash will be removed\r\n\r\n    sed  -i &quot;s/\\&quot;GLOBAL_CONFIG\\&quot;/$global_config/1&quot; env_config.json\r\n\r\n",
                "title": "Use contents of a different JSON as an input to modify using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1626347947,
        "creation_date": 1626344212,
        "last_edit_date": 1626345860,
        "question_id": 68391954,
        "body_markdown": "I have a config file as follows:\r\n\r\n\r\n    env_config.json:\r\n    \r\n    {\r\n      &quot;config&quot;:&quot;GLOBAL_CONFIG&quot;\r\n    }\r\n\r\n    global_config.json:\r\n    {\r\n      &quot;key&quot;:&quot;value&quot;\r\n    }\r\n\r\n\r\nbefore deployment, I need to change the value of GLOBAL_CONFIG with an stringify json of global_config.json. so env_config.json should look like this:\r\n\r\n    env_config.json\r\n    {\r\n      &quot;config&quot;:&quot;{\\&quot;key\\&quot;:\\&quot;value\\&quot;}&quot;\r\n    }\r\n\r\n\r\nto achieve the above output I did the following:\r\n\r\n    global_config=$(jq -c &#39;.|tostring&#39;  global_config.json)\r\n    sed  -i &quot;s/\\&quot;GLOBAL_CONFIG\\&quot;/$global_config/1&quot; env_config.json\r\n\r\nUnfortunately, this unescape the double quotes which makes my final JSON invalid\r\n\r\n \r\n\r\n    {\r\n       &quot;config&quot;:&quot;{&quot;key&quot;:&quot;value&quot;}&quot;.   #please note the inner double quotes are not escaped anymore\r\n    }\r\n\r\nIs there a way to make sure the replacement with `sed` carries out with the escaped double quotes?",
        "link": "https://stackoverflow.com/questions/68391954/use-contents-of-a-different-json-as-an-input-to-modify-using-jq",
        "title": "Use contents of a different JSON as an input to modify using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1626353585,
                "creation_date": 1626353585,
                "answer_id": 68394222,
                "question_id": 68394005,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [assignment][1] to add the zeta field where you want it, and [`del`][2] to remove it where you don&#39;t want it anymore.\r\n\r\n```\r\njq &#39;.alpha.zeta=.zeta|del(.zeta)&#39; input.json\r\n```\r\n\r\n[1]: https://stedolan.github.io/jq/manual/#Assignment\r\n[2]: https://stedolan.github.io/jq/manual/#del(path_expression)",
                "title": "When given an Object with two sibling properties, using jq how do I create a new Object where the sibling property is moved to be a child property?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1626354489,
                "creation_date": 1626354489,
                "answer_id": 68394451,
                "question_id": 68394005,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    $ jq &#39;{alpha: (.alpha + {zeta})}&#39; tmp.json\r\n    {\r\n      &quot;alpha&quot;: {\r\n        &quot;beta&quot;: &quot;gamma&quot;,\r\n        &quot;delta&quot;: &quot;epsilon&quot;,\r\n        &quot;zeta&quot;: {\r\n          &quot;eta&quot;: &quot;theta&quot;,\r\n          &quot;iota&quot;: &quot;kappa&quot;\r\n        }\r\n      }\r\n    }\r\n\r\n`{zeta}` is shorthand for `{zeta: .zeta}`.",
                "title": "When given an Object with two sibling properties, using jq how do I create a new Object where the sibling property is moved to be a child property?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1626354489,
        "creation_date": 1626352681,
        "question_id": 68394005,
        "body_markdown": "I have an array of Objects in the following form:\r\n\r\n```\r\n{\r\n    &quot;alpha&quot;: {\r\n        &quot;beta&quot;: &quot;gamma&quot;,\r\n        &quot;delta&quot;: &quot;epsilon&quot;\r\n    },\r\n    &quot;zeta&quot;: {\r\n        &quot;eta&quot;: &quot;theta&quot;,\r\n        &quot;iota&quot;: &quot;kappa&quot;\r\n    }\r\n}\r\n```\r\n\r\nUsing `jq`, I would like to transform this Object to be in the following form:\r\n\r\n```\r\n{\r\n    &quot;alpha&quot;: {\r\n        &quot;beta&quot;: &quot;gamma&quot;,\r\n        &quot;delta&quot;: &quot;epsilon&quot;,\r\n        &quot;zeta&quot;: {\r\n            &quot;eta&quot;: &quot;theta&quot;,\r\n            &quot;iota&quot;: &quot;kappa&quot;\r\n        }\r\n    },\r\n}\r\n```\r\n\r\nHow do I do that? I&#39;m not especially familiar with `jq&#39;s` syntax and the manual isn&#39;t presenting any clear answers, at least as far as I can see.\r\n\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/68394005/when-given-an-object-with-two-sibling-properties-using-jq-how-do-i-create-a-new",
        "title": "When given an Object with two sibling properties, using jq how do I create a new Object where the sibling property is moved to be a child property?"
    },
    {
        "tags": [
            "json",
            "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": 3,
                "creation_date": 1626358676,
                "post_id": 68395321,
                "comment_id": 120876554,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18748342,
                    "reputation": 41,
                    "user_id": 13669924,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/329af62deff01aeb40903ca2e4b3bdda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "G.kalyan",
                    "link": "https://stackoverflow.com/users/13669924/g-kalyan"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1626359157,
                "post_id": 68395321,
                "comment_id": 120876803,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18748342,
                    "reputation": 41,
                    "user_id": 13669924,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/329af62deff01aeb40903ca2e4b3bdda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "G.kalyan",
                    "link": "https://stackoverflow.com/users/13669924/g-kalyan"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1626362944,
                "post_id": 68395321,
                "comment_id": 120878579,
                "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": 1626363234,
                "post_id": 68395321,
                "comment_id": 120878718,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1626363286,
                "post_id": 68395321,
                "comment_id": 120878740,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18748342,
                    "reputation": 41,
                    "user_id": 13669924,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/329af62deff01aeb40903ca2e4b3bdda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "G.kalyan",
                    "link": "https://stackoverflow.com/users/13669924/g-kalyan"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1626365778,
                "post_id": 68395321,
                "comment_id": 120879769,
                "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": 1626366181,
                "post_id": 68395321,
                "comment_id": 120879922,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1626387461,
                "creation_date": 1626387461,
                "answer_id": 68401359,
                "question_id": 68395321,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n..\r\n| objects\r\n| select(has(&quot;created&quot;) and any(.items[]; .toString == &quot;Code Review&quot;))\r\n| .created\r\n```\r\n\r\n#### Research Effort\r\nFor future reference, please note that, since you&#39;ve been a member of the SO community for over a year and have asked other questions, you should be familiar with the SO guidelines for asking appropriate questions.  Apart from the &quot;miminum reproducible example&quot; guidelines already mentioned on this page, there should be some evidence of &quot;research effort&quot; as per\r\nhttps://meta.stackoverflow.com/questions/261592/how-much-research-effort-is-expected-of-stack-overflow-users",
                "title": "Conditions In Jq tool"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1626387461,
        "creation_date": 1626357824,
        "last_edit_date": 1626385454,
        "question_id": 68395321,
        "body_markdown": "Greetings for the day!\r\n\r\nhow to get &quot;created&quot; value if &quot;toString&quot; value is Code Review from below json code.\r\n\r\n\r\nJson code:-\r\n==========\r\n```\r\n  {\r\n  &quot;expand&quot;: &quot;renderedFields,names,schema,operations,editmeta,changelog,versionedRepresentations&quot;,\r\n  &quot;id&quot;: &quot;562940&quot;,\r\n  &quot;self&quot;: &quot;https://example/rest/api/2/issue/562940&quot;,\r\n  &quot;key&quot;: &quot;TPR-13098&quot;,\r\n  &quot;fields&quot;: {\r\n    &quot;customfield_17384&quot;: null,\r\n    &quot;customfield_17379&quot;: null,\r\n    &quot;customfield_17378&quot;: null,\r\n    &quot;labels&quot;: [\r\n      \r\n    ],\r\n    &quot;customfield_15505&quot;: null,\r\n    &quot;issuelinks&quot;: [\r\n      \r\n    ],\r\n    &quot;customfield_11709&quot;: null,\r\n    &quot;assignee&quot;: {\r\n      &quot;self&quot;: &quot;https://example/rest/api/2/user?username=example&quot;,\r\n      &quot;name&quot;: &quot;example&quot;,\r\n      &quot;key&quot;: &quot;example&quot;,\r\n      &quot;emailAddress&quot;: &quot;example@sample&quot;,\r\n      &quot;avatarUrls&quot;: {\r\n        &quot;48x48&quot;: &quot;https://example/secure/useravatar?ownerId=example&amp;avatarId=12908&quot;,\r\n        &quot;24x24&quot;: &quot;https://example/secure/useravatar?size=small&amp;ownerId=example&amp;avatarId=12908&quot;,\r\n        &quot;16x16&quot;: &quot;https://example/secure/useravatar?size=xsmall&amp;ownerId=example&amp;avatarId=12908&quot;,\r\n        &quot;32x32&quot;: &quot;https://example/secure/useravatar?size=medium&amp;ownerId=example&amp;avatarId=12908&quot;\r\n      },\r\n      &quot;displayName&quot;: &quot;example&quot;,\r\n      &quot;active&quot;: true,\r\n      &quot;timeZone&quot;: &quot;Asia/Kolkata&quot;\r\n    },\r\n    &quot;components&quot;: [\r\n      {\r\n        &quot;self&quot;: &quot;https://example/rest/api/2/component/17139&quot;,\r\n        &quot;id&quot;: &quot;17139&quot;,\r\n        &quot;name&quot;: &quot;Others&quot;\r\n      }\r\n    ],\r\n    &quot;customfield_17366&quot;: null,\r\n    &quot;customfield_11935&quot;: [\r\n      {\r\n        &quot;self&quot;: &quot;https://example/rest/api/2/user?username=testuser&quot;,\r\n        &quot;name&quot;: &quot;testuser&quot;,\r\n        &quot;key&quot;: &quot;testuser&quot;,\r\n        &quot;emailAddress&quot;: &quot;testuser@sample&quot;,\r\n        &quot;avatarUrls&quot;: {\r\n          &quot;48x48&quot;: &quot;https://example/secure/useravatar?avatarId=15907&quot;,\r\n          &quot;24x24&quot;: &quot;https://example/secure/useravatar?size=small&amp;avatarId=15907&quot;,\r\n          &quot;16x16&quot;: &quot;https://example/secure/useravatar?size=xsmall&amp;avatarId=15907&quot;,\r\n          &quot;32x32&quot;: &quot;https://example/secure/useravatar?size=medium&amp;avatarId=15907&quot;\r\n        },\r\n        &quot;displayName&quot;: &quot;testuser&quot;,\r\n        &quot;active&quot;: true,\r\n        &quot;timeZone&quot;: &quot;Asia/Kolkata&quot;\r\n      }\r\n    ],\r\n    &quot;customfield_11937&quot;: null,\r\n    &quot;customfield_17351&quot;: &quot;2021-06-30&quot;,\r\n    &quot;subtasks&quot;: [\r\n      \r\n    ],\r\n    &quot;customfield_17352&quot;: null,\r\n    &quot;customfield_17359&quot;: null,\r\n    &quot;reporter&quot;: {\r\n      &quot;self&quot;: &quot;https://example/rest/api/2/user?username=testuser&quot;,\r\n      &quot;name&quot;: &quot;testuser&quot;,\r\n      &quot;key&quot;: &quot;testuser&quot;,\r\n      &quot;emailAddress&quot;: &quot;testuser@sample&quot;,\r\n      &quot;avatarUrls&quot;: {\r\n        &quot;48x48&quot;: &quot;https://example/secure/useravatar?avatarId=15907&quot;,\r\n        &quot;24x24&quot;: &quot;https://example/secure/useravatar?size=small&amp;avatarId=15907&quot;,\r\n        &quot;16x16&quot;: &quot;https://example/secure/useravatar?size=xsmall&amp;avatarId=15907&quot;,\r\n        &quot;32x32&quot;: &quot;https://example/secure/useravatar?size=medium&amp;avatarId=15907&quot;\r\n      },\r\n      &quot;displayName&quot;: &quot;testuser&quot;,\r\n      &quot;active&quot;: true,\r\n      &quot;timeZone&quot;: &quot;Asia/Kolkata&quot;\r\n    },\r\n    &quot;customfield_17357&quot;: null,\r\n    &quot;customfield_16700&quot;: null,\r\n    &quot;customfield_11920&quot;: null,\r\n    &quot;customfield_11922&quot;: null,\r\n    &quot;progress&quot;: {\r\n      &quot;progress&quot;: 0,\r\n      &quot;total&quot;: 0\r\n    },\r\n    &quot;worklog&quot;: {\r\n      &quot;startAt&quot;: 0,\r\n      &quot;maxResults&quot;: 20,\r\n      &quot;total&quot;: 0,\r\n      &quot;worklogs&quot;: [\r\n        \r\n      ]\r\n    },\r\n    &quot;issuetype&quot;: {\r\n      &quot;self&quot;: &quot;https://example/rest/api/2/issuetype/12506&quot;,\r\n      &quot;id&quot;: &quot;12506&quot;,\r\n      &quot;description&quot;: &quot;&quot;,\r\n      &quot;iconUrl&quot;: &quot;https://example/secure/viewavatar?size=xsmall&amp;avatarId=10306&amp;avatarType=issuetype&quot;,\r\n      &quot;name&quot;: &quot;Work Item&quot;,\r\n      &quot;subtask&quot;: false,\r\n      &quot;avatarId&quot;: 10306\r\n    },\r\n    &quot;customfield_17102&quot;: null,\r\n    &quot;customfield_17347&quot;: null,\r\n    &quot;project&quot;: {\r\n      &quot;self&quot;: &quot;https://example/rest/api/2/project/14309&quot;,\r\n      &quot;id&quot;: &quot;14309&quot;,\r\n      &quot;key&quot;: &quot;TPR&quot;,\r\n      &quot;name&quot;: &quot;TallyPrime&quot;,\r\n      &quot;projectTypeKey&quot;: &quot;software&quot;,\r\n      &quot;avatarUrls&quot;: {\r\n        &quot;48x48&quot;: &quot;https://example/secure/projectavatar?avatarId=10703&quot;,\r\n        &quot;24x24&quot;: &quot;https://example/secure/projectavatar?size=small&amp;avatarId=10703&quot;,\r\n        &quot;16x16&quot;: &quot;https://example/secure/projectavatar?size=xsmall&amp;avatarId=10703&quot;,\r\n        &quot;32x32&quot;: &quot;https://example/secure/projectavatar?size=medium&amp;avatarId=10703&quot;\r\n      }\r\n    },\r\n    &quot;customfield_17346&quot;: null,\r\n    &quot;customfield_17103&quot;: null,\r\n    &quot;customfield_17345&quot;: &quot;-&quot;,\r\n    &quot;customfield_15602&quot;: null,\r\n    &quot;customfield_11486&quot;: null,\r\n    &quot;customfield_15600&quot;: null,\r\n    &quot;customfield_15601&quot;: null,\r\n    &quot;customfield_16806&quot;: null,\r\n    &quot;customfield_16804&quot;: null,\r\n    &quot;customfield_11910&quot;: null,\r\n    &quot;customfield_16803&quot;: null,\r\n    &quot;customfield_11913&quot;: &quot;2021-06-28&quot;,\r\n    &quot;customfield_11912&quot;: null,\r\n    &quot;customfield_11915&quot;: &quot;2021-06-28&quot;,\r\n    &quot;resolutiondate&quot;: null,\r\n    &quot;customfield_11914&quot;: null,\r\n    &quot;watches&quot;: {\r\n      &quot;self&quot;: &quot;https://example/rest/api/2/issue/TPR-13098/watchers&quot;,\r\n      &quot;watchCount&quot;: 1,\r\n      &quot;isWatching&quot;: false\r\n    },\r\n    &quot;customfield_16002&quot;: null,\r\n    &quot;customfield_17333&quot;: null,\r\n    &quot;customfield_17331&quot;: 0.0,\r\n    &quot;customfield_17330&quot;: null,\r\n    &quot;customfield_16006&quot;: null,\r\n    &quot;customfield_16005&quot;: null,\r\n    &quot;customfield_16003&quot;: null,\r\n    &quot;customfield_16802&quot;: null,\r\n    &quot;customfield_16009&quot;: null,\r\n    &quot;customfield_16801&quot;: null,\r\n    &quot;customfield_16800&quot;: null,\r\n    &quot;customfield_17339&quot;: null,\r\n    &quot;customfield_16007&quot;: null,\r\n    &quot;customfield_17338&quot;: null,\r\n    &quot;updated&quot;: &quot;2021-06-29T17:40:13.000+0530&quot;,\r\n    &quot;customfield_17322&quot;: null,\r\n    &quot;customfield_17321&quot;: null,\r\n    &quot;timeoriginalestimate&quot;: null,\r\n    &quot;customfield_17326&quot;: null,\r\n    &quot;description&quot;: &quot;Clean up of JsonElem::GetOwnName as it is duplicate of JsonElem::GetKey.&quot;,\r\n    &quot;customfield_10010&quot;: &quot;0|i2he8j:&quot;,\r\n    &quot;customfield_17323&quot;: null,\r\n    &quot;customfield_11344&quot;: 0.0,\r\n    &quot;customfield_17329&quot;: null,\r\n    &quot;timetracking&quot;: {\r\n      \r\n    },\r\n    &quot;customfield_15700&quot;: {\r\n      &quot;self&quot;: &quot;https://example/rest/api/2/customFieldOption/16104&quot;,\r\n      &quot;value&quot;: &quot;Thank you&quot;,\r\n      &quot;id&quot;: &quot;16104&quot;\r\n    },\r\n    &quot;customfield_10005&quot;: null,\r\n    &quot;customfield_14726&quot;: null,\r\n    &quot;customfield_10006&quot;: null,\r\n    &quot;customfield_14724&quot;: null,\r\n    &quot;customfield_14725&quot;: null,\r\n    &quot;summary&quot;: &quot;Clean up of GetOwnName from JsonElem class&quot;,\r\n    &quot;customfield_16101&quot;: null,\r\n    &quot;customfield_17311&quot;: null,\r\n    &quot;customfield_16100&quot;: null,\r\n    &quot;customfield_17310&quot;: null,\r\n    &quot;customfield_16103&quot;: null,\r\n    &quot;customfield_16102&quot;: null,\r\n    &quot;customfield_17312&quot;: null,\r\n    &quot;customfield_14722&quot;: null,\r\n    &quot;customfield_14723&quot;: null,\r\n    &quot;customfield_17318&quot;: null,\r\n    &quot;customfield_14721&quot;: null,\r\n    &quot;customfield_11204&quot;: null,\r\n    &quot;customfield_11205&quot;: &quot;0.0&quot;,\r\n    &quot;environment&quot;: null,\r\n    &quot;customfield_11206&quot;: 0.0,\r\n    &quot;customfield_10118&quot;: null,\r\n    &quot;duedate&quot;: null,\r\n    &quot;comment&quot;: {\r\n      &quot;comments&quot;: [\r\n        \r\n      ],\r\n      &quot;maxResults&quot;: 0,\r\n      &quot;total&quot;: 0,\r\n      &quot;startAt&quot;: 0\r\n    },\r\n    &quot;customfield_17300&quot;: null,\r\n    &quot;customfield_17304&quot;: &quot;3.Coding&quot;,\r\n    &quot;customfield_17303&quot;: null,\r\n    &quot;fixVersions&quot;: [\r\n      {\r\n        &quot;self&quot;: &quot;https://example/rest/api/2/version/18013&quot;,\r\n        &quot;id&quot;: &quot;18013&quot;,\r\n        &quot;description&quot;: &quot;This is for Release B1 of GST Revamp planned as part of TallyPrime&quot;,\r\n        &quot;name&quot;: &quot;TallyPrime Release 3.0&quot;,\r\n        &quot;archived&quot;: false,\r\n        &quot;released&quot;: false\r\n      }\r\n    ],\r\n    &quot;customfield_17301&quot;: {\r\n      &quot;self&quot;: &quot;https://example/rest/api/2/customFieldOption/18133&quot;,\r\n      &quot;value&quot;: &quot;Client&quot;,\r\n      &quot;id&quot;: &quot;18133&quot;\r\n    },\r\n    &quot;customfield_15800&quot;: null,\r\n    &quot;customfield_17307&quot;: {\r\n      &quot;self&quot;: &quot;https://example/rest/api/2/user?username=example&quot;,\r\n      &quot;name&quot;: &quot;example&quot;,\r\n      &quot;key&quot;: &quot;example&quot;,\r\n      &quot;emailAddress&quot;: &quot;example@sample&quot;,\r\n      &quot;avatarUrls&quot;: {\r\n        &quot;48x48&quot;: &quot;https://example/secure/useravatar?ownerId=example&amp;avatarId=12908&quot;,\r\n        &quot;24x24&quot;: &quot;https://example/secure/useravatar?size=small&amp;ownerId=example&amp;avatarId=12908&quot;,\r\n        &quot;16x16&quot;: &quot;https://example/secure/useravatar?size=xsmall&amp;ownerId=example&amp;avatarId=12908&quot;,\r\n        &quot;32x32&quot;: &quot;https://example/secure/useravatar?size=medium&amp;ownerId=example&amp;avatarId=12908&quot;\r\n      },\r\n      &quot;displayName&quot;: &quot;example&quot;,\r\n      &quot;active&quot;: true,\r\n      &quot;timeZone&quot;: &quot;Asia/Kolkata&quot;\r\n    },\r\n    &quot;customfield_17305&quot;: null,\r\n    &quot;customfield_14704&quot;: null,\r\n    &quot;customfield_14705&quot;: null,\r\n    &quot;timeestimate&quot;: null,\r\n    &quot;status&quot;: {\r\n      &quot;self&quot;: &quot;https://example/rest/api/2/status/12606&quot;,\r\n      &quot;description&quot;: &quot;&quot;,\r\n      &quot;iconUrl&quot;: &quot;https://example/images/icons/statuses/generic.png&quot;,\r\n      &quot;name&quot;: &quot;Code Review&quot;,\r\n      &quot;id&quot;: &quot;12606&quot;,\r\n      &quot;statusCategory&quot;: {\r\n        &quot;self&quot;: &quot;https://example/rest/api/2/statuscategory/4&quot;,\r\n        &quot;id&quot;: 4,\r\n        &quot;key&quot;: &quot;indeterminate&quot;,\r\n        &quot;colorName&quot;: &quot;yellow&quot;,\r\n        &quot;name&quot;: &quot;In Progress&quot;\r\n      }\r\n    },\r\n    &quot;customfield_17403&quot;: null,\r\n    &quot;customfield_17401&quot;: null,\r\n    &quot;customfield_15102&quot;: {\r\n      &quot;self&quot;: &quot;https://example/rest/api/2/customFieldOption/18132&quot;,\r\n      &quot;value&quot;: &quot;Code Improvement&quot;,\r\n      &quot;id&quot;: &quot;18132&quot;\r\n    },\r\n    &quot;customfield_17400&quot;: null,\r\n    &quot;customfield_15900&quot;: null,\r\n    &quot;customfield_17406&quot;: null,\r\n    &quot;customfield_17405&quot;: null,\r\n    &quot;customfield_17404&quot;: null,\r\n    &quot;customfield_14802&quot;: null,\r\n    &quot;aggregatetimeestimate&quot;: null,\r\n    &quot;creator&quot;: {\r\n      &quot;self&quot;: &quot;https://example/rest/api/2/user?username=testuser&quot;,\r\n      &quot;name&quot;: &quot;testuser&quot;,\r\n      &quot;key&quot;: &quot;testuser&quot;,\r\n      &quot;emailAddress&quot;: &quot;testuser@sample&quot;,\r\n      &quot;avatarUrls&quot;: {\r\n        &quot;48x48&quot;: &quot;https://example/secure/useravatar?avatarId=15907&quot;,\r\n        &quot;24x24&quot;: &quot;https://example/secure/useravatar?size=small&amp;avatarId=15907&quot;,\r\n        &quot;16x16&quot;: &quot;https://example/secure/useravatar?size=xsmall&amp;avatarId=15907&quot;,\r\n        &quot;32x32&quot;: &quot;https://example/secure/useravatar?size=medium&amp;avatarId=15907&quot;\r\n      },\r\n      &quot;displayName&quot;: &quot;testuser&quot;,\r\n      &quot;active&quot;: true,\r\n      &quot;timeZone&quot;: &quot;Asia/Kolkata&quot;\r\n    },\r\n    &quot;aggregateprogress&quot;: {\r\n      &quot;progress&quot;: 0,\r\n      &quot;total&quot;: 0\r\n    },\r\n    &quot;timespent&quot;: null,\r\n    &quot;customfield_15202&quot;: [\r\n      \r\n    ],\r\n    &quot;customfield_15203&quot;: null,\r\n    &quot;customfield_15200&quot;: null,\r\n    &quot;customfield_15201&quot;: null,\r\n    &quot;aggregatetimespent&quot;: null,\r\n    &quot;customfield_15204&quot;: null,\r\n    &quot;workratio&quot;: -1,\r\n    &quot;customfield_15306&quot;: null,\r\n    &quot;customfield_15303&quot;: null,\r\n    &quot;attachment&quot;: [\r\n      \r\n    ],\r\n    &quot;customfield_10527&quot;: null,\r\n    &quot;customfield_10518&quot;: null\r\n  },\r\n  &quot;changelog&quot;: {\r\n    &quot;startAt&quot;: 0,\r\n    &quot;maxResults&quot;: 4,\r\n    &quot;total&quot;: 4,\r\n    &quot;histories&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;3818773&quot;,\r\n        &quot;author&quot;: {\r\n          &quot;self&quot;: &quot;https://example/rest/api/2/user?username=testuser&quot;,\r\n          &quot;name&quot;: &quot;testuser&quot;,\r\n          &quot;key&quot;: &quot;testuser&quot;,\r\n          &quot;emailAddress&quot;: &quot;testuser@sample&quot;,\r\n          &quot;avatarUrls&quot;: {\r\n            &quot;48x48&quot;: &quot;https://example/secure/useravatar?avatarId=15907&quot;,\r\n            &quot;24x24&quot;: &quot;https://example/secure/useravatar?size=small&amp;avatarId=15907&quot;,\r\n            &quot;16x16&quot;: &quot;https://example/secure/useravatar?size=xsmall&amp;avatarId=15907&quot;,\r\n            &quot;32x32&quot;: &quot;https://example/secure/useravatar?size=medium&amp;avatarId=15907&quot;\r\n          },\r\n          &quot;displayName&quot;: &quot;testuser&quot;,\r\n          &quot;active&quot;: true,\r\n          &quot;timeZone&quot;: &quot;Asia/Kolkata&quot;\r\n        },\r\n        &quot;created&quot;: &quot;2021-06-28T16:34:02.000+0530&quot;,\r\n        &quot;items&quot;: [\r\n          {\r\n            &quot;field&quot;: &quot;status&quot;,\r\n            &quot;fieldtype&quot;: &quot;jira&quot;,\r\n            &quot;from&quot;: &quot;10114&quot;,\r\n            &quot;fromString&quot;: &quot;New&quot;,\r\n            &quot;to&quot;: &quot;12605&quot;,\r\n            &quot;toString&quot;: &quot;Coding&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;3818870&quot;,\r\n        &quot;author&quot;: {\r\n          &quot;self&quot;: &quot;https://example/rest/api/2/user?username=testuser&quot;,\r\n          &quot;name&quot;: &quot;testuser&quot;,\r\n          &quot;key&quot;: &quot;testuser&quot;,\r\n          &quot;emailAddress&quot;: &quot;testuser@sample&quot;,\r\n          &quot;avatarUrls&quot;: {\r\n            &quot;48x48&quot;: &quot;https://example/secure/useravatar?avatarId=15907&quot;,\r\n            &quot;24x24&quot;: &quot;https://example/secure/useravatar?size=small&amp;avatarId=15907&quot;,\r\n            &quot;16x16&quot;: &quot;https://example/secure/useravatar?size=xsmall&amp;avatarId=15907&quot;,\r\n            &quot;32x32&quot;: &quot;https://example/secure/useravatar?size=medium&amp;avatarId=15907&quot;\r\n          },\r\n          &quot;displayName&quot;: &quot;testuser&quot;,\r\n          &quot;active&quot;: true,\r\n          &quot;timeZone&quot;: &quot;Asia/Kolkata&quot;\r\n        },\r\n        &quot;created&quot;: &quot;2021-06-28T17:23:44.000+0530&quot;,\r\n        &quot;items&quot;: [\r\n          {\r\n            &quot;field&quot;: &quot;status&quot;,\r\n            &quot;fieldtype&quot;: &quot;jira&quot;,\r\n            &quot;from&quot;: &quot;12605&quot;,\r\n            &quot;fromString&quot;: &quot;Coding&quot;,\r\n            &quot;to&quot;: &quot;12606&quot;,\r\n            &quot;toString&quot;: &quot;Code Review&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;3820419&quot;,\r\n        &quot;author&quot;: {\r\n          &quot;self&quot;: &quot;https://example/rest/api/2/user?username=example&quot;,\r\n          &quot;name&quot;: &quot;example&quot;,\r\n          &quot;key&quot;: &quot;example&quot;,\r\n          &quot;emailAddress&quot;: &quot;example@sample&quot;,\r\n          &quot;avatarUrls&quot;: {\r\n            &quot;48x48&quot;: &quot;https://example/secure/useravatar?ownerId=example&amp;avatarId=12908&quot;,\r\n            &quot;24x24&quot;: &quot;https://example/secure/useravatar?size=small&amp;ownerId=example&amp;avatarId=12908&quot;,\r\n            &quot;16x16&quot;: &quot;https://example/secure/useravatar?size=xsmall&amp;ownerId=example&amp;avatarId=12908&quot;,\r\n            &quot;32x32&quot;: &quot;https://example/secure/useravatar?size=medium&amp;ownerId=example&amp;avatarId=12908&quot;\r\n          },\r\n          &quot;displayName&quot;: &quot;example&quot;,\r\n          &quot;active&quot;: true,\r\n          &quot;timeZone&quot;: &quot;Asia/Kolkata&quot;\r\n        },\r\n        &quot;created&quot;: &quot;2021-06-29T17:40:12.000+0530&quot;,\r\n        &quot;items&quot;: [\r\n          {\r\n            &quot;field&quot;: &quot;Coding Due Date&quot;,\r\n            &quot;fieldtype&quot;: &quot;custom&quot;,\r\n            &quot;from&quot;: null,\r\n            &quot;fromString&quot;: null,\r\n            &quot;to&quot;: &quot;2021-06-30&quot;,\r\n            &quot;toString&quot;: &quot;30/Jun/21&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;3820420&quot;,\r\n        &quot;author&quot;: {\r\n          &quot;self&quot;: &quot;https://example/rest/api/2/user?username=example&quot;,\r\n          &quot;name&quot;: &quot;example&quot;,\r\n          &quot;key&quot;: &quot;example&quot;,\r\n          &quot;emailAddress&quot;: &quot;example@sample&quot;,\r\n          &quot;avatarUrls&quot;: {\r\n            &quot;48x48&quot;: &quot;https://example/secure/useravatar?ownerId=example&amp;avatarId=12908&quot;,\r\n            &quot;24x24&quot;: &quot;https://example/secure/useravatar?size=small&amp;ownerId=example&amp;avatarId=12908&quot;,\r\n            &quot;16x16&quot;: &quot;https://example/secure/useravatar?size=xsmall&amp;ownerId=example&amp;avatarId=12908&quot;,\r\n            &quot;32x32&quot;: &quot;https://example/secure/useravatar?size=medium&amp;ownerId=example&amp;avatarId=12908&quot;\r\n          },\r\n          &quot;displayName&quot;: &quot;example&quot;,\r\n          &quot;active&quot;: true,\r\n          &quot;timeZone&quot;: &quot;Asia/Kolkata&quot;\r\n        },\r\n        &quot;created&quot;: &quot;2021-06-29T17:40:13.000+0530&quot;,\r\n        &quot;items&quot;: [\r\n          {\r\n            &quot;field&quot;: &quot;assignee&quot;,\r\n            &quot;fieldtype&quot;: &quot;jira&quot;,\r\n            &quot;from&quot;: &quot;testuser&quot;,\r\n            &quot;fromString&quot;: &quot;testuser&quot;,\r\n            &quot;to&quot;: &quot;example&quot;,\r\n            &quot;toString&quot;: &quot;example&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/68395321/conditions-in-jq-tool",
        "title": "Conditions In Jq tool"
    },
    {
        "tags": [
            "arrays",
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1626373892,
                "creation_date": 1626373892,
                "answer_id": 68399126,
                "question_id": 68398296,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to tackle the problem is to use jq &quot;$-variables&quot;:\r\n```\r\n.metricId as $metricId\r\n| .data[]\r\n| .dimensionMap.Queue as $q\r\n| [.timestamps, .values] | transpose[]\r\n| [$metricId, $q, .[]]\r\n| @csv\r\n```",
                "title": "How to use jq to convert 2 objects into CSV?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1626373990,
        "creation_date": 1626369927,
        "last_edit_date": 1626373990,
        "question_id": 68398296,
        "body_markdown": "I&#39;m trying to convert objects that look like this:\r\n\r\n```\r\n{\r\n  &quot;metricId&quot;: &quot;metric1&quot;,\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;dimensions&quot;: [\r\n        &quot;DEVICE-a1b2c3&quot;,\r\n        &quot;queue1&quot;\r\n      ],\r\n      &quot;dimensionMap&quot;: {\r\n        &quot;Queue&quot;: &quot;queue1&quot;,\r\n        &quot;enitity&quot;: &quot;DEVICE-a1b2c3&quot;\r\n      },\r\n      &quot;timestamps&quot;: [\r\n        1626286800000\r\n      ],\r\n      &quot;values&quot;: [\r\n        1\r\n      ]\r\n    },\r\n    {\r\n      &quot;dimensions&quot;: [\r\n        &quot;DEVICE-a1b2c3&quot;,\r\n        &quot;queue2&quot;\r\n      ],\r\n      &quot;dimensionMap&quot;: {\r\n        &quot;Queue&quot;: &quot;queue2&quot;,\r\n        &quot;entity&quot;: &quot;DEVICE-a1b2c3&quot;\r\n      },\r\n      &quot;timestamps&quot;: [\r\n        1626286800000\r\n      ],\r\n      &quot;values&quot;: [\r\n        2\r\n      ]\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;metricId&quot;: &quot;metric2&quot;,\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;dimensions&quot;: [\r\n        &quot;DEVICE-a1b2c3&quot;,\r\n        &quot;queue1&quot;\r\n      ],\r\n      &quot;dimensionMap&quot;: {\r\n        &quot;Queue&quot;: &quot;queue1&quot;,\r\n        &quot;entity&quot;: &quot;DEVICE-a1b2c3&quot;\r\n      },\r\n      &quot;timestamps&quot;: [\r\n        1626286800000\r\n      ],\r\n      &quot;values&quot;: [\r\n        11\r\n      ]\r\n    },\r\n    {\r\n      &quot;dimensions&quot;: [\r\n        &quot;DEVICE-a1b2c3&quot;,\r\n        &quot;queue2&quot;\r\n      ],\r\n      &quot;dimensionMap&quot;: {\r\n        &quot;Queue&quot;: &quot;queue2&quot;,\r\n        &quot;entity&quot;: &quot;DEVICE-a1b2c3&quot;\r\n      },\r\n      &quot;timestamps&quot;: [\r\n        1626286800000\r\n      ],\r\n      &quot;values&quot;: [\r\n        22\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nTo CSV that looks like this:\r\n```\r\n&quot;metric1&quot;,&quot;queue1&quot;,1626286800000,1\r\n&quot;metric1&quot;,&quot;queue1&quot;,1626286800000,2\r\n&quot;metric2&quot;,&quot;queue1&quot;,1626286800000,11\r\n&quot;metric2&quot;,&quot;queue1&quot;,1626286800000,22\r\n```\r\n\r\nI was somewhat successful but I&#39;m getting duplicates in my results. \r\n\r\nCommand: ```jq -r &#39;. | {id:.metricId, queue: .data[].dimensionMap.Queue, time: .data[].timestamps[0], value: .data[].values[0]} | [.id, .queue, .time, .value] | @csv&#39;```\r\n\r\nOutput:\r\n```\r\n&quot;metric1&quot;,&quot;queue1&quot;,1626286800000,1\r\n&quot;metric1&quot;,&quot;queue1&quot;,1626286800000,2\r\n&quot;metric1&quot;,&quot;queue1&quot;,1626286800000,1\r\n&quot;metric1&quot;,&quot;queue1&quot;,1626286800000,2\r\n&quot;metric1&quot;,&quot;queue2&quot;,1626286800000,1\r\n&quot;metric1&quot;,&quot;queue2&quot;,1626286800000,2\r\n&quot;metric1&quot;,&quot;queue2&quot;,1626286800000,1\r\n&quot;metric1&quot;,&quot;queue2&quot;,1626286800000,2\r\n&quot;metric2&quot;,&quot;queue1&quot;,1626286800000,11\r\n&quot;metric2&quot;,&quot;queue1&quot;,1626286800000,22\r\n&quot;metric2&quot;,&quot;queue1&quot;,1626286800000,11\r\n&quot;metric2&quot;,&quot;queue1&quot;,1626286800000,22\r\n&quot;metric2&quot;,&quot;queue2&quot;,1626286800000,11\r\n&quot;metric2&quot;,&quot;queue2&quot;,1626286800000,22\r\n&quot;metric2&quot;,&quot;queue2&quot;,1626286800000,11\r\n&quot;metric2&quot;,&quot;queue2&quot;,1626286800000,2\r\n```\r\n\r\nI&#39;ve looked over the documentation and several blog posts/videos but I haven&#39;t been able to find a solution so far. Thank you for your help.",
        "link": "https://stackoverflow.com/questions/68398296/how-to-use-jq-to-convert-2-objects-into-csv",
        "title": "How to use jq to convert 2 objects into CSV?"
    },
    {
        "tags": [
            "json",
            "jq",
            "zimbra"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1628295034,
                "creation_date": 1628295034,
                "answer_id": 68688493,
                "question_id": 68402950,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You was very close of the solution .\r\n\r\nWhen you have a list of files , you can use `jq -slurp`  to create a big array with all contents of your files . \r\n\r\nBut because in your case you care about the filename a alternative is concatenate the content of file with the filename in one object .\r\n\r\nin your case for example :\r\n\r\n    jq  -r &#39;{&quot;email&quot;:input_filename} + .&#39; * \r\n\r\nand after you can apply almost your solution \r\n\r\n\r\n    jq  -r &#39;{&quot;email&quot;:input_filename} + . | \r\n            &quot;selectMailbox \\(.email)&quot;,\r\n              (..|objects | select(.flags == &quot;i&quot; or .flags == &quot;#i&quot;) |\r\n                              &quot;modifyFolderFlags \\(.path) \\&quot;\\&quot; &quot; \r\n              ),&quot;&quot; &#39; *\r\n\r\n\r\n\r\n \r\n\r\n\r\n\r\n",
                "title": "Generate raw output with headers and block separators in JQ"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1628295034,
        "creation_date": 1626404998,
        "last_edit_date": 1626411563,
        "question_id": 68402950,
        "body_markdown": "Using JQ, I need to convert JSON objects to a very specific format called `zmp`, which looks like this:\r\n\r\n```\r\nselectMailbox     user.one@domain.com\r\nmodifyFolderFlags /Inbox       &quot;&quot;\r\nmodifyFolderFlags /Inbox/teste &quot;&quot;\r\n\r\nselectMailbox     user.two@domain.com.br\r\nmodifyFolderFlags /Inbox &quot;&quot;\r\nmodifyFolderFlags /Sent  &quot;&quot;\r\n```\r\n\r\nWith this program:\r\n```\r\njq -r &#39;.. | objects | select(.flags == &quot;i&quot; or .flags == &quot;#i&quot;) | &quot;selectMailbox \\(input_filename)&quot;,&quot;modifyFolderFlags \\(.path) \\&quot;\\&quot; &quot;&#39; *\r\n```\r\nI was able to output:\r\n```\r\nselectMailbox     user.one@domain.com\r\nmodifyFolderFlags /Inbox       &quot;&quot;\r\nselectMailbox     user.one@domain.com\r\nmodifyFolderFlags /Inbox/teste &quot;&quot;\r\nselectMailbox     user.two@domain.com.br\r\nmodifyFolderFlags /Inbox &quot;&quot;\r\nselectMailbox     user.two@domain.com.br\r\nmodifyFolderFlags /Sent  &quot;&quot;\r\n```\r\nAs you see, it outputs `selectMailbox` multiple times and it&#39;s missing the block separator (blank line).\r\n\r\nBelow are sample inputs.\r\n\r\n`/tmp/jq/user.one@domain.com`\r\n```\r\n{\r\n  &quot;path&quot;: &quot;/&quot;,\r\n  &quot;subFolders&quot;: [\r\n    {\r\n      &quot;flags&quot;: &quot;#&quot;,\r\n      &quot;path&quot;: &quot;/Drafts&quot;,\r\n      &quot;subFolders&quot;: []\r\n    },\r\n    {\r\n      &quot;flags&quot;: &quot;#i&quot;,\r\n      &quot;path&quot;: &quot;/Inbox&quot;,\r\n      &quot;subFolders&quot;: [\r\n        {\r\n          &quot;flags&quot;: &quot;i&quot;,\r\n          &quot;path&quot;: &quot;/Inbox/teste&quot;,\r\n          &quot;subFolders&quot;: []\r\n        }\r\n      ],\r\n      &quot;unreadCount&quot;: 0\r\n    },\r\n    {\r\n      &quot;path&quot;: &quot;/Sent&quot;,\r\n      &quot;subFolders&quot;: []\r\n    }\r\n  ],\r\n  &quot;unreadCount&quot;: 0\r\n}\r\n```\r\n\r\n`/tmp/jq/user.two@domain.com.br`\r\n```\r\n{\r\n  &quot;path&quot;: &quot;/&quot;,\r\n  &quot;subFolders&quot;: [\r\n    {\r\n      &quot;flags&quot;: &quot;#i&quot;,\r\n      &quot;path&quot;: &quot;/Inbox&quot;,\r\n      &quot;subFolders&quot;: []\r\n    },\r\n    {\r\n      &quot;flags&quot;: &quot;#i&quot;,\r\n      &quot;path&quot;: &quot;/Sent&quot;,\r\n      &quot;subFolders&quot;: []\r\n    },\r\n    {\r\n      &quot;flags&quot;: &quot;#&quot;,\r\n      &quot;path&quot;: &quot;/Trash&quot;,\r\n      &quot;subFolders&quot;: []\r\n    }\r\n  ],\r\n  &quot;unreadCount&quot;: 0\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/68402950/generate-raw-output-with-headers-and-block-separators-in-jq",
        "title": "Generate raw output with headers and block separators in JQ"
    },
    {
        "tags": [
            "json",
            "jq",
            "trivy"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1626417179,
                "creation_date": 1626417179,
                "answer_id": 68404446,
                "question_id": 68404038,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just select array inputs.\r\n``` shell\r\njq -n &#39;[inputs | arrays[]]&#39; *.json\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/J6ELapSwyI)&lt;/sup&gt;\r\n\r\nUse `select(. != null)` instead of `arrays` if you don&#39;t want to exclude all non-arrays but only `null`.",
                "title": "Exclude null inputs while concatenating JSON files"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1626417241,
        "creation_date": 1626414746,
        "last_edit_date": 1626417241,
        "question_id": 68404038,
        "body_markdown": "I&#39;m looking to concatenate multiple JSON files in a directory using jq. \r\nMajority of the JSON files look like this \r\n```\r\n[\r\n  {\r\n    a: 12,\r\n    b: 22,\r\n    c: []\r\n  }\r\n]\r\n```\r\nSo for concatenating them I use the follow jq query\r\n```\r\njq -s &#39;[.[]|.[ ]]&#39; *.json &gt; xyz.json\r\n```\r\n\r\nThis seems work okay and I get the expected concatenated output until it encounters a JSON file that just has null written in it, and when I try to concatenate this with the others I get an error.\r\n```\r\n$ cat test.json\r\n  null\r\n$ jq -s &#39;[.[]|.[ ]]&#39; xyz.json test.json &gt; y.json\r\njq: error (at test.json:0): Cannot iterate over null (null)\r\n```\r\n\r\nIs there a way to exclude this null JSON file while concatenating through the directory?\r\n\r\nI must mention these JSON files are generated as outputs for different **Trivy Image** scans and I have no control over what the output is.\r\n\r\nIf anyone else has faced this issue previously please help me out.",
        "link": "https://stackoverflow.com/questions/68404038/exclude-null-inputs-while-concatenating-json-files",
        "title": "Exclude null inputs while concatenating JSON files"
    },
    {
        "tags": [
            "makefile",
            "environment-variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1626420167,
                "post_id": 68404857,
                "comment_id": 120892677,
                "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": 1626420263,
                "post_id": 68404857,
                "comment_id": 120892713,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1976031,
                    "reputation": 30404,
                    "user_id": 1773798,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/4Ljqn.png?s=256",
                    "display_name": "Renaud Pacalet",
                    "link": "https://stackoverflow.com/users/1773798/renaud-pacalet"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1626421518,
                "post_id": 68404857,
                "comment_id": 120893176,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1626420546,
                "creation_date": 1626420546,
                "answer_id": 68405130,
                "question_id": 68404857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using a shell variable may not be the best idea, but if that&#39;s what you want, this should give you the hint you&#39;re looking for:\r\n```\r\nENV=development jq -n &#39;env.ENV&#39;\r\n```\r\n\r\nUsing this approach, though, you&#39;d have to provide the filename as an argument to jq.\r\n\r\nNotice that using this approach avoids any conflict with jq&#39;s &quot;$-variables&quot;.",
                "title": "How to plugin variable key to jq in a Makefile?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1626994398,
        "creation_date": 1626419273,
        "last_edit_date": 1626994398,
        "question_id": 68404857,
        "body_markdown": "I want to do this:\r\n\r\n    ENV=development cat dbconfig.json | jq &#39;.database.$ENV&#39;\r\n\r\nwhere config looks like:\r\n\r\n    {\r\n      &quot;database&quot;: {\r\n        &quot;development&quot;: {\r\n          &quot;name&quot;: &quot;example&quot;,\r\n          &quot;user&quot;: &quot;user&quot;,\r\n          &quot;password&quot;: &quot;asdfasdf&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI want to specify the `ENV` in the command and use it to fetch the key `&quot;development&quot;` from the json.\r\n\r\nIn a makefile specifically, I would like to do:\r\n\r\n\r\n\t\t# ensure env is set\r\n\t\tifeq ($(ENV),)\r\n\t\t\t$(error ENV is not set)\r\n\t\tendif\r\n\r\n\t\tCONFIG := $(shell cat config.json)\r\n\t\tDATABASE_NAME = $(shell echo CONFIG | jq &#39;database.$(ENV).name&#39;)\r\n\r\n\t\tmigrate:\r\n\t\t\t@migrate -source backend/migrations -database postgres://localhost:5432/$(DATABASE_NAME) up\r\n\t\t.PHONY: migrate\r\n\r\nI am new to jq, and somewhat to makefiles, how could this be accomplished?",
        "link": "https://stackoverflow.com/questions/68404857/how-to-plugin-variable-key-to-jq-in-a-makefile",
        "title": "How to plugin variable key to jq in a Makefile?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1626431450,
                "creation_date": 1626431450,
                "answer_id": 68407510,
                "question_id": 68407091,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n``` none\r\n.orders[] |= (\r\n  ( .packages | INDEX(.packagenumber) ) as $r\r\n  | .contents[] |= . + ($r[.packagenumber | tostring] | {status})\r\n  | del(.packages)\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/cTsXA35HjS)&lt;/sup&gt;",
                "title": "JSON transformation with JQ / pyjq. Move objects from an object array to another array, matched by a identity field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1626432703,
        "creation_date": 1626429583,
        "last_edit_date": 1626432703,
        "question_id": 68407091,
        "body_markdown": "I would like to add the orders[].packages[].status field to the orders[].contents[] with the matching packagenumber. \r\n\r\n\r\n\r\nInput JSON:\r\n\r\n```json\r\n{\r\n  &quot;orders&quot;: [\r\n    {\r\n      &quot;code&quot;: 2389,\r\n      &quot;packages&quot;: [\r\n        {\r\n          &quot;packagenumber&quot;: 3929,\r\n          &quot;status&quot;: 100\r\n        },\r\n        {\r\n          &quot;packagenumber&quot;: 3930,\r\n          &quot;status&quot;: 110\r\n        }\r\n      ],\r\n      &quot;contents&quot;: [\r\n        {\r\n          &quot;contentid&quot;: 398,\r\n          &quot;description&quot;: &quot;closet&quot;,\r\n          &quot;packagenumber&quot;: 3929\r\n        },\r\n        {\r\n          &quot;contentid&quot;: 399,\r\n          &quot;description&quot;: &quot;rice&quot;,\r\n          &quot;packagenumber&quot;: 3929\r\n        },\r\n        {\r\n          &quot;contentid&quot;: 400,\r\n          &quot;description&quot;: &quot;foo&quot;,\r\n          &quot;packagenumber&quot;: 3930\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;code&quot;: 2390,\r\n      &quot;packages&quot;: [\r\n        {\r\n          &quot;packagenumber&quot;: 3930,\r\n          &quot;status&quot;: 110\r\n        },\r\n        {\r\n          &quot;packagenumber&quot;: 3931,\r\n          &quot;status&quot;: 150\r\n        }\r\n      ],\r\n      &quot;contents&quot;: [\r\n        {\r\n          &quot;contentid&quot;: 500,\r\n          &quot;description&quot;: &quot;bar&quot;,\r\n          &quot;packagenumber&quot;: 3931\r\n        },\r\n        {\r\n          &quot;contentid&quot;: 501,\r\n          &quot;description&quot;: &quot;snicker&quot;,\r\n          &quot;packagenumber&quot;: 3931\r\n        },\r\n        {\r\n          &quot;contentid&quot;: 502,\r\n          &quot;description&quot;: &quot;mars&quot;,\r\n          &quot;packagenumber&quot;: 3930\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\n\r\n\r\nDesired output JSON:\r\n\r\n```json\r\n{\r\n  &quot;orders&quot;: [\r\n    {\r\n      &quot;code&quot;: 2389,\r\n      &quot;contents&quot;: [\r\n        {\r\n          &quot;contentid&quot;: 398,\r\n          &quot;description&quot;: &quot;closet&quot;,\r\n          &quot;packagenumber&quot;: 3929,\r\n          &quot;status&quot;: 100\r\n        },\r\n        {\r\n          &quot;contentid&quot;: 399,\r\n          &quot;description&quot;: &quot;rice&quot;,\r\n          &quot;packagenumber&quot;: 3929,\r\n          &quot;status&quot;: 100\r\n        },\r\n        {\r\n          &quot;contentid&quot;: 400,\r\n          &quot;description&quot;: &quot;foo&quot;,\r\n          &quot;packagenumber&quot;: 3930,\r\n          &quot;status&quot;: 110\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;code&quot;: 2390,\r\n      &quot;contents&quot;: [\r\n        {\r\n          &quot;contentid&quot;: 500,\r\n          &quot;description&quot;: &quot;bar&quot;,\r\n          &quot;packagenumber&quot;: 3931,\r\n          &quot;status&quot;: 150\r\n        },\r\n        {\r\n          &quot;contentid&quot;: 501,\r\n          &quot;description&quot;: &quot;snicker&quot;,\r\n          &quot;packagenumber&quot;: 3931,\r\n          &quot;status&quot;: 150\r\n        },\r\n        {\r\n          &quot;contentid&quot;: 502,\r\n          &quot;description&quot;: &quot;mars&quot;,\r\n          &quot;packagenumber&quot;: 3930,\r\n          &quot;status&quot;: 110\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\n\r\nThis moves the packages to the contents: \r\n\r\n    {shipments: [.orders[] | .packages as $packages | {code:  .code, contents: [(.contents[] | ., $packages )] } ]}\r\n\r\nWith select, it is possible to get the a package, but I don&#39;t get the package that matches the packagenumber of the content work.  \r\n\r\n\r\n\r\n    packages: .packages[] | select(.packagenumber==3930)\r\n\r\n\r\n\r\n\r\nQuestion:\r\n- How can the input transformed to the desired output format?  Using pyjq or jqplay.org?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68407091/json-transformation-with-jq-pyjq-move-objects-from-an-object-array-to-another",
        "title": "JSON transformation with JQ / pyjq. Move objects from an object array to another array, matched by a identity field"
    },
    {
        "tags": [
            "json",
            "syntax",
            "environment-variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1626459778,
                "creation_date": 1626459778,
                "answer_id": 68413685,
                "question_id": 68411502,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The jq filter should be:\r\n\r\n    .[$ITEM1][$PROPERTY2] = $VALUE\r\n\r\nYour query has an extra `.`.\r\n\r\n### An alternative:\r\n\r\nYou could also use `setpath/2`, e.g.\r\n\r\n    setpath([$ITEM1,$PROPERTY2]; $VALUE)\r\n\r\n### Aside\r\nIt&#39;s usually best to quote your shell variables, e.g.\r\n`echo &quot;$contents&quot; ...`",
                "title": "JQ: add variable property to existing object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1626541986,
        "creation_date": 1626448826,
        "last_edit_date": 1626541986,
        "question_id": 68411502,
        "body_markdown": "I&#39;m trying to add variable properties to some existing json\r\n```\r\n{\r\n  &quot;item1&quot;: {\r\n    &quot;proerty1&quot;: &quot;test&quot;\r\n  },\r\n  &quot;item2&quot;: {}\r\n}\r\n```\r\nSo if I do something like this it works\r\n```\r\necho $contents | jq --arg ITEM1 $item1 &#39;.[$ITEM1].property2 = &quot;test2&quot;&#39;\r\n```\r\nBut when I try to add more arguments like this it fails: \r\n```\r\necho $contents | jq --arg ITEM1 $item1 --arg PROPERTY2 $property2 --arg VALUE $value  &#39;.[$ITEM1].[PROPERTY2] = $VALUE&#39;\r\n```\r\n\r\nThe error I get is: \r\n```\r\njq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.[$ITEM1].[PROPERTY2] = $VALUE\r\njq: 1 compile error\r\n```\r\n\r\nSo I guess += operator wouldn&#39;t be the correct way to do this with variables. What would be the correct way to add a propetry where the whole path .item.property and the value itself are variable",
        "link": "https://stackoverflow.com/questions/68411502/jq-add-variable-property-to-existing-object",
        "title": "JQ: add variable property to existing object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1626450179,
                "creation_date": 1626450179,
                "answer_id": 68411809,
                "question_id": 68411696,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `reduce` to fold all the objects together, and merge their contents with the `*` operator:\r\n\r\n```\r\nreduce .[] as $item ({}; . * $item)\r\n```",
                "title": "How can I merge a sequence of objects with repeating keys into one?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1626450179,
        "creation_date": 1626449697,
        "question_id": 68411696,
        "body_markdown": "I have a sequence of objects, each with a single key. The values are themselves objects and the keys in the sequence may repeat. I would like to group said objects by their key and merge the values for repeated keys with something like jq&#39;s `add`.\r\n\r\nMore generally I want to\r\n```none\r\n1. Group by key\r\n2. Perform some op on array of values under matching keys\r\n3. Get object with all unique keys from input with values the results of step 2\r\n```\r\n\r\nHere is my input:\r\n\r\n```json\r\n# jq &#39;.&#39; /tmp/json.json \r\n{\r\n  &quot;cmsa-x-41100001&quot;: {\r\n    &quot;fqdn&quot;: &quot;cmsa-x-41100001.example.com&quot;,\r\n    &quot;fqdn_ip4&quot;: [\r\n      &quot;100.64.40.10&quot;\r\n    ]\r\n  }\r\n}\r\n{\r\n  &quot;cmsa-x-41100002&quot;: {\r\n    &quot;fqdn&quot;: &quot;cmsa-x-41100002.example.com&quot;,\r\n    &quot;fqdn_ip4&quot;: [\r\n      &quot;100.64.40.5&quot;\r\n    ]\r\n  }\r\n}\r\n{\r\n  &quot;cmsa-x-41100000&quot;: {\r\n    &quot;fqdn&quot;: &quot;cmsa-x-41100000.example.com&quot;,\r\n    &quot;fqdn_ip4&quot;: [\r\n      &quot;100.64.40.13&quot;\r\n    ]\r\n  }\r\n}\r\n{\r\n  &quot;cmsa-x-41100001&quot;: {\r\n    &quot;k8s_salt:cluster_domain&quot;: &quot;cluster4.csip&quot;\r\n  }\r\n}\r\n{\r\n  &quot;cmsa-x-41100002&quot;: {\r\n    &quot;k8s_salt:cluster_domain&quot;: &quot;cluster4.csip&quot;\r\n  }\r\n}\r\n{\r\n  &quot;cmsa-x-41100000&quot;: {\r\n    &quot;k8s_salt:cluster_domain&quot;: &quot;cluster4.csip&quot;\r\n  }\r\n}\r\n```\r\n\r\nHere is my desired output:\r\n\r\n```json\r\n{\r\n  &quot;cmsa-x-41100000&quot;: {\r\n    &quot;fqdn&quot;: &quot;cmsa-x-41100000.example.com&quot;,\r\n    &quot;fqdn_ip4&quot;: [\r\n      &quot;100.64.40.13&quot;\r\n    ],\r\n    &quot;k8s_salt:cluster_domain&quot;: &quot;cluster4.csip&quot;\r\n  },\r\n  &quot;cmsa-x-41100001&quot;: {\r\n    &quot;fqdn&quot;: &quot;cmsa-x-41100001.example.com&quot;,\r\n    &quot;fqdn_ip4&quot;: [\r\n      &quot;100.64.40.10&quot;\r\n    ],\r\n    &quot;k8s_salt:cluster_domain&quot;: &quot;cluster4.csip&quot;\r\n  },\r\n  &quot;cmsa-x-41100002&quot;: {\r\n    &quot;fqdn&quot;: &quot;cmsa-x-41100002.example.com&quot;,\r\n    &quot;fqdn_ip4&quot;: [\r\n      &quot;100.64.40.5&quot;\r\n    ],\r\n    &quot;k8s_salt:cluster_domain&quot;: &quot;cluster4.csip&quot;\r\n  }\r\n}\r\n```\r\n\r\nI have managed to achieve this with\r\n\r\n```\r\njq -s &#39;map(to_entries[0]) | group_by(.key) | map(.[0].value = (map(.value) | add) ) | map(.[0]) | from_entries&#39; /tmp/json.json\r\n```\r\n\r\nbut it seems ugly and I feel, I&#39;m doing it the wrong way. How would this be done properly? ",
        "link": "https://stackoverflow.com/questions/68411696/how-can-i-merge-a-sequence-of-objects-with-repeating-keys-into-one",
        "title": "How can I merge a sequence of objects with repeating keys into one?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1626474939,
                "last_edit_date": 1626474939,
                "creation_date": 1626453222,
                "answer_id": 68412440,
                "question_id": 68412090,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Okay, let&#39;s start by summarising what you&#39;re trying to do:\r\n\r\n* Drop some fields and keep others in `service.options`\r\n* Drop all fields except `name` in `service.options.attributes`\r\n\r\nYou also specifically aren&#39;t modifying anything else. For example you want to:\r\n\r\n* Keep all the fields in `service`\r\n* Keep all the contents of `service.options.customAttributes`\r\n\r\nDepending on whether you want to specify the fields to drop or the fields to keep you can modify `service.options` like this:\r\n\r\n```\r\n# Specify what to keep...\r\njq &#39;.service.options|={attributes,customattributes}&#39;\r\n\r\n# ...or what to drop\r\njq &#39;del(.service.options.max, .service.options.objectGroupMember)&#39;\r\n```\r\n\r\nFor removing all fields but `name` from `service.options.attributes` it&#39;s easiest to specify just what you&#39;re keeping:\r\n\r\n```\r\n# Specify what to keep\r\njq &#39;.service.options.attributes|={name}&#39;\r\n```\r\n\r\nYou can combine these together:\r\n\r\n```\r\njq &#39;del(.service.options.max, .service.options.objectGroupMember)|.service.options.attributes|={name}&#39;\r\n```\r\n\r\nAnd you can simplify the repetition a fair bit:\r\n\r\n```\r\njq &#39;.service.options|=(del(.max,.objectGroupMember)|.attributes|={name})&#39;\r\n```\r\n\r\nAll in all, we used:\r\n* `|=` to apply a modification to just part of an object. It&#39;s helpful to remember that we can dig deep into a complex object on the left of this operator but our output still keeps all of the higher layers of object unchanged.\r\n* The shortcut syntax of `{name}` to keep only the name field. This is equivalent to `{&quot;name&quot;:.name}`.\r\n* `del(.field1, .field2)` to delete fields from an object.",
                "title": "How to delete many and keep few objects in big JSON"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1629905905,
        "creation_date": 1626451517,
        "last_edit_date": 1629905905,
        "question_id": 68412090,
        "body_markdown": "How to delete many and keep few objects in big JSON file? Here, I have the following JSON file:\r\n\r\n    {\r\n      &quot;service&quot; : {\r\n        &quot;category&quot; : &quot;managed-object&quot;,\r\n        &quot;resource&quot; : &quot;object&quot;,\r\n        &quot;action&quot; : &quot;locate&quot;,\r\n        &quot;options&quot; : {\r\n          &quot;max&quot; : &quot;#VALUE&quot;,\r\n          &quot;objectGroupMember&quot; : &quot;#FRESH|DEFAULT&quot;,\r\n          &quot;attributes&quot; : {\r\n            &quot;name&quot; : {\r\n              &quot;value&quot; : &quot;#VALUE&quot;\r\n            },\r\n            &quot;state&quot; : &quot;#PREACTIVE|ACTIVE|DEACTIVATED|COMPROMISED|DESTROYED|DESTROYED_COMPROMISED&quot;,\r\n            &quot;objectType&quot; : &quot;#VALUE&quot;,\r\n            &quot;fresh&quot; : &quot;#YES|NO&quot;,\r\n            &quot;objectGroup&quot; : &quot;#VALUE&quot;,\r\n            &quot;contactInfo&quot; : &quot;#VALUE&quot;,\r\n            &quot;cryptographicAlgorithm&quot; : &quot;#VALUE&quot;,\r\n            &quot;cryptographicLength&quot; : &quot;#VALUE&quot;,\r\n            &quot;cryptoUsageMask&quot; : &quot;#VALUE&quot;,\r\n            &quot;certificateLength&quot; : &quot;#VALUE&quot;,\r\n            &quot;certificateType&quot; : &quot;#VALUE&quot;,\r\n            &quot;x509CertificateSubject&quot; : &quot;#VALUE&quot;,\r\n            &quot;x509CertificateIssuer&quot; : &quot;#VALUE&quot;,\r\n            &quot;digitalSigningAlgorithm&quot; : &quot;#VALUE&quot;,\r\n            &quot;digest&quot; : {\r\n              &quot;digestValue&quot; : &quot;#VALUE&quot;,\r\n              &quot;algorithm&quot; : &quot;#VALUE&quot;,\r\n              &quot;keyFormatType&quot; : &quot;#VALUE&quot;\r\n            },\r\n            &quot;link&quot; : {\r\n              &quot;linkType&quot; : &quot;#VALUE&quot;,\r\n              &quot;linkValue&quot; : &quot;#VALUE&quot;\r\n            },\r\n            &quot;activationDate&quot; : &quot;#YYYY-MM-DD HH:mm:ss&quot;,\r\n            &quot;deactivationDate&quot; : &quot;#YYYY-MM-DD HH:mm:ss&quot;,\r\n            &quot;processStartDate&quot; : &quot;#YYYY-MM-DD HH:mm:ss&quot;,\r\n            &quot;protectStopDate&quot; : &quot;#YYYY-MM-DD HH:mm:ss&quot;,\r\n            &quot;initialDate&quot; : &quot;#YYYY-MM-DD HH:mm:ss&quot;,\r\n            &quot;lastChangeDate&quot; : &quot;#YYYY-MM-DD HH:mm:ss&quot;,\r\n            &quot;compromiseDate&quot; : &quot;#YYYY-MM-DD HH:mm:ss&quot;,\r\n            &quot;compromiseOccurrenceDate&quot; : &quot;#YYYY-MM-DD HH:mm:ss&quot;,\r\n            &quot;destroyDate&quot; : &quot;#YYYY-MM-DD HH:mm:ss&quot;,\r\n            &quot;archiveDate&quot; : &quot;#YYYY-MM-DD HH:mm:ss&quot;\r\n          },\r\n          &quot;customAttributes&quot; : [ {\r\n            &quot;name&quot; : &quot;#VALUE&quot;,\r\n            &quot;value&quot; : &quot;#VALUE&quot;,\r\n            &quot;type&quot; : &quot;#TEXT|NUMBER&quot;\r\n          } ]\r\n        }\r\n      }\r\n    }\r\n    \r\nWhat jq command deletes everything but:\r\n    \r\n    {\r\n      &quot;service&quot; : {\r\n        &quot;category&quot; : &quot;managed-object&quot;,\r\n        &quot;resource&quot; : &quot;object&quot;,\r\n        &quot;action&quot; : &quot;locate&quot;,\r\n        &quot;options&quot; : {\r\n          &quot;attributes&quot; : {\r\n            &quot;name&quot; : {\r\n              &quot;value&quot; : &quot;#VALUE&quot;\r\n            },\r\n          },\r\n          &quot;customAttributes&quot; : [ {\r\n            &quot;name&quot; : &quot;#VALUE&quot;,\r\n            &quot;value&quot; : &quot;#VALUE&quot;,\r\n            &quot;type&quot; : &quot;#TEXT|NUMBER&quot;\r\n          } ]\r\n        }\r\n      }\r\n    }\r\n\r\nI have searched high and low, and spent a lot of time with trial-and-error, but nothing has really worked. I highly appreciate your support in advance, thank you.\r\nHow to delete many and keep few objects in big JSON file? \r\n",
        "link": "https://stackoverflow.com/questions/68412090/how-to-delete-many-and-keep-few-objects-in-big-json",
        "title": "How to delete many and keep few objects in big JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1661899401,
                "last_edit_date": 1661899401,
                "creation_date": 1626474858,
                "answer_id": 68415895,
                "question_id": 68415620,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;{&quot;collection&quot;: .}&#39; &lt;in.json &gt;out.json\r\n```\r\n\r\nAnd if your JSON is the output of another jq command, just add the collection at the end, like: \r\n\r\n```bash\r\n# For example: delete an element and then wrap \r\n# entries around a &quot;records&quot; attribute (assuming\r\n# the date is already a JSON list):\r\njq &#39;[.[] | del(.undesiredAttribute)] | {&quot;records&quot;: .}&#39;\r\n``` \r\n\r\nThen the output is:\r\n\r\n```\r\n{&quot;records&quot;:[{&quot;name&quot;:&quot;Foo&quot;},{&quot;name&quot;:&quot;Bar&quot;}]}\r\n```",
                "title": "Adding a new root level property to JSON object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1661899401,
        "creation_date": 1626472500,
        "question_id": 68415620,
        "body_markdown": "I have a large JSON file (about 7K lines) with deeply nested items which has a missing required property `collection` that I need to add.\r\nCurrent JSON object:\r\n\r\n```\r\n{\r\n  &quot;item&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;123&quot;,\r\n          &quot;name&quot;: &quot;Customer&quot;,\r\n          &quot;item&quot;: [\r\n              {\r\n                 &quot;id&quot;: &quot;456&quot;,\r\n                 &quot;name&quot;: &quot;Retrieve a customer&quot;\r\n....\r\n```\r\n\r\nUsing a bash script, I need to add a top level property `&quot;collection&quot;`  like this, which still contains the same nested items within it. This is my desired result:\r\n\r\n```\r\n{\r\n  &quot;collection&quot;: {\r\n    &quot;item&quot;: [\r\n         {\r\n           &quot;id&quot;: &quot;123&quot;,\r\n           &quot;name&quot;: &quot;Customer&quot;,\r\n           &quot;item&quot;: [\r\n               {\r\n                &quot;id&quot;: &quot;456&quot;,\r\n                &quot;name&quot;: &quot;Retrieve a customer&quot;,\r\n....       \r\n```\r\nAt the end of the JSON object I also need the matching closing `}` brace at the end of the file for my newly added `collection:` key. Is there a way to do this with JQ?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68415620/adding-a-new-root-level-property-to-json-object-using-jq",
        "title": "Adding a new root level property to JSON object using jq"
    },
    {
        "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": 1,
                "creation_date": 1626627771,
                "post_id": 68430853,
                "comment_id": 120938591,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22240493,
                    "reputation": 3,
                    "user_id": 16475097,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJzIgpox5sAuGnKpJ8DMe1poANO-IN495cEWh7Jf=k-s256",
                    "display_name": "SVC RVBRAND",
                    "link": "https://stackoverflow.com/users/16475097/svc-rvbrand"
                },
                "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": 1626630438,
                "post_id": 68430853,
                "comment_id": 120939260,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1626669409,
                "last_edit_date": 1626669409,
                "creation_date": 1626633573,
                "answer_id": 68432076,
                "question_id": 68430853,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to aggregate your inputs into an object where you can easily navigate first. Then the rest is going to be plain recursion.\r\n\r\nLike, with **-n/--null-input** specified, something like this should work just fine:\r\n```\r\ndef prepare:\r\n  reduce inputs as $in ({};\r\n    . + ($in | {&quot;id:\\(.id)&quot;: .})\r\n  );\r\ndef search($id):\r\n  def follow($ref):\r\n    if has($ref) then .[$ref], follow(.[$ref].ref) else empty end;\r\n  follow(&quot;id:\\($id)&quot;);\r\nprepare | search(1)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/iGuCUItL6w)&lt;/sup&gt;",
                "title": "Yield objects recursively in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1626669409,
        "creation_date": 1626624196,
        "last_edit_date": 1626635787,
        "question_id": 68430853,
        "body_markdown": "I have this list of json objects\r\n```\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;ref&quot;: &quot;id:2&quot;,\r\n  &quot;msg&quot;: &quot;1&quot;\r\n}\r\n{\r\n  &quot;id&quot;: 2,\r\n  &quot;ref&quot;: &quot;none&quot;,\r\n  &quot;msg&quot;: &quot;2&quot;\r\n}\r\n{\r\n  &quot;id&quot;: 3,\r\n  &quot;ref&quot;: &quot;none&quot;,\r\n  &quot;msg&quot;: &quot;3&quot;\r\n}\r\n````\r\nI want to be able (let&#39;s say search(id) is a function). if I call search(1) it needs to return the list of objects from (id=1) and all the ref objects that follow until one of the object has &quot;ref&quot;: &quot;none&quot; or the `id` it references does not exist in the list of objects.\r\n\r\n`&quot;ref&quot;: &quot;id:2&quot;,`, references the object with (id=2). I want to get all those objects until the `ref` field of one object is none or makes reference to a non-existing `id` in the list like &quot;ref:101&quot; (id=101 is not in the list)\r\n\r\nDesired output for search(1)\r\n\r\n```\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;ref&quot;: &quot;id:2&quot;,\r\n  &quot;msg&quot;: &quot;1&quot;\r\n}\r\n{\r\n  &quot;id&quot;: 2,\r\n  &quot;ref&quot;: &quot;none&quot;,\r\n  &quot;msg&quot;: &quot;2&quot;\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/68430853/yield-objects-recursively-in-jq",
        "title": "Yield objects recursively in JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1626681555,
                "creation_date": 1626681555,
                "answer_id": 68437032,
                "question_id": 68436928,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were close.\r\n```\r\nto_entries[] | [{name: .key} + .value]\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/bwxqWYFsDe)&lt;/sup&gt;",
                "title": "Converting JSON object to Array using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1662425896,
        "creation_date": 1626681011,
        "last_edit_date": 1662425896,
        "question_id": 68436928,
        "body_markdown": "I am trying to convert map of objects to an array with jq\r\n\r\nMy Input is \r\n\r\n    {\r\n      &quot;fish-chips&quot;: {\r\n        &quot;likeDislikeRatio&quot;: [&quot;80%&quot;, &quot;20%&quot;],\r\n        &quot;country&quot;: [&quot;BRIT_FOOD&quot;,&quot;USA_FOOD&quot;]\r\n      },\r\n      &quot;sausage&quot;: {\r\n        &quot;likeDislikeRatio&quot;: [&quot;75%&quot;, &quot;25%&quot;],\r\n        &quot;country&quot;: [&quot;EU_FOOD&quot;]\r\n      },\r\n      &quot;cheese-burger&quot;: {\r\n        &quot;likeDislikeRatio&quot;: [&quot;25%&quot;, &quot;75%&quot;],\r\n        &quot;country&quot;: [\r\n          &quot;BRIT_FOOD&quot;,\r\n          &quot;USA_FOOD&quot;,\r\n          &quot;EU_FOOD&quot;,\r\n          &quot;DEFAULT&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\nAnd my expected output is \r\n\r\n    [\r\n      {\r\n    &quot;name&quot; : &quot;fish-chips&quot;,    \r\n    &quot;likeDislikeRatio&quot;: [\r\n          &quot;80%&quot;,\r\n          &quot;20%&quot;\r\n        ],\r\n        &quot;country&quot;: [\r\n          &quot;BRIT_FOOD&quot;,\r\n          &quot;USA_FOOD&quot;\r\n        ]\r\n      }\r\n    ]\r\n    [\r\n      {\r\n    &quot;name&quot; : &quot;sausage&quot;,\r\n        &quot;likeDislikeRatio&quot;: [\r\n          &quot;75%&quot;,\r\n          &quot;25%&quot;\r\n        ],\r\n        &quot;country&quot;: [\r\n          &quot;EU_FOOD&quot;\r\n        ]\r\n      }\r\n    ]\r\n    [\r\n      {\r\n    &quot;name&quot; : &quot;cheese-burger&quot;,\r\n        &quot;likeDislikeRatio&quot;: [\r\n          &quot;25%&quot;,\r\n          &quot;75%&quot;\r\n        ],\r\n        &quot;country&quot;: [\r\n          &quot;BRIT_FOOD&quot;,\r\n          &quot;USA_FOOD&quot;,\r\n          &quot;EU_FOOD&quot;,\r\n          &quot;DEFAULT&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\n**what I tried**\r\nThe closest filter I could find was **to_entries[] | [.key, .value]**\r\n\r\nbut the output is not as what I expected and I feel that there should be one more filter with this to get the desired out put\r\n\r\nCurrent Output\r\n\r\n    [\r\n      &quot;fish-chips&quot;,\r\n      {\r\n        &quot;likeDislikeRatio&quot;: [\r\n          &quot;80%&quot;,\r\n          &quot;20%&quot;\r\n        ],\r\n        &quot;country&quot;: [\r\n          &quot;BRIT_FOOD&quot;,\r\n          &quot;USA_FOOD&quot;\r\n        ]\r\n      }\r\n    ]\r\n    [\r\n      &quot;sausage&quot;,\r\n      {\r\n        &quot;likeDislikeRatio&quot;: [\r\n          &quot;75%&quot;,\r\n          &quot;25%&quot;\r\n        ],\r\n        &quot;country&quot;: [\r\n          &quot;EU_FOOD&quot;\r\n        ]\r\n      }\r\n    ]\r\n    [\r\n      &quot;cheese-burger&quot;,\r\n      {\r\n        &quot;likeDislikeRatio&quot;: [\r\n          &quot;25%&quot;,\r\n          &quot;75%&quot;\r\n        ],\r\n        &quot;country&quot;: [\r\n          &quot;BRIT_FOOD&quot;,\r\n          &quot;USA_FOOD&quot;,\r\n          &quot;EU_FOOD&quot;,\r\n          &quot;DEFAULT&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nI saw many posts on doing the opposite that is converting array to map using either reduce or INDEX but not what I expected.",
        "link": "https://stackoverflow.com/questions/68436928/converting-json-object-to-array-using-jq",
        "title": "Converting JSON object to Array using JQ"
    },
    {
        "tags": [
            "json",
            "jq",
            "cartesian-product"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1626733943,
                "last_edit_date": 1626733943,
                "creation_date": 1626733536,
                "answer_id": 68447637,
                "question_id": 68447475,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Introducing a single &quot;$-variable&quot; keeps things brief and straightforward:\r\n```\r\nmap(range(0; .x|length) as $i\r\n    | {a: .x[$i], b: .y[$i]})\r\n```\r\n\r\nbut a $-variable free solution only requires one more line:\r\n\r\n```\r\nmap([.x, .y]\r\n    | transpose[]\r\n    | {a: .[0], b: .[1]})\r\n```",
                "title": "jq: how to change structure of JSON avoiding cartesian product?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1626738753,
        "creation_date": 1626732116,
        "last_edit_date": 1626738753,
        "question_id": 68447475,
        "body_markdown": "I have thin JSON input:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;x&quot;: [\r\n      &quot;2020-02-24T00:00:00&quot;,\r\n      &quot;2020-02-25T00:00:00&quot;,\r\n      &quot;2020-02-26T00:00:00&quot;\r\n    ],\r\n    &quot;y&quot;: [\r\n      3,\r\n      2,\r\n      6\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nAnd I would like to obtain:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;a&quot;: &quot;2020-02-24T00:00:00&quot;,\r\n    &quot;b&quot;: 3\r\n  },\r\n  {\r\n    &quot;a&quot;: &quot;2020-02-25T00:00:00&quot;,\r\n    &quot;b&quot;: 2\r\n  },\r\n  {\r\n    &quot;a&quot;: &quot;2020-02-26T00:00:00&quot;,\r\n    &quot;b&quot;: 6\r\n  }\r\n]\r\n```\r\n\r\nIf I apply [`.[]|{a:.x[],b:.y[]}`](https://jqplay.org/s/kijmcduRMw) I obtain the cartesian product (9 items).\r\n\r\nHow to change the structure of this JSON avoiding cartesian product?",
        "link": "https://stackoverflow.com/questions/68447475/jq-how-to-change-structure-of-json-avoiding-cartesian-product",
        "title": "jq: how to change structure of JSON avoiding cartesian product?"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1626788553,
                "post_id": 68455813,
                "comment_id": 120982831,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1626789836,
                "post_id": 68455813,
                "comment_id": 120983375,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1626799764,
                "creation_date": 1626799764,
                "answer_id": 68458609,
                "question_id": 68455813,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one way you could do it:\r\n\r\n_parse.jq_\r\n\r\n```jq\r\n# We are only interested in the request and response objects\r\n.[] | [ { httpRequest, httpResponse } ] |\r\n\r\n# Delete unwanted paths\r\ndel(\r\n    .[].httpRequest.headers,\r\n    .[].httpRequest.keepAlive,\r\n    .[].httpRequest.secure,\r\n    .[].httpRequest.body.rawBytes,\r\n    .[].httpResponse.body.rawBytes\r\n) |\r\n\r\n# Reshape the httpResponse object\r\n.[].httpResponse |= \r\n  ( \r\n    {\r\n      statusCode,\r\n      reasonPhrase,\r\n      &quot;headers&quot; : {\r\n        &quot;Content-Type&quot;   : .headers.&quot;Content-Type&quot;,\r\n        &quot;content-length&quot; : .headers.&quot;content-length&quot;\r\n      },\r\n      body \r\n    }\r\n  )\r\n```\r\nRun it like this:\r\n```\r\njq -f parse.jq infile.json\r\n```\r\nOutput:\r\n```json\r\n[\r\n  {\r\n    &quot;httpRequest&quot;: {\r\n      &quot;method&quot;: &quot;POST&quot;,\r\n      &quot;path&quot;: &quot;/catalog-data-rest/oid/search.xml&quot;,\r\n      &quot;body&quot;: {\r\n        &quot;type&quot;: &quot;STRING&quot;,\r\n        &quot;string&quot;: &quot;&lt;request&gt;&lt;oid&gt;2.16.724.4.402&lt;/oid&gt;&lt;startIndex&gt;1&lt;/startIndex&gt;&lt;pageSize&gt;100&lt;/pageSize&gt;&lt;/request&gt;&quot;,\r\n        &quot;contentType&quot;: &quot;text/html; charset=utf-8&quot;\r\n      }\r\n    },\r\n    &quot;httpResponse&quot;: {\r\n      &quot;statusCode&quot;: 200,\r\n      &quot;reasonPhrase&quot;: &quot;OK&quot;,\r\n      &quot;headers&quot;: {\r\n        &quot;Content-Type&quot;: [\r\n          &quot;application/xml&quot;\r\n        ],\r\n        &quot;content-length&quot;: [\r\n          &quot;29089&quot;\r\n        ]\r\n      },\r\n      &quot;body&quot;: {\r\n        &quot;type&quot;: &quot;XML&quot;,\r\n        &quot;xml&quot;: &quot;string-value&quot;,\r\n        &quot;contentType&quot;: &quot;application/xml&quot;\r\n      }\r\n    }\r\n  }\r\n]\r\n```",
                "title": "jq: pick and remove nested fields"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1654457127,
                "last_edit_date": 1654457127,
                "creation_date": 1626838975,
                "answer_id": 68463706,
                "question_id": 68455813,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Create a fresh object (using `{}`) when you want to pick, and use `del` when you want to remove.\r\n\r\n```jq\r\nmap({\r\n   &quot;httpRequest&quot;: (\r\n      .httpRequest |\r\n      del(.headers, .keepAlive, .secure, .body.rawBytes)\r\n   ),\r\n   &quot;httpResponse&quot;: (\r\n      .httpResponse |\r\n      del(.body.rawBytes) |\r\n      {\r\n         statusCode,\r\n         reasonPhrase,\r\n         &quot;headers&quot;: {\r\n            &quot;Content-Type&quot;:   .headers.&quot;Content-Type&quot;,\r\n            &quot;Content-Length&quot;: .headers.&quot;content-length&quot;\r\n         },\r\n         body\r\n      }\r\n   )\r\n})\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/JRoMHYNCkj2)\r\n\r\nThe issue with both this solution and the previously-posted one is that HTTP headers are case-insensitive, so I don&#39;t think `.headers.&quot;Content-Type&quot;` and `.headers.&quot;content-length&quot;` will always work. Adjust as necessary.\r\n",
                "title": "jq: pick and remove nested fields"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1654457127,
        "creation_date": 1626788009,
        "last_edit_date": 1626846030,
        "question_id": 68455813,
        "body_markdown": "Here is my json:\r\n\r\n```lang-json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;7250078e-5fbf-43d7-9c67-94b88fbf44d8&quot;,\r\n    &quot;priority&quot;: 0,\r\n    &quot;httpRequest&quot;: {\r\n      &quot;method&quot;: &quot;POST&quot;,\r\n      &quot;path&quot;: &quot;/catalog-data-rest/oid/search.xml&quot;,\r\n      &quot;headers&quot;: {\r\n        &quot;Host&quot;: [\r\n          &quot;preproduccio.gcatalegs.isisscat.intranet.gencat.cat:8443&quot;\r\n        ],\r\n        &quot;Authorization&quot;: [\r\n          &quot;Basic VVNVTVBJVFNUOkJ4c2w3MjU5&quot;\r\n        ],\r\n        &quot;User-Agent&quot;: [\r\n          &quot;curl/7.58.0&quot;\r\n        ],\r\n        &quot;Accept&quot;: [\r\n          &quot;*/*&quot;\r\n        ],\r\n        &quot;Content-Type&quot;: [\r\n          &quot;text/html; charset=utf-8&quot;\r\n        ],\r\n        &quot;Content-Length&quot;: [\r\n          &quot;94&quot;\r\n        ]\r\n      },\r\n      &quot;keepAlive&quot;: true,\r\n      &quot;secure&quot;: true,\r\n      &quot;body&quot;: {\r\n        &quot;type&quot;: &quot;STRING&quot;,\r\n        &quot;string&quot;: &quot;&lt;request&gt;&lt;oid&gt;2.16.724.4.402&lt;/oid&gt;&lt;startIndex&gt;1&lt;/startIndex&gt;&lt;pageSize&gt;100&lt;/pageSize&gt;&lt;/request&gt;&quot;,\r\n        &quot;rawBytes&quot;: &quot;PHJlcXVlc3Q+PG9pZD4yLjE2LjcyNC40LjQwMjwvb2lkPjxzdGFydEluZGV4PjE8L3N0YXJ0SW5kZXg+PHBhZ2VTaXplPjEwMDwvcGFnZVNpemU+PC9yZXF1ZXN0Pg==&quot;,\r\n        &quot;contentType&quot;: &quot;text/html; charset=utf-8&quot;\r\n      }\r\n    },\r\n    &quot;httpResponse&quot;: {\r\n      &quot;statusCode&quot;: 200,\r\n      &quot;reasonPhrase&quot;: &quot;OK&quot;,\r\n      &quot;headers&quot;: {\r\n        &quot;Date&quot;: [\r\n          &quot;Tue, 20 Jul 2021 11:07:40 GMT&quot;\r\n        ],\r\n        &quot;X-Powered-By&quot;: [\r\n          &quot;Servlet/3.0&quot;\r\n        ],\r\n        &quot;X-Content-Type-Options&quot;: [\r\n          &quot;nosniff&quot;\r\n        ],\r\n        &quot;X-XSS-Protection&quot;: [\r\n          &quot;1; mode=block&quot;\r\n        ],\r\n        &quot;Cache-Control&quot;: [\r\n          &quot;no-cache, no-store, max-age=0, must-revalidate&quot;\r\n        ],\r\n        &quot;Pragma&quot;: [\r\n          &quot;no-cache&quot;\r\n        ],\r\n        &quot;Expires&quot;: [\r\n          &quot;0&quot;\r\n        ],\r\n        &quot;Strict-Transport-Security&quot;: [\r\n          &quot;max-age=31536000 ; includeSubDomains&quot;\r\n        ],\r\n        &quot;X-Frame-Options&quot;: [\r\n          &quot;DENY&quot;\r\n        ],\r\n        &quot;Set-Cookie&quot;: [\r\n          &quot;JSESSIONID=0000r6GgpYaB7bQiXRaS8zB8qw8:19pp48tgo; Path=/; HttpOnly&quot;\r\n        ],\r\n        &quot;Keep-Alive&quot;: [\r\n          &quot;timeout=10, max=100&quot;\r\n        ],\r\n        &quot;Connection&quot;: [\r\n          &quot;Keep-Alive&quot;\r\n        ],\r\n        &quot;Content-Type&quot;: [\r\n          &quot;application/xml&quot;\r\n        ],\r\n        &quot;Content-Language&quot;: [\r\n          &quot;en-US&quot;\r\n        ],\r\n        &quot;content-length&quot;: [\r\n          &quot;29089&quot;\r\n        ]\r\n      },\r\n      &quot;cookies&quot;: {\r\n        &quot;JSESSIONID&quot;: &quot;0000r6GgpYaB7bQiXRaS8zB8qw8:19pp48tgo&quot;\r\n      },\r\n      &quot;body&quot;: {\r\n        &quot;type&quot;: &quot;XML&quot;,\r\n        &quot;xml&quot;: &quot;string-value&quot;,\r\n        &quot;rawBytes&quot;: &quot;string-value&quot;,\r\n        &quot;contentType&quot;: &quot;application/xml&quot;\r\n      }\r\n    },\r\n    &quot;times&quot;: {\r\n      &quot;remainingTimes&quot;: 1\r\n    },\r\n    &quot;timeToLive&quot;: {\r\n      &quot;unlimited&quot;: true\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nI need to remove and pick following fields:\r\n\r\nFrom .httpRequest I need to REMOVE:\r\n```\r\n.httpRequest.headers\r\n.httpRequest.keepAlive\r\n.httpRequest.secure\r\n.httpRequest.body.rawBytes\r\n```\r\n\r\nDesired result:\r\n\r\n```lang-json\r\n    &quot;httpRequest&quot;: {\r\n      &quot;method&quot;: &quot;POST&quot;,\r\n      &quot;path&quot;: &quot;/catalog-data-rest/oid/search.xml&quot;,\r\n      &quot;body&quot;: {\r\n        &quot;type&quot;: &quot;STRING&quot;,\r\n        &quot;string&quot;: &quot;&lt;request&gt;&lt;oid&gt;2.16.724.4.402&lt;/oid&gt;&lt;startIndex&gt;1&lt;/startIndex&gt;&lt;pageSize&gt;100&lt;/pageSize&gt;&lt;/request&gt;&quot;,\r\n        &quot;contentType&quot;: &quot;text/html; charset=utf-8&quot;\r\n      }\r\n    }\r\n```\r\n\r\nFrom .httpResponse I need to PICK:\r\n```\r\n.httpResponse.statusCode\r\n.httpResponse.reasonPhrase\r\n.httpResponse.headers.Content-Type\r\n.httpResponse.headers.content-lenght\r\n```\r\n\r\nFrom .httpResponse I need to REMOVE:\r\n```\r\n.httpResponse.body.rawBytes\r\n```\r\n\r\nDesired result would be:\r\n\r\n```lang-json\r\n    &quot;httpResponse&quot;: {\r\n      &quot;statusCode&quot;: 200,\r\n      &quot;reasonPhrase&quot;: &quot;OK&quot;,\r\n      &quot;headers&quot;: {\r\n        &quot;Content-Type&quot;: [\r\n          &quot;application/xml&quot;\r\n        ],\r\n        &quot;content-length&quot;: [\r\n          &quot;29089&quot;\r\n        ]\r\n      },\r\n      &quot;body&quot;: {\r\n        &quot;type&quot;: &quot;XML&quot;,\r\n        &quot;xml&quot;: &quot;string-value&quot;,\r\n        &quot;contentType&quot;: &quot;application/xml&quot;\r\n      }\r\n    }\r\n```\r\n\r\nSo my final json would be:\r\n\r\n```lang-json\r\n[\r\n  {\r\n    &quot;httpRequest&quot;: {\r\n      &quot;method&quot;: &quot;POST&quot;,\r\n      &quot;path&quot;: &quot;/catalog-data-rest/oid/search.xml&quot;,\r\n      &quot;body&quot;: {\r\n        &quot;type&quot;: &quot;STRING&quot;,\r\n        &quot;string&quot;: &quot;&lt;request&gt;&lt;oid&gt;2.16.724.4.402&lt;/oid&gt;&lt;startIndex&gt;1&lt;/startIndex&gt;&lt;pageSize&gt;100&lt;/pageSize&gt;&lt;/request&gt;&quot;,\r\n        &quot;contentType&quot;: &quot;text/html; charset=utf-8&quot;\r\n      }\r\n    },\r\n    &quot;httpResponse&quot;: {\r\n      &quot;statusCode&quot;: 200,\r\n      &quot;reasonPhrase&quot;: &quot;OK&quot;,\r\n      &quot;headers&quot;: {\r\n        &quot;Content-Type&quot;: [\r\n          &quot;application/xml&quot;\r\n        ],\r\n        &quot;content-length&quot;: [\r\n          &quot;29089&quot;\r\n        ]\r\n      },\r\n      &quot;body&quot;: {\r\n        &quot;type&quot;: &quot;XML&quot;,\r\n        &quot;xml&quot;: &quot;string-value&quot;,\r\n        &quot;contentType&quot;: &quot;application/xml&quot;\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nI hope I&#39;ve explained so well.\r\n\r\nUp to now I&#39;ve able to get [this demo](https://jqplay.org/s/iALEgJ6Tqb)",
        "link": "https://stackoverflow.com/questions/68455813/jq-pick-and-remove-nested-fields",
        "title": "jq: pick and remove nested fields"
    },
    {
        "tags": [
            "jq",
            "systemd-journald"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1626894010,
                "creation_date": 1626894010,
                "answer_id": 68475141,
                "question_id": 68471082,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. A jq-only solution would be:\r\n```\r\n[inputs|select(.MESSAGE|test(&quot;My search string&quot;)) | length] | length\r\n```\r\n\r\n2. Notice there is no need for the initial or final `.*` in the regex\r\n\r\n3. For future reference, please follow the &quot;mcve&quot; guidelines at http://stackoverflow.com/help/mcve .\r\nIn particular, your JSON got mangled while copying-and-pasting into SO; and an actual example, with expected output, would be appreciated.",
                "title": "Using jq to loop over objects and return an iterated value"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1626894010,
        "creation_date": 1626876669,
        "question_id": 68471082,
        "body_markdown": "I have an enteresting TODO that I&#39;d like some eyes on. I&#39;m using `journalctl` to grab system journal entries and output as JSON. `journalctl` outputs as JSON objects separated by a newline.\r\n\r\nHere&#39;s a sample of a JSON object outputted from journalctl:\r\n\r\n    { &quot;__CURSOR&quot; : &quot;s=bd3afe956aec45d89cf3939e839c3647;i=3e084;b=6dd8a3060bdb448d848f4694339c6e94;m=5d0fd53a6;t=5c797ae76d38f;x=6cdb742ba83df8f5&quot;, &quot;__REALTIME_TIMES\r\n    TAMP&quot; : &quot;1626829164613612&quot;, &quot;__MONOTONIC_TIMESTAMP&quot; : &quot;24980054950&quot;, &quot;_BOOT_ID&quot; : &quot;6dd8a3030bdb446d858f4694337c6e94&quot;, &quot;PRIORITY&quot; : &quot;6&quot;, &quot;SYSLOG_FACILITY&quot; : &quot;3&quot;,\r\n    &quot;CODE_FILE&quot; : &quot;../src/core/job.c&quot;, &quot;CODE_LINE&quot; : &quot;845&quot;, &quot;CODE_FUNC&quot; : \r\n    &quot;job_log_status_message&quot;, &quot;SYSLOG_IDENTIFIER&quot; : &quot;systemd&quot;, &quot;JOB_TYPE&quot; : &quot;start&quot;, &quot;JOB_RES\r\n    ULT&quot; : &quot;done&quot;, &quot;MESSAGE_ID&quot; : &quot;39f53479d3a045ac8e11786248231fbf&quot;, &quot;_TRANSPORT&quot; : &quot;journal&quot;, &quot;_PID&quot; : &quot;11282&quot;, &quot;_UID&quot; : &quot;1162&quot;, &quot;_GID&quot; : &quot;1162&quot;, &quot;_COMM&quot; : &quot;syste\r\n    md&quot;, &quot;_EXE&quot; : &quot;/lib/systemd/systemd&quot;, &quot;_CMDLINE&quot; : &quot;/lib/systemd/systemd --user&quot;, &quot;_CAP_EFFECTIVE&quot; : &quot;0&quot;, &quot;_SELINUX_CONTEXT&quot; : &quot;unconfined\\n&quot;, &quot;_AUDIT_SESSION&quot;\r\n    : &quot;974&quot;, &quot;_AUDIT_LOGINUID&quot; : &quot;1162&quot;, &quot;_SYSTEMD_CGROUP&quot; : &quot;/user.slice/user-1162.slice/user@1162.service/init.scope&quot;, &quot;_SYSTEMD_OWNER_UID&quot; : &quot;1162&quot;, &quot;_SYSTEMD_UN\r\n    IT&quot; : &quot;user@1162.service&quot;, &quot;_SYSTEMD_USER_UNIT&quot; : &quot;init.scope&quot;, &quot;_SYSTEMD_SLICE&quot; : &quot;user-1162.slice&quot;, &quot;_SYSTEMD_USER_SLICE&quot; : &quot;-.slice&quot;, &quot;_SYSTEMD_INVOCATION_ID\r\n    &quot; : &quot;1f72568e79c34f14a525f98ce6a151c2&quot;, &quot;_MACHINE_ID&quot; : &quot;32c9faf3dd90422881ce03690ebf0015&quot;, &quot;_HOSTNAME&quot; : &quot;ip-192-168-22-27&quot;, &quot;MESSAGE&quot; : &quot;Listening on port.&quot;, &quot;USER_UNIT&quot; : &quot;dirmngr.socket&quot;, &quot;USER_INVOCATION_ID&quot; : \r\n    &quot;7c1e914aada947cd80a45d68275751dc&quot;, &quot;_SOURCE_REALTIME_TIMESTAMP&quot; :\r\n    &quot;1626829165607533&quot; }\r\n\r\nI&#39;m using `--after-cursor` to get a subset of the journal. There is no `--before-cursor` option afaik so I&#39;m trying to find a way to stop at a specific cursor and search the JSON objects between the `first` and `last` cursor.\r\n\r\nAt the moment I&#39;m using the following snippet (sloppy by my own admission) to search the journal after a cursor and count the objects where a match is found. \r\n\r\n    journalctl -u my-service --after-cursor=&quot;$FIRST_CURSOR&quot; -o json | jq -n &#39;inputs|select(.MESSAGE|test(&quot;.*My search string .*&quot;)) | jq length | wc -l\r\n\r\nI&#39;d like to do this more intelligently with possibly an if/else statement but I&#39;m a `jq` novice.\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/68471082/using-jq-to-loop-over-objects-and-return-an-iterated-value",
        "title": "Using jq to loop over objects and return an iterated value"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1626960585,
                "last_edit_date": 1626960585,
                "creation_date": 1626894510,
                "answer_id": 68475237,
                "question_id": 68472959,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using your approach, the jq `filter` you&#39;d need is `getpath`:\r\n\r\n```\r\ngetpath(paths | select(.[-1] == &quot;inner1&quot;) | .[0:-2])\r\n```\r\n\r\nAs an alternative, you could also use `..`, e.g. perhaps:\r\n\r\n    .. | objects | map_values( select(has(&quot;inner1&quot;))) | select(length&gt;0)",
                "title": "jq select where property contains property by name"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1626960698,
        "creation_date": 1626883748,
        "last_edit_date": 1626960698,
        "question_id": 68472959,
        "body_markdown": "I have a basic JSON structure:\r\n\r\n```json\r\n{\r\n  &quot;A&quot;: {\r\n    &quot;Option1&quot;: {\r\n      &quot;contains&quot;: {\r\n         &quot;inner1&quot;: { ... },\r\n         &quot;inner2&quot;: { ... },\r\n         &quot;innerN&quot;: { ... }\r\n      }\r\n    }\r\n\r\n    &quot;Option2&quot;: {\r\n         &quot;innerX&quot;: { ... },\r\n         &quot;innerY&quot;: { ... },\r\n         &quot;innerZ&quot;: { ... }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nWhat I need is to select either `Option1` or `Option2` based on whether or not it contains user input.\r\n\r\nFor example:\r\n\r\n- If the user provides `inner1`, return the `Option1` object\r\n- If the user provides `innerY` return the `Option2` object\r\n- etc.\r\n\r\nI have been successful if the options were an array, but I cannot do this if they are objects themselves.\r\n\r\nI tried looking at [this example using `descend`](https://stackoverflow.com/questions/43946092/how-to-recurse-with-jq-on-nested-json-where-each-object-has-a-name-property) but didn&#39;t quite follow.\r\n\r\n---\r\n\r\n## Update 1\r\n\r\nI got a sloppy means to do this and then reuse the expression:\r\n\r\n```bash\r\njq -r &#39;paths | select(.[-1] == &quot;inner1&quot;) | .[0:-2] | join(&quot;.&quot;)&#39; myFile.json\r\n```\r\n\r\nI can store that in a variable and reuse it. But that seems sloppy. It&#39;s a workaround, though.\r\n\r\nTo test that out I did this:\r\n\r\n```bash\r\njq .$(THAT_COMMAND_ABOVE) myFile.json\r\n```",
        "link": "https://stackoverflow.com/questions/68472959/jq-select-where-property-contains-property-by-name",
        "title": "jq select where property contains property by name"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1626963239,
                "post_id": 68486144,
                "comment_id": 121036337,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22273724,
                    "reputation": 75,
                    "user_id": 16503256,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e42e01c3f7dc816e909b9c58a91af482?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "gmpy1990",
                    "link": "https://stackoverflow.com/users/16503256/gmpy1990"
                },
                "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": 1626963348,
                "post_id": 68486144,
                "comment_id": 121036383,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1626965188,
                "last_edit_date": 1626965188,
                "creation_date": 1626964388,
                "answer_id": 68486720,
                "question_id": 68486144,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njson=&#39;{&quot;price1&quot;:&quot;120.10&quot;,&quot;price2&quot;:&quot;110.30&quot;,&quot;price3&quot;:&quot;244.45&quot;}&#39;\r\n\r\narray=($(jq -r &#39;to_entries[] | ( &quot;\\(.key):\\(.value)&quot;)&#39; &lt;&lt;&lt; &quot;$json&quot;))\r\necho ${array[@]}\r\nprintf &#39;%s\\n&#39; &quot;${array[@]}&quot;\r\ndeclare -p array\r\n\r\necho\r\n\r\narray=($(jq -r &#39;to_entries[] | ( &quot;\\(.key):\\(.value)&quot;) | @sh&#39; &lt;&lt;&lt; &quot;$json&quot;))\r\necho ${array[@]}\r\nprintf &#39;%s\\n&#39; &quot;${array[@]}&quot;\r\ndeclare -p array\r\n\r\n```\r\n\r\nOutput:\r\n\r\n```\r\nprice1:120.10 price2:110.30 price3:244.45\r\nprice1:120.10\r\nprice2:110.30\r\nprice3:244.45\r\ndeclare -a array=&#39;([0]=&quot;price1:120.10&quot; [1]=&quot;price2:110.30&quot; [2]=&quot;price3:244.45&quot;)&#39;\r\n\r\n&#39;price1:120.10&#39; &#39;price2:110.30&#39; &#39;price3:244.45&#39;\r\n&#39;price1:120.10&#39;\r\n&#39;price2:110.30&#39;\r\n&#39;price3:244.45&#39;\r\ndeclare -a array=&#39;([0]=&quot;&#39;\\&#39;&#39;price1:120.10&#39;\\&#39;&#39;&quot; [1]=&quot;&#39;\\&#39;&#39;price2:110.30&#39;\\&#39;&#39;&quot; [2]=&quot;&#39;\\&#39;&#39;price3:244.45&#39;\\&#39;&#39;&quot;)&#39;\r\n\r\n```\r\n",
                "title": "how to parse json in bash script as an array? array value should have both key:value format"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1627483336,
                "last_edit_date": 1627483336,
                "creation_date": 1626964501,
                "answer_id": 68486749,
                "question_id": 68486144,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Parsing `json` with `sed` is probably a bad idea. But let&#39;s assume it is a super-simple and regular kind of `json` format. You were not too far from a working solution:\r\n\r\n    $ array=($(sed -nr &#39;s/.*&quot;(.*)&quot;.*&quot;(.*)&quot;.*/\\1:\\2/p&#39; json.file))\r\n    $ echo ${array[*]}\r\n    price1:120.10 price2:110.30 price3:244.45\r\n\r\nThe `p` flag of the substitute command tells sed to print the result if there was a match. It is good to know. If you have only two quoted strings per line of interest it should work. The regular expression `.*&quot;(.*)&quot;.*&quot;(.*)&quot;.*` matches anything - `.*` - followed by a double quote, anything again, another double quote... The parentheses - `(.*)` - do not change what is matched. It just records the matched part between parentheses in one of nine buffers that can be used in the replacement string - `\\1:\\2`. So here, the replacement string corresponds to:\r\n\r\n    &lt;first recorded match&gt;:&lt;second recorded match&gt;\r\n\r\nIf you want to be more specific about the matching lines you can. For instance:\r\n\r\n    sed -nr &#39;s/^  &quot;(.*)&quot; : &quot;(.*)&quot;,?$/\\1:\\2/p&#39; json.file\r\n\r\nAlso specifies that there are 2 leading spaces, that the colon is preceded and followed by one single space and that there is a optional comma after the last quote and before the end of line.\r\n\r\nBut there is also the much simpler:\r\n\r\n    sed -nr &#39;s/[[:space:]&quot;,]//gp&#39; json.file\r\n\r\nthat just removes all spaces, double quotes and commas, printing only the matching lines. And guess what? It is what you (apparently) want.\r\n\r\nAnyway, remember that if your `json` files are more complex than what you show `sed` is definitely not the right tool.",
                "title": "how to parse json in bash script as an array? array value should have both key:value format"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1626965101,
                "creation_date": 1626965101,
                "answer_id": 68486914,
                "question_id": 68486144,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your solution just needs to extract the extra data:\r\n\r\n    array=( $(sed -n &#39;/{/,/}/{s/&quot;\\([^&quot;]*\\)&quot;[^:]*:[^&quot;]*&quot;\\([^&quot;]*\\).*/\\1:\\2/p;}&#39; &lt;&lt;&lt; &quot;$j&quot;) )\r\n    echo ${array[@]}\r\n    price1:120.10 price2:110.30 price3:244.45\r\n\r\nSimpler looking solutions may work too, but I&#39;m assuming that you wrote your pattern like that deliberately.\r\n\r\nThe key trick here is to enclose part of your pattern with escaped brackets `\\(...\\)` and then have a numbered substitution for each in the output part `\\1`, `\\2`, etc.",
                "title": "how to parse json in bash script as an array? array value should have both key:value format"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1626977948,
                "creation_date": 1626977948,
                "answer_id": 68489786,
                "question_id": 68486144,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For bash scripting, you might want to use an Associative array:\r\n\r\n```bash\r\ndeclare -A prices\r\nwhile IFS=$&#39;\\t&#39; read -r key value; do\r\n    prices[$key]=$value\r\ndone &lt; &lt;(\r\n    jq -r &#39;to_entries[] | [.key, .value] | @tsv&#39; json.file\r\n)\r\n```\r\nThen, inspect the array\r\n```bash\r\ndeclare -p prices\r\n```\r\n```none\r\ndeclare -A prices=&#39;([price1]=&quot;120.10&quot; [price3]=&quot;244.45&quot; [price2]=&quot;110.30&quot; )&#39;\r\n```\r\nor iterate over it\r\n```bash\r\nfor key in &quot;${!prices[@]}&quot;; do\r\n    printf &#39;%s =&gt; %s\\n&#39; &quot;$key&quot; &quot;${prices[$key]}&quot;\r\ndone\r\n```\r\n```none\r\nprice1 =&gt; 120.10\r\nprice3 =&gt; 244.45\r\nprice2 =&gt; 110.30\r\n```",
                "title": "how to parse json in bash script as an array? array value should have both key:value format"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1627483336,
        "creation_date": 1626962293,
        "last_edit_date": 1626964172,
        "question_id": 68486144,
        "body_markdown": "my json.file looks like\r\n\r\n    {\r\n      &quot;price1&quot; : &quot;120.10&quot;,\r\n      &quot;price2&quot; : &quot;110.30&quot;,\r\n      &quot;price3&quot; : &quot;244.45&quot;\r\n    }\r\n\r\nI have used below sed command in my bash script to declare array that reads from json \r\n\r\n    array=( $(sed -n &#39;/{/,/}/{s/[^:]*:[^&quot;]*&quot;\\([^&quot;]*\\).*/\\1/p;}&#39; json.file) )\r\n\r\nthis gave me output for `echo ${array[*]}` values\r\n \r\n    120.10 110.10 244.45\r\n\r\nI am looking for my array values to include the key name as well (`key:value`). \r\nmy desired output should be `key:value` format \r\n\r\n    price1:120.10 price2:110.10 price3:244.45\r\n\r\ncan someone please help or guide me?",
        "link": "https://stackoverflow.com/questions/68486144/how-to-parse-json-in-bash-script-as-an-array-array-value-should-have-both-keyv",
        "title": "how to parse json in bash script as an array? array value should have both key:value format"
    },
    {
        "tags": [
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1627014435,
                "creation_date": 1627014435,
                "answer_id": 68494044,
                "question_id": 68493809,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To ignore those instances, you could use `.Tags // empty`, like so:\r\n```\r\njq -r &#39;.Reservations[].Instances[]\r\n  | ((.Tags // empty) | from_entries) as $tags\r\n  | &quot;\\(.InstanceId)  \\(.PrivateIpAddress)  \\($tags.Name)&quot;&#39;\r\n```\r\n\r\nOne way to add placeholder values would be to use an `if ... then ... else ... end` construction, e.g.\r\n\r\n```\r\njq -r &#39;\r\n.Reservations[].Instances[]\r\n  | (if .Tags then (.Tags | from_entries).Name else &quot;-&quot; end) as $name\r\n  | &quot;\\(.InstanceId)  \\(.PrivateIpAddress)  \\($name)&quot;&#39;\r\n```\r\n\r\nIf you need further details, then please follow the \r\n [minimal complete verifiable example guidelines][1].\r\n\r\n\r\n  [1]: http://stackoverflow.com/help/mcve",
                "title": "Handling missing Tags in &#39;aws | jq&#39; command (jq: error Cannot iterate over null)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1627014435,
        "creation_date": 1627012080,
        "question_id": 68493809,
        "body_markdown": "I&#39;m trying to write a simple script to output a table of AWS EC2 instance information (instance-id, ip, name) using &#39;jq&#39;.\r\n\r\nHowever, in our environment, some instances do not have any tags associated with them, so when I run my script I get an error, at which point jq stops processing before iterating over the remainding elements of the array:\r\n\r\n    $ aws ec2 describe-instances | \\\r\n      jq -r &#39;.Reservations[].Instances[] | (.Tags | from_entries) as $tags | &quot;\\(.InstanceId)  \\(.PrivateIpAddress)  \\($tags.Name)&quot;&#39;\r\n\r\n    i-0664dc6c236767b4e  10.177.99.141  foo\r\n    i-02077630c093d65dc  10.177.99.85  bar\r\n    jq: error (at &lt;stdin&gt;:2108): Cannot iterate over null (null)\r\n\r\nIs there a way I can filter for non-existent Tags and substitute a placeholder value for Name (like &#39;-&#39;), to avoid this error and produce a clean output?",
        "link": "https://stackoverflow.com/questions/68493809/handling-missing-tags-in-aws-jq-command-jq-error-cannot-iterate-over-null",
        "title": "Handling missing Tags in &#39;aws | jq&#39; command (jq: error Cannot iterate over null)"
    },
    {
        "tags": [
            "json",
            "while-loop",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16263325,
                    "reputation": 542,
                    "user_id": 11744097,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/--_CSWfqF3tQ/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdzBBPcl2w1PZhBaW5zcKAhfur-_Q/s256-rj/photo.jpg",
                    "display_name": "Ken Jenney",
                    "link": "https://stackoverflow.com/users/11744097/ken-jenney"
                },
                "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": 1627045727,
                "post_id": 68499385,
                "comment_id": 121059356,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1627047596,
                "creation_date": 1627047596,
                "answer_id": 68500132,
                "question_id": 68499385,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `--slurp`:\r\n\r\n```\r\nreduce .[] as $i ([0, true]; if .[1] and ($i.message | contains(&quot;brown fox&quot;)) then .[0] += 1 else .[1] = false end) | .[0]\r\n```\r\n\r\nI use `[0, true]` to know when to stop counting:\r\n\r\n1. The boolean indicate that we should keep counting\r\n2. The number is incremented whilst we keep matching &quot;brown fox&quot;\r\n3. However as soon as we don&#39;t the flag is changed to false\r\n\r\nI&#39;m sure there&#39;s a better way but I just can&#39;t see it ;)\r\n\r\n___\r\n\r\nhttps://jqplay.org/s/Art_0y3u_g",
                "title": "Count elements whilst predicate is true"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1627048202,
                "creation_date": 1627048202,
                "answer_id": 68500275,
                "question_id": 68499385,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another option similar to @customcommander, but using `until` instead of `reduce`:\r\n\r\n```\r\n&#39;[0,.] |                                                                                                                                                                                             \r\n until(\r\n   (.[1] | .[0] | .message | test(&quot;brown fox&quot;)| not);\r\n   [ .[0]+ 1 , (.[1] | .[1:]) ]) \r\n| .[0]&#39; \r\n```\r\n\r\nhttps://jqplay.org/s/pAyfv7ZvQK",
                "title": "Count elements whilst predicate is true"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1706847612,
                "last_edit_date": 1706847612,
                "creation_date": 1627053273,
                "answer_id": 68501417,
                "question_id": 68499385,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For efficiency, it is best to avoid &quot;slurping&quot; the input, which as envisioned in the Q, can in this case can be done quite simply by using `input` (or `inputs`) and the -n command-line option.\r\n\r\nUsing a stream-oriented counting function and the built-in `while`:\r\n\r\n```\r\ndef count(s): reduce s as $x (0; .+1);\r\n\r\ncount(while (inputs | .message|test(&quot;brown fox&quot;); true) )\r\n```\r\n\r\n## An alternative\r\n```\r\ndef count(s): reduce s as $x (0; .+1);\r\n\r\ndef select_while(s; cond):\r\n  label $out | s | if cond then . else break $out end;\r\n\r\ncount( select_while(inputs; .message|test(&quot;brown fox&quot;) ) )\r\n```",
                "title": "Count elements whilst predicate is true"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1706847612,
        "creation_date": 1627044182,
        "last_edit_date": 1627114642,
        "question_id": 68499385,
        "body_markdown": "I have a collection of JSON objects like so:\r\n\r\n    {&quot;id&quot;:&quot;da1234563&quot;,&quot;message&quot;:&quot;brown fox jump over a red log&quot;}\r\n    {&quot;id&quot;:&quot;da1234564&quot;,&quot;message&quot;:&quot;brown fox jump over a red log&quot;}\r\n    {&quot;id&quot;:&quot;da1234565&quot;,&quot;message&quot;:&quot;brown fox jump over a red log&quot;}\r\n    {&quot;id&quot;:&quot;da1234566&quot;,&quot;message&quot;:&quot;brown fox jump over a red log&quot;}\r\n    {&quot;id&quot;:&quot;da1234567&quot;,&quot;message&quot;:&quot;red fox jump over a brown log&quot;}\r\n    {&quot;id&quot;:&quot;da1234568&quot;,&quot;message&quot;:&quot;another random string&quot;}\r\n    {&quot;id&quot;:&quot;da1234569&quot;,&quot;message&quot;:&quot;brown fox jump over a red log&quot;}\r\n\r\nI&#39;d like to use `jq` to iterate over these objects and return the number of `brown fox`&#39;s  jumping UNTIL a match is not found.\r\n\r\nThe following `jq` gives me every line with brown fox including the last line:\r\n\r\n    jq -n &#39;inputs|select(.message|test(&quot;brown fox&quot;))&#39;\r\n\r\nHow do I exclude the matches after a mismatch and count the number of matches so that `jq` returns only `4`?\r\n",
        "link": "https://stackoverflow.com/questions/68499385/count-elements-whilst-predicate-is-true",
        "title": "Count elements whilst predicate is true"
    },
    {
        "tags": [
            "arrays",
            "json",
            "append",
            "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": 1627077824,
                "post_id": 68504374,
                "comment_id": 121069896,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2230457,
                    "reputation": 17671,
                    "user_id": 1968182,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/E5nF2.jpg?s=256",
                    "display_name": "Ulrich Eckhardt",
                    "link": "https://stackoverflow.com/users/1968182/ulrich-eckhardt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1627121736,
                "post_id": 68504374,
                "comment_id": 121075677,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1627510925,
                "last_edit_date": 1627510925,
                "creation_date": 1627070329,
                "answer_id": 68504495,
                "question_id": 68504374,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Well, does something like this work for you?\r\n\r\n    jq &#39;.[0].array += [&quot;string3&quot;]&#39; test.json\r\n\r\nI see this response, which looks pretty much like what I would want:\r\n\r\n    [\r\n      {\r\n        &quot;array&quot;: [\r\n          &quot;string1&quot;,\r\n          &quot;string2&quot;,\r\n          &quot;string3&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;object1&quot;: {\r\n          &quot;subobject1&quot;: {},\r\n          &quot;subobject2&quot;: {}\r\n        }\r\n      },\r\n      {\r\n        &quot;object2&quot;: {}\r\n      }\r\n    ]\r\n\r\nEDIT 1:\r\nI like the more general solutions provided by @peak particularly the first one:\r\n\r\n    map( if .array then .array += [&quot;string3&quot;] else . end)\r\nHere&#39;s a [snippet][1] you can experiment with. It&#39;s easy to see how you could insert the new string into the second contained array rather than the first with:\r\n\r\n     map( if .array2 then .array2 += [&quot;string3&quot;] else . end)\r\n\r\n\r\n  [1]: https://jqplay.org/s/bzuuaVHtYK",
                "title": "Using jq, how to append an element to an array without it updating every other object?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1627078606,
                "last_edit_date": 1627078606,
                "creation_date": 1627078057,
                "answer_id": 68505450,
                "question_id": 68504374,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Depending on your requirements, you may wish to consider:\r\n\r\n    map( if .array then .array += [&quot;string3&quot;] else . end)\r\n\r\nor even:\r\n\r\n    walk( if type == &quot;object&quot; and .array then .array += [&quot;string3&quot;] else . end)\r\n\r\n\r\nIf you only want the first occurrence at the top-level to be affected:\r\n\r\n    (first(.[]|.array // empty)) += [&quot;string3&quot;]\r\n",
                "title": "Using jq, how to append an element to an array without it updating every other object?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1627118335,
                "last_edit_date": 1627118335,
                "creation_date": 1627112601,
                "answer_id": 68508003,
                "question_id": 68504374,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try this to find object by key `array` and append there\r\n```\r\njq &#39;.[] | select(has(&quot;array&quot;)).array += [&quot;string3&quot;]&#39; test.json\r\n```\r\nThis is what the response looks like\r\n```\r\n{\r\n  &quot;array&quot;: [\r\n    &quot;string1&quot;,\r\n    &quot;string2&quot;,\r\n    &quot;string3&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;object1&quot;: {\r\n    &quot;subobject1&quot;: {},\r\n    &quot;subobject2&quot;: {}\r\n  }\r\n}\r\n{\r\n  &quot;object2&quot;: {}\r\n}\r\n```",
                "title": "Using jq, how to append an element to an array without it updating every other object?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1627510925,
        "creation_date": 1627069268,
        "last_edit_date": 1627349707,
        "question_id": 68504374,
        "body_markdown": "I have a test.json file that looks like this: \r\n\r\n    [\r\n      {\r\n        &quot;array&quot;: [\r\n          &quot;string1&quot;,\r\n          &quot;string2&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;object1&quot;: {\r\n          &quot;subobject1&quot;: {},\r\n          &quot;subobject2&quot;: {}\r\n        }\r\n      },\r\n      {\r\n        &quot;object2&quot;: {}\r\n      }\r\n    ]\r\n\r\n\r\nI&#39;m trying to append an element, `string3` into `array`. I&#39;ve tried the following commands: \r\n\r\n    $ jq &#39;.[] | .array |= . + [&quot;string3&quot;]&#39; test.json\r\n    $ jq &#39;.[] | .array += [&quot;string3&quot;]&#39; test.json\r\n\r\nWhat I expect is this, `string3` only being appended to `array`: \r\n\r\n    {\r\n      &quot;array&quot;: [\r\n        &quot;string1&quot;,\r\n        &quot;string2&quot;,\r\n        &quot;string3&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;object1&quot;: {\r\n        &quot;subobject1&quot;: {},\r\n        &quot;subobject2&quot;: {}\r\n      },\r\n    }\r\n    {\r\n      &quot;object2&quot;: {},\r\n    }\r\n\r\nHowever, I get these as the actual result, where the `array` array is being added to all objects:\r\n\r\n    {\r\n      &quot;array&quot;: [\r\n        &quot;string1&quot;,\r\n        &quot;string2&quot;,\r\n        &quot;string3&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;object1&quot;: {\r\n        &quot;subobject1&quot;: {},\r\n        &quot;subobject2&quot;: {}\r\n      },\r\n      &quot;array&quot;: [\r\n        &quot;string3&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;object2&quot;: {},\r\n      &quot;array&quot;: [\r\n        &quot;string3&quot;\r\n      ]\r\n    }\r\n\r\nHow can I append to the one array `array` without affecting any other objects in the file?  \r\n\r\nI&#39;m using jq version 1.6.  ",
        "link": "https://stackoverflow.com/questions/68504374/using-jq-how-to-append-an-element-to-an-array-without-it-updating-every-other-o",
        "title": "Using jq, how to append an element to an array without it updating every other object?"
    },
    {
        "tags": [
            "json",
            "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": 1627071840,
                "post_id": 68504668,
                "comment_id": 121068461,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3280760,
                    "reputation": 9459,
                    "user_id": 2761425,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/af75a738ff3b9d20c54150210e1e11aa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bryan",
                    "link": "https://stackoverflow.com/users/2761425/bryan"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1627072017,
                "post_id": 68504668,
                "comment_id": 121068513,
                "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": 1627072255,
                "post_id": 68504668,
                "comment_id": 121068585,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3280760,
                    "reputation": 9459,
                    "user_id": 2761425,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/af75a738ff3b9d20c54150210e1e11aa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bryan",
                    "link": "https://stackoverflow.com/users/2761425/bryan"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1627072481,
                "post_id": 68504668,
                "comment_id": 121068651,
                "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": 1627073031,
                "post_id": 68504668,
                "comment_id": 121068818,
                "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": 1627073224,
                "post_id": 68504668,
                "comment_id": 121068864,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3280760,
                    "reputation": 9459,
                    "user_id": 2761425,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/af75a738ff3b9d20c54150210e1e11aa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bryan",
                    "link": "https://stackoverflow.com/users/2761425/bryan"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1627074655,
                "post_id": 68504668,
                "comment_id": 121069194,
                "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": 1627074739,
                "post_id": 68504668,
                "comment_id": 121069213,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3280760,
                    "reputation": 9459,
                    "user_id": 2761425,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/af75a738ff3b9d20c54150210e1e11aa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bryan",
                    "link": "https://stackoverflow.com/users/2761425/bryan"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1627074913,
                "post_id": 68504668,
                "comment_id": 121069247,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1627076798,
                "creation_date": 1627076798,
                "answer_id": 68505315,
                "question_id": 68504668,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one solution to the problem as I understand it:\r\n```\r\njq -n &#39;\r\n input.error as $file1\r\n | input.error as $file2\r\n | (($file2|keys_unsorted) - ($file1|keys_unsorted)) as $k1\r\n | ($file1 + $file2) | delpaths($k1 | map([.]))\r\n | {error: .}\r\n&#39; file1.json file2.json\r\n```\r\nThere are many other alternatives....\r\n",
                "title": "How to update a json file with keys from another file, only if they already exist in the original?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1627506857,
                "last_edit_date": 1627506857,
                "creation_date": 1627081663,
                "answer_id": 68505773,
                "question_id": 68504668,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq -n &#39;\r\n   input.error as $overrides |\r\n   input | .error |= (\r\n      keys_unsorted[] as $key |\r\n      .[$key] = ( $overrides[$key] // .[$key] )\r\n   )\r\n&#39; file2.json file1.json\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/SKDH7k6_X8) [Example from question]&lt;br&gt;\r\n[jqplay](https://jqplay.org/s/fB9IbP4RX1) [Example from comments]\r\n\r\n(Note the reversed file order.)",
                "title": "How to update a json file with keys from another file, only if they already exist in the original?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1630397313,
        "creation_date": 1627071583,
        "last_edit_date": 1630397313,
        "question_id": 68504668,
        "body_markdown": "I have the following two files:\r\n\r\n**file1.json**:\r\n```\r\n{\r\n  &quot;error&quot;: {\r\n    &quot;200&quot;: &quot;200 error&quot;,\r\n    &quot;500&quot;: &quot;500 error&quot;\r\n  }\r\n}\r\n```\r\n\r\n**file2.json**:\r\n```\r\n{\r\n  &quot;error&quot;: {\r\n    &quot;200&quot;: &quot;200 error code&quot;,\r\n    &quot;400&quot;: &quot;400 error code&quot;\r\n  }\r\n}\r\n```\r\n\r\nWhen I run the following command `jq -s &#39;.[0] * .[1]&#39; ./file1.json ./file2.json` I get this file:\r\n\r\n```\r\n{\r\n  &quot;error&quot;: {\r\n    &quot;200&quot;: &quot;200 error code&quot;,\r\n    &quot;400&quot;: &quot;400 error code&quot;\r\n    &quot;500&quot;: &quot;500 error&quot;\r\n  }\r\n}\r\n```\r\n\r\nBut what I want is to update the keys of `file1` with the values of matching keys  in `file2`, and the new keys in `file2` will be ignored. So it would return:\r\n\r\n```\r\n{\r\n  &quot;error&quot;: {\r\n    &quot;200&quot;: &quot;200 error code&quot;,\r\n    &quot;500&quot;: &quot;500 error&quot;\r\n  }\r\n}\r\n```\r\n\r\nNotice that the key `200` was updated with the value from `file2` while the key `400` was ignored.",
        "link": "https://stackoverflow.com/questions/68504668/how-to-update-a-json-file-with-keys-from-another-file-only-if-they-already-exis",
        "title": "How to update a json file with keys from another file, only if they already exist in the original?"
    },
    {
        "tags": [
            "json",
            "select",
            "conditional-statements",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1627095640,
                "creation_date": 1627095640,
                "answer_id": 68506650,
                "question_id": 68506318,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the -r command-line option, the filter:\r\n\r\n```\r\n[.fields[]\r\n | (select(.&quot;035&quot;.ind1 == &quot;0&quot; and .&quot;035&quot;.ind2 == &quot;0&quot;)\r\n    | (.&quot;035&quot;.subfields[] | select(.a) | .a) ),\r\n   (select(.&quot;999&quot;)\r\n    | (.&quot;999&quot;.subfields[] | select(.s) | .s) ) ]\r\n| join(&quot; &quot;)\r\n```\r\n\r\nyields:\r\n```\r\nocm00000001projmusemuse13792 020d182f-ba5d-4bbe-a2eb-e4390aa0736c\r\n```",
                "title": "Conditional jq extraction of two elements in different places of hierarchy"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1627113918,
        "creation_date": 1627089850,
        "last_edit_date": 1627113918,
        "question_id": 68506318,
        "body_markdown": "I have a json document that I need to extract both the value of subfield a of tags 035 and 999 when 035.subfields[].ind1 and 035.subfields[].ind2 are both &quot;0&quot;. Here is my document:  \r\n\r\n    {\r\n      &quot;leader&quot;: &quot;01815cam a22004934a 4500&quot;,\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;001&quot;: &quot;mig00005597434&quot;\r\n        },\r\n        {\r\n          &quot;035&quot;: {\r\n            &quot;subfields&quot;: [\r\n              {\r\n                &quot;a&quot;: &quot;(OCoLC)67764532&quot;\r\n              }\r\n            ],\r\n            &quot;ind1&quot;: &quot; &quot;,\r\n            &quot;ind2&quot;: &quot; &quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;035&quot;: {\r\n            &quot;subfields&quot;: [\r\n              {\r\n                &quot;a&quot;: &quot;ocm00000001projmusemuse13792&quot;\r\n              }\r\n            ],\r\n            &quot;ind1&quot;: &quot;0&quot;,\r\n            &quot;ind2&quot;: &quot;0&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;245&quot;: {\r\n            &quot;subfields&quot;: [\r\n              {\r\n                &quot;a&quot;: &quot;The Sins of the Father&quot;\r\n              },\r\n              {\r\n                &quot;b&quot;: &quot;A Romance of the South /&quot;\r\n              },\r\n              {\r\n                &quot;c&quot;: &quot;by Thomas Dixon ; with an introduction by Steven Weisenburger.&quot;\r\n              }\r\n            ],\r\n            &quot;ind1&quot;: &quot;1&quot;,\r\n            &quot;ind2&quot;: &quot;4&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;999&quot;: {\r\n            &quot;subfields&quot;: [\r\n              {\r\n                &quot;i&quot;: &quot;a1b7fa7e-9e2e-4973-96d0-3939235c8b80&quot;\r\n              },\r\n              {\r\n                &quot;s&quot;: &quot;020d182f-ba5d-4bbe-a2eb-e4390aa0736c&quot;\r\n              }\r\n            ],\r\n            &quot;ind1&quot;: &quot;f&quot;,\r\n            &quot;ind2&quot;: &quot;f&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nMy desired output is \r\n\r\n    ocm00000001projmusemuse13792     020d182f-ba5d-4bbe-a2eb-e4390aa0736c\r\n\r\nWhen I try to get both values, \r\n\r\n    jq -r &#39;.fields[] | [(select(.&quot;035&quot;.ind1 == &quot;0&quot; and .&quot;035&quot;.ind2 == &quot;0&quot;) | .&quot;035&quot;.subfields[].a), (select(.&quot;999&quot;) |.&quot;999&quot;.subfields[].s)] &#39;\r\n\r\nI get \r\n\r\n    []\r\n    []\r\n    [\r\n      &quot;ocm00000001projmusemuse13792&quot;\r\n    ]\r\n    []\r\n    [\r\n      null,\r\n      &quot;020d182f-ba5d-4bbe-a2eb-e4390aa0736c&quot;\r\n    ]\r\n\r\nBut and other variations where I try to move the 999 selection (e.g. \r\n\r\n    jq &#39;.fields[] | [(select(.&quot;035&quot;.ind1 == &quot;0&quot; and .&quot;035&quot;.ind2 == &quot;0&quot;) | .&quot;035&quot;.subfields[].a), (select(.&quot;999&quot;.subfields[].s) | .&quot;999&quot;.subfields[].s)] &#39;\r\n\r\nI get that I can&#39;t iterate over null. What am I missing?",
        "link": "https://stackoverflow.com/questions/68506318/conditional-jq-extraction-of-two-elements-in-different-places-of-hierarchy",
        "title": "Conditional jq extraction of two elements in different places of hierarchy"
    },
    {
        "tags": [
            "kubernetes",
            "jq",
            "metrics"
        ],
        "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": 1627243782,
                "post_id": 68521246,
                "comment_id": 121098585,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1627243423,
                "creation_date": 1627243423,
                "answer_id": 68522127,
                "question_id": 68521246,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your sample input is a bit of a mess.  If you really have to deal with something like that, the best would be to modify the beginning and end of the string, to make it parseable as a JSON string:\r\n\r\n    &quot;{ \\&quot;container\\&quot;:{\\&quot;memory\\&quot;:{\\&quot;request\\&quot;:{\\&quot;bytes\\&quot;:6.142515354e+08}},\\&quot;name\\&quot;:\\&quot;testcontainer\\&quot;,\\&quot;cpu\\&quot;:{\\&quot;request\\&quot;:{\\&quot;cores\\&quot;:0.3}}}}&quot;\r\n\r\nThen you can run jq on it, e.g.:\r\n\r\n    &lt; kubernetes.txt jq fromjson\r\n\r\nyields:\r\n```\r\n{\r\n  &quot;container&quot;: {\r\n    &quot;memory&quot;: {\r\n      &quot;request&quot;: {\r\n        &quot;bytes&quot;: 614251535.4\r\n      }\r\n    },\r\n    &quot;name&quot;: &quot;testcontainer&quot;,\r\n    &quot;cpu&quot;: {\r\n      &quot;request&quot;: {\r\n        &quot;cores&quot;: 0.3\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n\r\nNow it&#39;s easy to write the queries to get the details you want, e.g.\r\n\r\n   &lt; kubernetes.txt jq fromjson.container.memory.request",
                "title": "Making request jq to output memory and container"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1627243423,
        "creation_date": 1627235916,
        "last_edit_date": 1627239410,
        "question_id": 68521246,
        "body_markdown": "how to make request to output coantainer name and how much memory and cpu usage.\r\n\r\n    \\&quot;container\\&quot;:{\\&quot;memory\\&quot;:{\\&quot;request\\&quot;:{\\&quot;bytes\\&quot;:6.142515354e+08}},\\&quot;name\\&quot;:\\&quot;testcontainer\\&quot;,\\&quot;cpu\\&quot;:{\\&quot;request\\&quot;:{\\&quot;cores\\&quot;:0.3}}",
        "link": "https://stackoverflow.com/questions/68521246/making-request-jq-to-output-memory-and-container",
        "title": "Making request jq to output memory and container"
    },
    {
        "tags": [
            "json",
            "object",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1627253490,
                "last_edit_date": 1627253490,
                "creation_date": 1627241027,
                "answer_id": 68521861,
                "question_id": 68521557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `add` to merge the objects.\r\n\r\n    jq &#39;[ .[] | { (.name) : .age } ] | add&#39;",
                "title": "output arrays values as single object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1627253490,
        "creation_date": 1627238472,
        "last_edit_date": 1627243885,
        "question_id": 68521557,
        "body_markdown": "I need to be able to produce the following but without having to explicit array&#39;s indexes, so that I don&#39;t need to know input array&#39;s lenght\r\n\r\n    echo &#39;[{&quot;name&quot;:&quot;John&quot;, &quot;age&quot;:30, &quot;car&quot;:null},{&quot;name&quot;:&quot;Marc&quot;, &quot;age&quot;:32, &quot;car&quot;:null}]&#39; | jq -r &#39;{(.[0].name):.[0].age,(.[1].name):.[1].age}&#39;\r\n\r\nProduces :\r\n\r\n    {  &quot;John&quot;: 30, &quot;Marc&quot;: 32}",
        "link": "https://stackoverflow.com/questions/68521557/output-arrays-values-as-single-object",
        "title": "output arrays values as single object"
    },
    {
        "tags": [
            "jq",
            "aws-cli"
        ],
        "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": 1627363369,
                "post_id": 68538777,
                "comment_id": 121128931,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1627379613,
                "last_edit_date": 1627379613,
                "creation_date": 1627377510,
                "answer_id": 68542193,
                "question_id": 68538777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This error message indicates that the input piped to `jq` wasn&#39;t valid JSON. Since this input comes directly from the output of the `aws ec2 describe-instances` command it looks like it isn&#39;t emitting JSON, or it&#39;s emitting other text _as well_ as JSON.\r\n\r\nThe fastest way to diagnose this is going to be for you to find out what text the `aws` command is emitting.\r\n\r\nOne possible cause could be that you have it configured via an environment variable (`AWS_DEFAULT_OUTPUT`) or configuration file (e.g. `~/.aws/config`) to output YAML or text or tables. (In fact, I consider this probable. I can reproduce the error message exactly down to the column number if I set it to output YAML.) You could rule this out by [explicitly specifying][1] `--output json`.\r\n\r\nBeyond that, I suggest you compare these machines to each other. For example, try this on each machine and see what&#39;s different on the odd machine:\r\n\r\n```\r\necho Versions:\r\naws --version\r\njq --version\r\n\r\necho Environment:\r\nenv | grep &#39;^AWS_&#39;\r\n\r\necho AWS configuration:\r\naws configure list\r\n\r\necho AWS config file:\r\ncat ~/.aws/config\r\n```\r\n\r\n[1]: https://docs.aws.amazon.com/cli/latest/userguide/cli-usage-output-format.html#cli-usage-output-format",
                "title": "jq command executes differently - one successfully and the other is not"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1627379613,
        "creation_date": 1627358270,
        "last_edit_date": 1627379515,
        "question_id": 68538777,
        "body_markdown": "I am running this command: \r\n\r\n    {{ aws ec2 describe-availability-zones --region ca-central-1 | jq &#39;.AvailabilityZones[]|(.ZoneName)}}&#39;\r\n\r\non 2 identical MacOs and one Amazon Linux.\r\n\r\nThe MacOs subject to this question is showing this error : \r\n\r\n&gt; parse error: Invalid numeric literal at line 1, column 18\r\n\r\nHowever, the Amazon and the Other MacOS are showing the correct output \r\n\r\n![enter image description here][1]\r\n\r\nPlease help me! This is driving me crazy\r\n\r\n  [1]: https://i.sstatic.net/XdByp.png",
        "link": "https://stackoverflow.com/questions/68538777/jq-command-executes-differently-one-successfully-and-the-other-is-not",
        "title": "jq command executes differently - one successfully and the other is not"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1627385598,
                "creation_date": 1627385598,
                "answer_id": 68544087,
                "question_id": 68544053,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I need output of &#39;host1&#39; and &#39;host3&#39;\r\n\r\nIf you can use a *hardcoded* list of `keys`, you can use the following JQ command to get only `host1` and `host3`:\r\n\r\n```\r\n{ host1, host3 }\r\n```\r\n```json\r\n{\r\n  &quot;host1&quot;: {\r\n    &quot;ip&quot;: &quot;10.1.2.3&quot;\r\n  },\r\n  &quot;host3&quot;: {\r\n    &quot;ip&quot;: &quot;10.1.18.1&quot;\r\n  }\r\n}\r\n```\r\n\r\n&lt;hr&gt;\r\n\r\nThis uses the **Object Construction Shortcut Syntax** as explained in [there documentation](https://stedolan.github.io/jq/manual/#TypesandValues) and in this SO question: &lt;https://stackoverflow.com/questions/68002556/jq-can-i-use-the-name-of-an-argument-in-the-code-itself/68002658#68002658&gt;.\r\n\r\n\r\n----------\r\n\r\n\r\n[JqPlay Demo](https://jqplay.org/s/03yKgM1Kqn)",
                "title": "how to get the output by jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1627385598,
        "creation_date": 1627385440,
        "question_id": 68544053,
        "body_markdown": "So I have below sample codes\r\n\r\n```\r\n{\r\n  &quot;host1&quot;: { &quot;ip&quot;: &quot;10.1.2.3&quot; },\r\n  &quot;host2&quot;: { &quot;ip&quot;: &quot;10.1.2.2&quot; },\r\n  &quot;host3&quot;: { &quot;ip&quot;: &quot;10.1.18.1&quot; }\r\n  ...\r\n}\r\n```\r\n\r\nI need output of &#39;host1&#39; and &#39;host3&#39;\r\n\r\n```\r\n{\r\n  &quot;host1&quot;: { &quot;ip&quot;: &quot;10.1.2.3&quot; },\r\n  &quot;host3&quot;: { &quot;ip&quot;: &quot;10.1.18.1&quot; }\r\n}\r\n```\r\n\r\nwith command ` |jq .host1`, I can only get one\r\n```\r\n{\r\n  &quot;ip&quot;: &quot;10.1.2.3&quot;\r\n}\r\n```\r\n\r\nand I lost its key `host1` as well",
        "link": "https://stackoverflow.com/questions/68544053/how-to-get-the-output-by-jq",
        "title": "how to get the output by jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "unicode-escapes"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1627388571,
                "post_id": 68544684,
                "comment_id": 121138306,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1627388671,
                "post_id": 68544684,
                "comment_id": 121138353,
                "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": 1,
                "creation_date": 1627388935,
                "post_id": 68544684,
                "comment_id": 121138494,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1627397514,
                "creation_date": 1627397514,
                "answer_id": 68547127,
                "question_id": 68544684,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t think there&#39;s any way to force jq to round-trip the input exactly, but you certainly can use the `--ascii-output` option to make sure that _all_ its output is ASCII, and any non-ASCII characters inside strings are suitably escaped. I guess it depends on what you&#39;re trying to do. If you want to absolutely minimise unnecessary differences between your input and output, it&#39;s probably little help. But if you simply want to avoid having UTF-8 in your output, this is what you need.",
                "title": "jq disable converting to unicode"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1627397514,
        "creation_date": 1627388321,
        "question_id": 68544684,
        "body_markdown": "I have a simple JSON file like:\r\n\r\n```\r\n{\r\n    &quot;name&quot;: &quot;This is a sample&quot;,\r\n    &quot;resources&quot;: [\r\n        {\r\n            &quot;id&quot;: 0,\r\n            &quot;obj&quot;: [\r\n                {&quot;data&quot;: &quot;attribute 0 \\u003e&quot;},\r\n                {&quot;data&quot;: &quot;attribute 1&quot;},\r\n                {&quot;data&quot;: &quot;attribute 2&quot;}\r\n            ]\r\n        },\r\n        {\r\n            &quot;id&quot;: 1,\r\n            &quot;obj&quot;: [\r\n                {&quot;data&quot;: &quot;attribute 0&quot;},\r\n                {&quot;data&quot;: &quot;attribute 1&quot;},\r\n                {&quot;data&quot;: &quot;attribute 2&quot;}\r\n            ]\r\n        },\r\n        {\r\n            &quot;id&quot;: 1,\r\n            &quot;obj&quot;: [\r\n                {&quot;data&quot;: &quot;attribute 0&quot;},\r\n                {&quot;data&quot;: &quot;attribute 1&quot;},\r\n                {&quot;data&quot;: &quot;attribute 2&quot;}\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI have to remove the &quot;data&quot; tags whose value is &quot;attribute 0&quot; in &quot;obj&quot; array in the objects whose &quot;id&quot; is 1. I used the below command and I got the output as expected.\r\n\r\n```\r\n jq &#39;del(.resources[] | select(.id== 1) | .obj[] | select(.data== &quot;attribute 0&quot;) )&#39;\r\n````\r\n\r\nBut the problem is the character `\\u003e` to it&#39;s unicode format `&gt;` (https://www.fileformat.info/info/unicode/char/3e/index.htm). But I don&#39;t want that to happen. Is there any way using which I can prevent the conversion of these elements to unicode?",
        "link": "https://stackoverflow.com/questions/68544684/jq-disable-converting-to-unicode",
        "title": "jq disable converting to unicode"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1627395796,
                "last_edit_date": 1627395796,
                "creation_date": 1627394806,
                "answer_id": 68546441,
                "question_id": 68545850,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t think [tag:jq] is capable of producing such an output in general.\r\n\r\n\r\n----------\r\n\r\n\r\n* We can use some [tag:bash] [tag:sed] magic to insert a newline on each line containing just an `}`.\r\n  *   `sed &#39;s/^\\}/&amp;\\n\\n/&#39;`\r\n\r\n* Since there will be a trailing newline, we&#39;ll use `head -c -2` to remove the last lines.\r\n\r\n\r\n----------\r\n\r\n\r\nOutput:\r\n```json\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;,\r\n  &quot;say&quot;: &quot;what&quot;\r\n}\r\n\r\n\r\n{\r\n  &quot;foo2&quot;: &quot;bar2&quot;,\r\n  &quot;say2&quot;: &quot;what2&quot;\r\n}\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nExample on my local machine:\r\n```none\r\n$ cat input.json\r\n{&quot;foo&quot;: &quot;bar&quot;, &quot;say&quot;:&quot;what&quot;}\r\n{&quot;foo2&quot;: &quot;bar2&quot;, &quot;say2&quot;:&quot;what2&quot;}\r\n$\r\n$\r\n$ jq &#39;.&#39; input.json | sed &#39;s/^\\}/&amp;\\n\\n/&#39; | head -c -2\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;,\r\n  &quot;say&quot;: &quot;what&quot;\r\n}\r\n\r\n\r\n{\r\n  &quot;foo2&quot;: &quot;bar2&quot;,\r\n  &quot;say2&quot;: &quot;what2&quot;\r\n}\r\n$\r\n```\r\n\r\n\r\n----------\r\n\r\n*edit*\r\n\r\n* Added `^` to the [tag:sed] command to only match `}` *on the start of the line*.\r\n\r\n    `sed &#39;s/\\}/&amp;\\n\\n/&#39;` --&gt; `sed &#39;s/^\\}/&amp;\\n\\n/&#39;`",
                "title": "How to append extra newline on each json with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1627394892,
                "creation_date": 1627394892,
                "answer_id": 68546463,
                "question_id": 68545850,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So long as none of the incoming JSON texts is a string, you could write:\r\n\r\n    jq -r &#39;., &quot;&quot;, &quot;&quot;&#39; file.json\r\n\r\n ",
                "title": "How to append extra newline on each json with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1627395073,
                "creation_date": 1627395073,
                "answer_id": 68546517,
                "question_id": 68545850,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can pipe the output of `jq .` to `sed` as follows:\r\n```\r\njq . file.json | sed &#39;/}/s//&amp;\\n\\n/&#39;\r\n```\r\n",
                "title": "How to append extra newline on each json with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1627399036,
                "creation_date": 1627399036,
                "answer_id": 68547531,
                "question_id": 68545850,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using some unreadable perl to only print extra newlines between the closing brace and the opening brace\r\n```bash\r\njq . file | perl -0777 -pe &#39;s/^\\}\\n\\{/}\\n\\n\\n{/gm&#39;\r\n```",
                "title": "How to append extra newline on each json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1627399036,
        "creation_date": 1627392741,
        "last_edit_date": 1627394029,
        "question_id": 68545850,
        "body_markdown": "I know that `jq .` makes the json pretty and indented, but I would like to add 2 extra newlines after each json. Meaning:\r\n\r\nInput:\r\n```\r\n{&quot;foo&quot;: &quot;bar&quot;, &quot;say&quot;:&quot;what&quot;}\r\n{&quot;foo2&quot;: &quot;bar2&quot;, &quot;say2&quot;:&quot;what2&quot;}\r\n```\r\n\r\nWanted output:\r\n```\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;, \r\n  &quot;say&quot;:&quot;what&quot;\r\n}\r\n\r\n\r\n{\r\n  &quot;foo2&quot;: &quot;bar2&quot;, \r\n  &quot;say2&quot;:&quot;what2&quot;\r\n}\r\n```\r\n\r\nIs that possible with `jq` somehow? I have tried `cat file.json | sed G | jq .` without success and actually I wanted to avoid some `sed` magic thinking that maybe `jq` could do all the work.",
        "link": "https://stackoverflow.com/questions/68545850/how-to-append-extra-newline-on-each-json-with-jq",
        "title": "How to append extra newline on each json with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "while-loop",
            "jq",
            "ifs"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1627427283,
                "last_edit_date": 1627427283,
                "creation_date": 1627426375,
                "answer_id": 68552563,
                "question_id": 68552491,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use two `read`s, one for each line:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\njson=&#39;\r\n[\r\n   {\r\n      &quot;name&quot;:&quot;name string (more info)&quot;,\r\n      &quot;nested_name&quot;:{\r\n         &quot;name&quot;:&quot;my name&quot;,\r\n         &quot;conclusion&quot;:&quot;failure&quot;,\r\n         &quot;number&quot;:11\r\n      }\r\n   },\r\n   {\r\n      &quot;name&quot;:&quot;name string (more info)&quot;,\r\n      &quot;nested_name&quot;:{\r\n         &quot;name&quot;:&quot;my other name&quot;,\r\n         &quot;conclusion&quot;:&quot;failure&quot;,\r\n         &quot;number&quot;:13\r\n      }\r\n   }\r\n]&#39;\r\n\r\n\r\nwhile read -r foo &amp;&amp; read -r bar; do\r\n    printf &quot;foo=%s\\nbar=%s\\n&quot; &quot;$foo&quot; &quot;$bar&quot;\r\ndone &lt; &lt;(jq &quot;.[] | .name, .nested_name.name&quot; &lt;&lt;&lt;&quot;$json&quot;)\r\n```\r\n\r\n---\r\n\r\nI had to change your `jq` expression to get your desired output.\r\n\r\nAlso note using different names for your original JSON text and the loop variable, using a [*here string*](https://www.gnu.org/software/bash/manual/html_node/Redirections.html#Here-Strings) instead of `echo`, and using file redirection instead of a pipeline; useful if the body of the `while` sets any variables needed later.\r\n\r\n---\r\n\r\nAn alternative that reads all the `jq` output into an array and then iterates it:\r\n\r\n```sh\r\nreadarray -t lines &lt; &lt;(jq &quot;.[] | .name, .nested_name.name&quot; &lt;&lt;&lt;&quot;$json&quot;)\r\nfor (( i = 0; i &lt; ${#lines[@]}; i += 2 )); do\r\n    foo=${lines[i]}\r\n    bar=${lines[i+1]}\r\n    printf &quot;foo=%s\\nbar=%s\\n&quot; &quot;$foo&quot; &quot;$bar&quot;\r\ndone\r\n```",
                "title": "Pipe multiple jq values to &quot;while read -r&quot; loop"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1627426646,
                "creation_date": 1627426646,
                "answer_id": 68552592,
                "question_id": 68552491,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I simulate some &quot;CSV input&quot; I can do this: (Note the `IFS` set to `,`)\r\n\r\n```lang-sh\r\necho &#39;aaa,bbb\\nccc,ddd&#39; | while IFS=, read -r x y; do\r\n  echo &quot;x=$x, y=$y&quot;\r\ndone\r\n```\r\n\r\nOutput:\r\n\r\n```lang-none\r\nx=aaa, y=bbb\r\nx=ccc, y=ddd\r\n```\r\n\r\nYou can generate a similar &quot;CSV output&quot; with the following `jq` command:\r\n\r\n```\r\njq --raw-output &#39;.[] | &quot;\\(.name),\\(.nested_name.name)&quot;&#39;\r\n```\r\n\r\nSo I think it&#39;d look something like this:\r\n\r\n```lang-sh\r\necho &quot;$foo&quot; | jq --raw-output &#39;.[] | &quot;\\(.name),\\(.nested_name.name)&quot;&#39; | while IFS=, read -r foo bar; do\r\n    # do stuff with foo and bar\r\ndone\r\n```",
                "title": "Pipe multiple jq values to &quot;while read -r&quot; loop"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1627469830,
                "creation_date": 1627469830,
                "answer_id": 68559122,
                "question_id": 68552491,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "how about this: https://jqplay.org/s/4MPWmMjFmM\r\n```\r\nassuming foobar.json\r\n    jq -r &#39;.[] | &quot;foo=\\&quot;&quot; + .name + &quot;\\&quot;&quot;,&quot;bar=\\&quot;&quot; + .nested_name.name + &quot;\\&quot;&quot;&#39; foobar.json\r\n    foo=&quot;name string (more info)&quot;\r\n    bar=&quot;my name&quot;\r\n    foo=&quot;name string (more info)&quot;\r\n    bar=&quot;my other name&quot;\r\n```\r\n\r\n\r\n",
                "title": "Pipe multiple jq values to &quot;while read -r&quot; loop"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1627496402,
                "creation_date": 1627496402,
                "answer_id": 68565565,
                "question_id": 68552491,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I prefer to do it like this:\r\n\r\n```\r\njq --argjson foo &quot;$foo&quot; --null-input --compact-output &#39;$foo[]&#39; | while IFS= read -r item\r\ndo\r\n    name=&quot;$(jq --argjson item &quot;$item&quot; --null-input --raw-output &#39;$item.name&#39;)&quot;\r\n    nested_name=&quot;$(jq --argjson item &quot;$item&quot; --null-input --raw-output &#39;$item.nested_name.name&#39;)&quot;\r\n    printf &#39;name is &quot;%s&quot; and nested_name is &quot;%s&quot;\\n&#39; &quot;$name&quot; &quot;$nested_name&quot;\r\ndone\r\n```\r\n\r\nWhile this method involves extra calls to `jq`, it has several benefits:\r\n* It&#39;s easy to extend if you need to iterate over something with more complex structure.\r\n* It&#39;s safe against spaces, commas, quotes, tabs and newlines.\r\n* It&#39;s easy to understand and have confidence in. It doesn&#39;t involve any special algorithm, parsing or escaping.\r\n\r\nHere&#39;s the same thing using abbreviated options if you want it a little bit more terse.\r\n\r\n```\r\njq --argjson foo &quot;$foo&quot; -nc &#39;$foo[]&#39; | while IFS= read -r item\r\ndo\r\n    name=&quot;$(jq --argjson item &quot;$item&quot; -nr &#39;$item.name&#39;)&quot;\r\n    nested_name=&quot;$(jq --argjson item &quot;$item&quot; -nr &#39;$item.nested_name.name&#39;)&quot;\r\n    printf &#39;name is &quot;%s&quot; and nested_name is &quot;%s&quot;\\n&#39; &quot;$name&quot; &quot;$nested_name&quot;\r\ndone\r\n```\r\n\r\nIn a little more detail:\r\n* We use `--argjson` to pass our JSON string in as a single argument and `--null-input` to ignore stdin. This way we don&#39;t have to worry about escaping or delimiters on the way in.\r\n* We use `--compact-output` (or `-c`) to output one JSON object per line.\r\n* We use `IFS=` to make sure that spaces and tabs inside our JSON string don&#39;t get picked up as delimiters. Only newlines will act as delimiters, and because all newlines inside JSON strings must be escaped, we can be confident that we will loop exactly once with for each item in the original JSON array.\r\n* We use `--raw-output` (or `-r`) to output the value of the JSON string directly into the shell variable. (We can choose to omit this if we instead want the JSON-encoded string.) ",
                "title": "Pipe multiple jq values to &quot;while read -r&quot; loop"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1627496402,
        "creation_date": 1627425560,
        "question_id": 68552491,
        "body_markdown": "I am trying to find a clean way to assign 2 json string values to 2 variables within a while loop. The loop and input I am working with are as follows. \r\n\r\nINPUT:\r\n\r\n    foo=&#39;\r\n    [\r\n       {\r\n          &quot;name&quot;:&quot;name string (more info)&quot;,\r\n          &quot;nested_name&quot;:{\r\n             &quot;name&quot;:&quot;my name&quot;,\r\n             &quot;conclusion&quot;:&quot;failure&quot;,\r\n             &quot;number&quot;:11\r\n          }\r\n       },\r\n       {\r\n          &quot;name&quot;:&quot;name string (more info)&quot;,\r\n          &quot;nested_name&quot;:{\r\n             &quot;name&quot;:&quot;my other name&quot;,\r\n             &quot;conclusion&quot;:&quot;failure&quot;,\r\n             &quot;number&quot;:13\r\n          }\r\n       }\r\n    ]&#39;\r\n\r\n\r\nCurrently I have the following:\r\n\r\n    echo &quot;$foo&quot; | jq &quot;.[].name,.[].nested_name.name&quot; | while read -r foo bar; do\r\n        # do stuff with foo and bar\r\n    done\r\n\r\nIn iteration 1, I want:\r\n\r\n    foo = &quot;name string (more info)&quot; \r\n    bar = &quot;my name&quot;\r\n\r\nIteration 2:\r\n\r\n    foo = &quot;name string (more info)&quot; \r\n    bar = &quot;my other name&quot;\r\n\r\nHowever this generates the following incorrect output:\r\n\r\n    foo = &quot;name \r\n    bar = string (more info)&quot;\r\n    foo = &quot;name \r\n    bar = string (more info)&quot;\r\n    foo = &quot;my \r\n    bar = name&quot;\r\n    foo = &quot;my \r\n    bar = other name&quot;\r\n\r\nI&#39;ve been at this all day, any input or suggestions would be very much appreciated!",
        "link": "https://stackoverflow.com/questions/68552491/pipe-multiple-jq-values-to-while-read-r-loop",
        "title": "Pipe multiple jq values to &quot;while read -r&quot; loop"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1627435443,
                "creation_date": 1627435443,
                "answer_id": 68553308,
                "question_id": 68552823,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": ".[] | .fillDate = { &quot;$date&quot;:   .fillDate |( .[0:4] + &quot;-&quot; + .[5:7] + .[6:9] + &quot;T00:00:00Z&quot;)        \r\n\r\n\r\nsnippet on jqplay\r\nhttps://jqplay.org/s/JmYVXRzTnh\r\n",
                "title": "How to update field value in jq when your are parsing the field&#39;s value to update the field (aka reformatting the value)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1627435443,
        "creation_date": 1627429248,
        "question_id": 68552823,
        "body_markdown": "Given a starting object like this: \r\n\r\n```\r\n[{\r\n  &quot;fieldA&quot;: &quot;123&quot;,\r\n  &quot;fillDate&quot;: &quot;20210101&quot;,\r\n  &quot;fieldB&quot;: &quot;foo&quot;\r\n},\r\n{\r\n  &quot;fieldA&quot;: &quot;456&quot;,\r\n  &quot;fillDate&quot;: &quot;20210102&quot;,\r\n  &quot;fieldB&quot;: &quot;bar&quot;\r\n}]\r\n```\r\n\r\nI am reformatting the &quot;fillDate&quot; field from a string date, to something with the following structure:  \r\n```\r\nfillDate&quot;: { &quot;$date&quot; : &quot;2021-01-02T00:00:00Z&quot;},\r\n```\r\nThis is so it can be correctly imported into a MongoDB database. The following code works correctly for an array; but it eliminates out all of the other fields in the json document. \r\n```\r\njq --raw-output &#39;.[ ] | .fillDate | &quot;\\&quot;fillDate\\&quot;: { \\&quot;$date\\&quot; : \\&quot;&quot;+ .[0:4] + &quot;-&quot;+ .[4:6]+ &quot;-&quot;+ .[6:9] + &quot;T00:00:00Z\\&quot;&quot; + &quot;},&quot;&#39;\r\n```\r\nSo the output currently looks like this: \r\n```\r\n&quot;fillDate&quot;: { &quot;$date&quot; : &quot;2021-01-01T00:00:00Z&quot;},\r\n&quot;fillDate&quot;: { &quot;$date&quot; : &quot;2021-01-02T00:00:00Z&quot;},\r\n```\r\nWhen I need it to look like this:\r\n```\r\n{\r\n  &quot;fieldA&quot;: &quot;123&quot;,\r\n  &quot;fillDate&quot;: { &quot;$date&quot; : &quot;2021-01-01T00:00:00Z&quot;},\r\n  &quot;fieldB&quot;: &quot;foo&quot;\r\n},\r\n{\r\n  &quot;fieldA&quot;: &quot;456&quot;,\r\n  &quot;fillDate&quot;: { &quot;$date&quot; : &quot;2021-01-02T00:00:00Z&quot;},\r\n  &quot;fieldB&quot;: &quot;bar&quot;\r\n}\r\n```\r\nI tried other suggestions on how to update the fillDate field directly, in a manner that would leave the other fields in-tact (while also iterating over the array); but could not get jq to accept anything without giving an error. ",
        "link": "https://stackoverflow.com/questions/68552823/how-to-update-field-value-in-jq-when-your-are-parsing-the-fields-value-to-updat",
        "title": "How to update field value in jq when your are parsing the field&#39;s value to update the field (aka reformatting the value)"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1627467125,
                "last_edit_date": 1627467125,
                "creation_date": 1627466107,
                "answer_id": 68558195,
                "question_id": 68553586,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t think `INDEX` can help here.\r\n\r\nWhat I&#39;d do instead is this:\r\n``` none\r\nsort_by(.url | -length) as $c | inputs | map(. + (.href as $s | first($c[] | select(.url as $ss | $s | index($ss))) // {}))\r\n```\r\nIn case it&#39;s unclear, the JQ invocation will look like so:\r\n``` shell\r\njq &#39;...&#39; key.json index-of-pages.json\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/JCLeC_RtL7)&lt;/sup&gt;",
                "title": "Add values from a &quot;key&quot; JSON file to other files based on partial string matching using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1662425935,
        "creation_date": 1627438493,
        "last_edit_date": 1662425935,
        "question_id": 68553586,
        "body_markdown": "The goal is to compare a JSON file against a &quot;key&quot; of standard values and add those values to objects in another JSON file if certain strings match. The purpose is to merge two sets of analytics that have complementary data.\r\n\r\nThe condition I have been trying to match on is when `href` from index-of-pages.json includes the string in `url` in key.json.\r\n\r\n**index-of-pages.json**\r\n```\r\n[\r\n    {\r\n      &quot;href&quot;: &quot;articles/guide1/page1.html&quot;,\r\n      &quot;name&quot;: &quot;Page 1&quot;,\r\n      &quot;views&quot;: &quot;204&quot;\r\n    },\r\n    {\r\n      &quot;href&quot;: &quot;articles/guide2/page2.html&quot;,\r\n      &quot;name&quot;: &quot;Page 2&quot;,\r\n      &quot;views&quot;: &quot;180&quot;\r\n    },\r\n    {\r\n      &quot;href&quot;: &quot;articles/guide2/page3.html&quot;,\r\n      &quot;name&quot;: &quot;Page 3&quot;,\r\n      &quot;views&quot;: &quot;121&quot;\r\n    },\r\n    {\r\n      &quot;href&quot;: &quot;apis/apiguide1/subguide1/page4.html&quot;,\r\n      &quot;name&quot;: &quot;Page 4&quot;,\r\n      &quot;views&quot;: &quot;101&quot;\r\n    },\r\n    {\r\n      &quot;href&quot;: &quot;apis/apiguide2/subguide2/page5.html&quot;,\r\n      &quot;name&quot;: &quot;Page 5&quot;,\r\n      &quot;views&quot;: &quot;103&quot;\r\n    },\r\n    {\r\n      &quot;href&quot;: &quot;articles/guide1/about.html&quot;,\r\n      &quot;name&quot;: &quot;Page 6&quot;,\r\n      &quot;views&quot;: &quot;103&quot;\r\n    },\r\n    {\r\n      &quot;href&quot;: &quot;index.html&quot;,\r\n      &quot;name&quot;: &quot;Page 7&quot;,\r\n      &quot;views&quot;: &quot;400&quot;\r\n    }\r\n]\r\n```\r\n\r\n**key.json**\r\n```\r\n[\r\n\t{\r\n\t\t&quot;url&quot;: &quot;/guide1/&quot;,\r\n\t\t&quot;guide&quot;: &quot;Guide 1&quot;,\r\n\t\t&quot;tag&quot;: &quot;how-to&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;url&quot;: &quot;/guide2/&quot;,\r\n\t\t&quot;guide&quot;: &quot;Guide 2&quot;,\r\n\t\t&quot;tag&quot;: &quot;how-to&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;url&quot;: &quot;/apiguide1/subguide1/&quot;,\r\n\t\t&quot;guide&quot;: &quot;API Guide 1&quot;,\r\n        &quot;subguide&quot;: &quot;Subguide 1&quot;,\r\n\t\t&quot;tag&quot;: &quot;api&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;url&quot;: &quot;/guide1/about&quot;,\r\n\t\t&quot;guide&quot;: &quot;Guide 1&quot;,\r\n\t\t&quot;tag&quot;: &quot;about&quot;\r\n\t}\r\n]\r\n```\r\nNote there is no trailing slash on `url` in the last object.\r\n\r\n**Desired result:**\r\n```\r\n[\r\n    {\r\n        &quot;href&quot;: &quot;articles/guide1/page1.html&quot;,\r\n        &quot;name&quot;: &quot;Page 1&quot;,\r\n        &quot;views&quot;: &quot;204&quot;,\r\n        &quot;url&quot;: &quot;/guide1/&quot;,\r\n        &quot;guide&quot;: &quot;Guide 1&quot;,\r\n        &quot;tag&quot;: &quot;how-to&quot;\r\n    },\r\n    {\r\n        &quot;href&quot;: &quot;articles/guide2/page2.html&quot;,\r\n        &quot;name&quot;: &quot;Page 2&quot;,\r\n        &quot;views&quot;: &quot;180&quot;,\r\n        &quot;url&quot;: &quot;/guide2/&quot;,\r\n        &quot;guide&quot;: &quot;Guide 2&quot;,\r\n        &quot;tag&quot;: &quot;how-to&quot;\r\n    },\r\n    {\r\n        &quot;href&quot;: &quot;articles/guide2/page3.html&quot;,\r\n        &quot;name&quot;: &quot;Page 3&quot;,\r\n        &quot;views&quot;: &quot;121&quot;\r\n    },\r\n    {\r\n        &quot;href&quot;: &quot;apis/apiguide1/subguide1/page4.html&quot;,\r\n        &quot;name&quot;: &quot;Page 4&quot;,\r\n        &quot;views&quot;: &quot;101&quot;,\r\n        &quot;url&quot;: &quot;/apiguide1/&quot;,\r\n        &quot;guide&quot;: &quot;API Guide 1&quot;,\r\n        &quot;subguide&quot;: &quot;Subguide 1&quot;,\r\n\t\t&quot;tag&quot;: &quot;api&quot;\r\n    },\r\n    {\r\n        &quot;href&quot;: &quot;apis/apiguide2/subguide2/page5.html&quot;,\r\n        &quot;name&quot;: &quot;Page 5&quot;,\r\n        &quot;views&quot;: &quot;103&quot;\r\n    },\r\n    {\r\n        &quot;href&quot;: &quot;articles/guide1/about.html&quot;,\r\n        &quot;name&quot;: &quot;Page 6&quot;,\r\n        &quot;views&quot;: &quot;103&quot;,\r\n        &quot;url&quot;: &quot;/guide1/about&quot;,\r\n        &quot;guide&quot;: &quot;Guide 1&quot;,\r\n        &quot;tag&quot;: &quot;about&quot;\r\n    },\r\n    {\r\n        &quot;href&quot;: &quot;index.html&quot;,\r\n        &quot;name&quot;: &quot;Page 7&quot;,\r\n        &quot;views&quot;: &quot;400&quot;\r\n    }\r\n]\r\n```\r\nObjects in **index-of-files.json** that do not match anything in the key would still be included in the desired output.\r\n\r\nWhether it is desirable for all keys to be included in the output objects even when they are empty, I&#39;m not sure what is best practice.\r\n\r\nThis has brought me closest, but I cannot figure out how to incorporate a step to match on the key:\r\n```\r\njq --argfile uid key.json &#39;\r\n ($uid | INDEX(.url)) as $dict\r\n | map( $dict[.href] + del(.href) )\r\n &#39; index-of-files.json\r\n```\r\n\r\nOther attempts such as the following do not result in a 1:1 match of objects; rather, it produces a huge list of every possible combination of every key (the output was nested so I labeled it `key`; all desired output keys are not shown in this script):\r\n\r\n```\r\n(.[].href/&quot;/&quot;?|{key: (&quot;/&quot; + .[-2] + &quot;/&quot;)}) as $abc | {name: .[].name, level: $abc}\r\n```\r\n\r\nI have also tried variations on `while if` loops with no success:\r\n\r\n```\r\njq -r &#39;.[] | &quot;\\(.url)|\\(.guide)|\\(.tag)|\\(.subguide)&quot;&#39; key.json |\r\nwhile IFS=&quot;|&quot; read -r url guide tag subguide; do\r\ncat index-of-files.json | jq --arg url &quot;$url&quot; --arg guide &quot;$guide&quot; --arg subguide &quot;$subguide&quot; &#39;.[] | if (.href | contains(&#39;\\&quot;$url\\&quot;&#39;)) then . + {guide: &#39;\\&quot;$guide\\&quot;&#39;, tag: &#39;\\&quot;$tag\\&quot;&#39;, subguide: &#39;\\&quot;$subguide\\&quot;&#39;} else . end&#39;\r\ndone\r\n```\r\n\r\nThank you for any insight or guidance.",
        "link": "https://stackoverflow.com/questions/68553586/add-values-from-a-key-json-file-to-other-files-based-on-partial-string-matchin",
        "title": "Add values from a &quot;key&quot; JSON file to other files based on partial string matching using JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1627526557,
                "creation_date": 1627526557,
                "answer_id": 68569406,
                "question_id": 68568375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq &#39;del( .features[] | select(.properties.algorithm == &quot;parameterA&quot;) )&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/TUQ2IXSL5l)",
                "title": "How can I erase specific parts of an array based on their content using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1627526557,
        "creation_date": 1627514617,
        "question_id": 68568375,
        "body_markdown": "Let&#39;s say I have the following GeoJSON file:\r\n\r\n```\r\n{\r\n    &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n    &quot;features&quot;: [\r\n      {\r\n        &quot;type&quot;: &quot;Feature&quot;,\r\n        &quot;properties&quot;: {\r\n        &quot;algorithm&quot;: &quot;parameterA&quot;\r\n        },\r\n        &quot;geometry&quot;: {\r\n          &quot;type&quot;: &quot;MultiPolygon&quot;,\r\n          &quot;coordinates&quot;: []\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;Feature&quot;,\r\n        &quot;properties&quot;: {\r\n        &quot;algorithm&quot;: &quot;parameterB&quot;\r\n        },\r\n        &quot;geometry&quot;: {\r\n          &quot;type&quot;: &quot;MultiPolygon&quot;,\r\n          &quot;coordinates&quot;: []\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;Feature&quot;,\r\n        &quot;properties&quot;: {\r\n        &quot;algorithm&quot;: &quot;parameterB&quot;\r\n        },\r\n        &quot;geometry&quot;: {\r\n          &quot;type&quot;: &quot;MultiPolygon&quot;,\r\n          &quot;coordinates&quot;: []\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;Feature&quot;,\r\n        &quot;properties&quot;: {\r\n        &quot;algorithm&quot;: &quot;parameterA&quot;\r\n        },\r\n        &quot;geometry&quot;: {\r\n          &quot;type&quot;: &quot;MultiPolygon&quot;,\r\n          &quot;coordinates&quot;: []\r\n        }\r\n      }\r\n    ],\r\n    &quot;properties&quot;: {\r\n      &quot;name&quot;: &quot;myGeoJSON&quot;\r\n    }\r\n}\r\n```\r\n\r\nI&#39;d like to find a way of erasing only the arrays containing a specific `algorithm` key. Let&#39;s say I want to erase all arrays which `algorithm` is equal to `parameterA`, so I&#39;d get the following result:\r\n\r\n    {\r\n        &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n        &quot;features&quot;: [\r\n          {\r\n            &quot;type&quot;: &quot;Feature&quot;,\r\n            &quot;properties&quot;: {\r\n            &quot;algorithm&quot;: &quot;parameterB&quot;\r\n            },\r\n            &quot;geometry&quot;: {\r\n              &quot;type&quot;: &quot;MultiPolygon&quot;,\r\n              &quot;coordinates&quot;: []\r\n            }\r\n          },\r\n          {\r\n            &quot;type&quot;: &quot;Feature&quot;,\r\n            &quot;properties&quot;: {\r\n            &quot;algorithm&quot;: &quot;parameterB&quot;\r\n            },\r\n            &quot;geometry&quot;: {\r\n              &quot;type&quot;: &quot;MultiPolygon&quot;,\r\n              &quot;coordinates&quot;: []\r\n            }\r\n          }\r\n        ],\r\n        &quot;properties&quot;: {\r\n          &quot;name&quot;: &quot;myGeoJSON&quot;\r\n        }\r\n    }\r\n\r\nI know I can erase a specific value from my array by using something like `jq del&#39;(.features[0] )&#39; file.json`. But I don&#39;t know how to use a condition in it that will erase only array blocks that have a specific property. How can I do it using `jq`?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68568375/how-can-i-erase-specific-parts-of-an-array-based-on-their-content-using-jq",
        "title": "How can I erase specific parts of an array based on their content using jq?"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1627532285,
                "last_edit_date": 1627532285,
                "creation_date": 1627532014,
                "answer_id": 68569960,
                "question_id": 68569705,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could wrap the results of your query in an array and then pick the first one \r\n\r\n```\r\n[.tags[] | select(.key==&quot;env&quot;)] | .[0]\r\n```",
                "title": "How to get the first object after filtering an array in jq?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1627555030,
                "creation_date": 1627555030,
                "answer_id": 68574394,
                "question_id": 68569705,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `first(expr)` to provide an expression that satisfies your usecase.\r\n\r\n```\r\nfirst(.tags[]? | select(.key == &quot;env&quot;) .value)\r\n```",
                "title": "How to get the first object after filtering an array in jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1627584823,
                "last_edit_date": 1627584823,
                "creation_date": 1627584519,
                "answer_id": 68581467,
                "question_id": 68569705,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq -r &#39;first( .tags[] | select(.key==&quot;env&quot;) ).value&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/UphoXETxo-)\r\n\r\n---\r\n\r\n`.tags[]` flattens the array into a stream of values. You&#39;re applying `.[0]` to each of the values, not a filtered array. To filter an array, you&#39;d use\r\n\r\n```jq\r\n.tags | map(select(...)) | .[0]\r\n```\r\n\r\nor \r\n\r\n```jq\r\n.tags | map(select(...)) | first\r\n```\r\n\r\n`map(...)` is a shorthand for `[ .[] | ... ]`, so the above is equivalent to\r\n\r\n```jq\r\n.tags | [ .[] | select(...) ] | first\r\n```\r\n\r\nand\r\n\r\n```jq\r\n[ .tags[] | select(...) ] | first\r\n```\r\n\r\nFinally, `[ ... ] | first` can be written as `first(...)`.\r\n\r\n```jq\r\nfirst( .tags[] | select(...) )\r\n```\r\n",
                "title": "How to get the first object after filtering an array in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1627622276,
        "creation_date": 1627529459,
        "last_edit_date": 1627622276,
        "question_id": 68569705,
        "body_markdown": "Given the following JSON \r\n\r\n    {\r\n      &quot;tags&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;env&quot;,\r\n          &quot;value&quot;: &quot;foo&quot;\r\n        },\r\n         {\r\n          &quot;key&quot;: &quot;env&quot;,\r\n          &quot;value&quot;: &quot;bar&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI am trying to find out the first tag where the key is `env`. I have this- \r\n```\r\n.tags[] | select (.key==&quot;env&quot;) |.[0]\r\n```\r\nbut that gives me an error `Cannot index object with number`\r\n",
        "link": "https://stackoverflow.com/questions/68569705/how-to-get-the-first-object-after-filtering-an-array-in-jq",
        "title": "How to get the first object after filtering an array in jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "while-loop",
            "jq",
            "ifs"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1627591576,
                "last_edit_date": 1627591576,
                "creation_date": 1627591236,
                "answer_id": 68582537,
                "question_id": 68582317,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need a `while` loop. Just format it with the jq command:\r\n\r\n    echo &quot;$foo&quot; | jq -j &#39;.[] | &quot;job = &quot;, .name, &quot;\\nstep = &quot;, .failed_step.name, &quot;\\nnumber = &quot;, .failed_step.number, &quot;\\n&quot;&#39;\r\n\r\nThis produces the same output that you want:\r\n\r\n    $ echo &quot;$foo&quot; | jq -j &#39;.[] | &quot;job = &quot;, .name, &quot;\\nstep = &quot;, .failed_step.name, &quot;\\nnumber = &quot;, .failed_step.number, &quot;\\n&quot;&#39;\r\n    job = e2e (control-plane, true, true, true, ipv4, IPv4, true, false)\r\n    step = Run Tests\r\n    number = 11\r\n    job = e2e (control-plane, true, true, true, ipv4, IPv4, true, false)\r\n    step = Generate Test Report\r\n    number = 13\r\n    $\r\n\r\n",
                "title": "Use IFS$&#39;\\n&#39; to read -r jq into multiple variables"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1627591630,
                "creation_date": 1627591630,
                "answer_id": 68582608,
                "question_id": 68582317,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Rather than trying to use `\\n`, perhaps tweak the `jq` to separate with tabs.  Something like:\r\n\r\n \r\n\r\n    jq -r &#39;.[] | .name + &quot;\\t&quot; + .failed_step.name + &quot;\\t&quot; + (.failed_step.number | tostring)&#39;\r\n\r\nThen you can do `while IFS=$&#39;\\t&#39; read job step number; do ...`",
                "title": "Use IFS$&#39;\\n&#39; to read -r jq into multiple variables"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1627591630,
        "creation_date": 1627589673,
        "question_id": 68582317,
        "body_markdown": "I currently have the following code which works as I want it to. \r\n\r\n    foo=&#39;\r\n    [{\r\n    \t&quot;name&quot;: &quot;e2e (control-plane, true, true, true, ipv4, IPv4, true, false)&quot;,\r\n    \t&quot;failed_step&quot;: {\r\n    \t\t&quot;name&quot;: &quot;Run Tests&quot;,\r\n    \t\t&quot;conclusion&quot;: &quot;failure&quot;,\r\n    \t\t&quot;number&quot;: 11\r\n    \t}\r\n    }, {\r\n    \t&quot;name&quot;: &quot;e2e (control-plane, true, true, true, ipv4, IPv4, true, false)&quot;,\r\n    \t&quot;failed_step&quot;: {\r\n    \t\t&quot;name&quot;: &quot;Generate Test Report&quot;,\r\n    \t\t&quot;conclusion&quot;: &quot;failure&quot;,\r\n    \t\t&quot;number&quot;: 13\r\n    \t}\r\n    }]&#39;\r\n\r\n    echo &quot;$foo&quot; | jq -r &#39;.[] | .name, .failed_step.name, .failed_step.number&#39; | while \\\r\n        read -r job &amp;&amp; read -r step &amp;&amp; read -r number; do\r\n            echo &quot;job = $job&quot;;\r\n            echo &quot;step = $step&quot;;\r\n            echo &quot;number = $number&quot;;\r\n    done\r\n\r\nwhich outputs the following desired output:\r\n\r\n    job = e2e (control-plane, true, true, true, ipv4, IPv4, true, false)\r\n    step = Run Tests\r\n    number = 11\r\n    job = e2e (control-plane, true, true, true, ipv4, IPv4, true, false)\r\n    step = Generate Test Report\r\n    number = 13\r\n\r\nHowever, my question is, is there a way to do this using IFS to avoid 3 separate read statements? I came up with the following, however, the output it generates is not quite right. It looks like it only reads into the first variable. \r\n\r\n    echo &quot;$foo&quot; | jq -r &#39;.[] | .name, .failed_step.name, .failed_step.number&#39; | while IFS=$&#39;\\n&#39; \\\r\n        read -r job step number; do \r\n            echo &quot;job = $job&quot;;\r\n            echo &quot;step = $step&quot;; \r\n            echo &quot;number = $number&quot;; \r\n    done\r\n\r\noutput:\r\n\r\n    job = e2e (control-plane, true, true, true, ipv4, IPv4, true, false)\r\n    step = \r\n    number = \r\n    job = Run Tests\r\n    step = \r\n    number = \r\n    job = 11\r\n    step = \r\n    number = \r\n    job = e2e (control-plane, true, true, true, ipv4, IPv4, true, false)\r\n    step = \r\n    number = \r\n    job = Generate Test Report\r\n    step = \r\n    number = \r\n    job = 13\r\n    step = \r\n    number = \r\n\r\n\r\nI feel like there has to be a way to do this, however I&#39;ve been at it for a while with no success.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68582317/use-ifs-n-to-read-r-jq-into-multiple-variables",
        "title": "Use IFS$&#39;\\n&#39; to read -r jq into multiple variables"
    },
    {
        "tags": [
            "json",
            "windows",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1627666369,
                "post_id": 68594397,
                "comment_id": 121226154,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20527725,
                    "reputation": 173,
                    "user_id": 15065774,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/89e51da4b91d443ca2941b419cadfb92?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ahamed",
                    "link": "https://stackoverflow.com/users/15065774/ahamed"
                },
                "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": 1627699501,
                "post_id": 68594397,
                "comment_id": 121232667,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 93689,
                    "reputation": 426801,
                    "user_id": 256196,
                    "user_type": "moderator",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/d84b558fd67be10d5a718fb94231909d?s=256&d=identicon&r=PG",
                    "display_name": "Bohemian",
                    "link": "https://stackoverflow.com/users/256196/bohemian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1627722022,
                "post_id": 68594397,
                "comment_id": 121235928,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20527725,
                    "reputation": 173,
                    "user_id": 15065774,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/89e51da4b91d443ca2941b419cadfb92?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ahamed",
                    "link": "https://stackoverflow.com/users/15065774/ahamed"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1627722350,
                "post_id": 68594397,
                "comment_id": 121235974,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1627756604,
                "last_edit_date": 1627756604,
                "creation_date": 1627733125,
                "answer_id": 68601930,
                "question_id": 68594397,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you have not followed the [mcve] guidelines, and more specifically since\r\nyou have neither described your functional requirements nor shown the expected output corresponding plausibly to the shown input,\r\nit is difficult to give more than a diagnosis for the problem you&#39;ve encountered.\r\n\r\nIn brief, each &quot;feature&quot; is not a flat object, and so, since you want to use `@csv`, you&#39;re\r\ngoing to have to specify how to represent each &quot;feature&quot; as a flat array.\r\n\r\nThis could be done in one of the following ways, but in each case, your headers are not going to match:\r\n\r\n    .features[] | [.. | scalars]\r\n\r\nor\r\n\r\n    .features[] | [.geometry.coordinates[], .properties[]]\r\n\r\nBy the way, to debug your programs, you can use jq&#39;s `debug` filter.\r\n",
                "title": "&quot;Cannot iterate over string&quot; error on converting .json to csv using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1627756604,
        "creation_date": 1627663154,
        "last_edit_date": 1627737044,
        "question_id": 68594397,
        "body_markdown": "We are trying to convert .geojson (openstreetmaps) to csv using &#39;jq&#39; command in command line prompt. On running the following command:\r\n\r\n```jq -r &#39;(.features[0] | keys_unsorted), (.features[] | to_entries | map(.value[]))|@csv&#39; temp.json```\r\n\r\nIt throws up this error\r\n```jq: error (at gcc.geojson:1892525): Cannot iterate over string (&quot;Feature&quot;).```\r\n\r\nThe gcc.geojson file contains 189252 lines. We need the columns: &quot;coordinates&quot;, &quot;properties&quot; and properties&#39;s sub nests as columns in the .csv file. Sample content is as given below for your information\r\n```\r\n{&quot;type&quot;:&quot;FeatureCollection&quot;,&quot;features&quot;:[\r\n{&quot;type&quot;:&quot;Feature&quot;,&quot;geometry&quot;:{&quot;type&quot;:&quot;Point&quot;,&quot;coordinates&quot;:[55.3139296,25.1810675]},&quot;properties&quot;:{&quot;highway&quot;:&quot;motorway_junction&quot;}},\r\n{&quot;type&quot;:&quot;Feature&quot;,&quot;geometry&quot;:{&quot;type&quot;:&quot;Point&quot;,&quot;coordinates&quot;:[55.3048406,25.2769554]},&quot;properties&quot;:{&quot;highway&quot;:&quot;traffic_signals&quot;}},\r\n{&quot;type&quot;:&quot;Feature&quot;,&quot;geometry&quot;:{&quot;type&quot;:&quot;Point&quot;,&quot;coordinates&quot;:[55.3064633,25.273499]},&quot;properties&quot;:{&quot;highway&quot;:&quot;traffic_signals&quot;,&quot;traffic_signals&quot;:&quot;signal&quot;}},\r\n{&quot;type&quot;:&quot;Feature&quot;,&quot;geometry&quot;:{&quot;type&quot;:&quot;Point&quot;,&quot;coordinates&quot;:[55.3160278,25.2672419]},&quot;properties&quot;:{&quot;highway&quot;:&quot;traffic_signals&quot;,&quot;traffic_signals&quot;:&quot;signal&quot;}},\r\n{&quot;type&quot;:&quot;Feature&quot;,&quot;geometry&quot;:{&quot;type&quot;:&quot;Point&quot;,&quot;coordinates&quot;:[55.3130749,25.2627212]},&quot;properties&quot;:{&quot;highway&quot;:&quot;traffic_signals&quot;,&quot;traffic_signals&quot;:&quot;signal&quot;}},\r\n{&quot;type&quot;:&quot;Feature&quot;,&quot;geometry&quot;:{&quot;type&quot;:&quot;Point&quot;,&quot;coordinates&quot;:[57.0755556,27.1506482]},&quot;properties&quot;:{&quot;int_name&quot;:&quot;Minab&quot;,&quot;name&quot;:&quot;میناب&quot;,&quot;addr:street&quot;:&quot;Minab&quot;,&quot;name:ja&quot;:&quot;ミーナーブ&quot;,&quot;name:ru&quot;:&quot;Минаб&quot;,&quot;place&quot;:&quot;town&quot;,&quot;population&quot;:&quot;73170&quot;,&quot;population:date&quot;:&quot;2016&quot;,&quot;source:population&quot;:&quot;amar.org.ir&quot;,&quot;wikidata&quot;:&quot;Q691052&quot;,&quot;wikipedia&quot;:&quot;en:Minab&quot;}},\r\n{&quot;type&quot;:&quot;Feature&quot;,&quot;geometry&quot;:{&quot;type&quot;:&quot;Point&quot;,&quot;coordinates&quot;:[54.4249414,24.5382557]},&quot;properties&quot;:{&quot;addr:city&quot;:&quot;Abu Dhabi&quot;,&quot;addr:neighbourhood&quot;:&quot;St. Regis Saadiyat Island&quot;,&quot;addr:street&quot;:&quot;St. Regis Saadiyat&quot;,&quot;contact:email&quot;:&quot;spnstregis@spinneysauh.com&quot;,&quot;contact:facebook&quot;:&quot;https://facebook.com/Spinneysbev&quot;,&quot;contact:instagram&quot;:&quot;https://instagram.com/spinneysbev&quot;,&quot;contact:phone&quot;:&quot;+971 2 676 6778&quot;,&quot;contact:twitter&quot;:&quot;https://twitter.com/@spinneysbev&quot;,&quot;contact:website&quot;:&quot;https://spinneysauh.com/&quot;,&quot;drive_through&quot;:&quot;no&quot;,&quot;name&quot;:&quot;Spinneys&quot;,&quot;opening_hours&quot;:&quot;Fr 09:00-12:00,13:00-22:00;Mo-Th,Sa-Su 09:00-22:00&quot;,&quot;operator&quot;:&quot;Spinneys&quot;,&quot;payment:cash&quot;:&quot;yes&quot;,&quot;payment:credit_cards&quot;:&quot;yes&quot;,&quot;shop&quot;:&quot;alcohol&quot;}},\r\n{&quot;type&quot;:&quot;Feature&quot;,&quot;geometry&quot;:{&quot;type&quot;:&quot;Point&quot;,&quot;coordinates&quot;:[54.4250687,24.5383771]},&quot;properties&quot;:{&quot;addr:city&quot;:&quot;Abu Dhabi&quot;,&quot;addr:neighbourhood&quot;:&quot;St. Regis Saadiyat Island&quot;,&quot;addr:street&quot;:&quot;St. Regis Saadiyat&quot;,&quot;name&quot;:&quot;Spinney&#39;s Market&quot;,&quot;operator&quot;:&quot;Spinney&#39;s&quot;,&quot;payment:cash&quot;:&quot;yes&quot;,&quot;payment:coins&quot;:&quot;yes&quot;,&quot;payment:credit_cards&quot;:&quot;yes&quot;,&quot;shop&quot;:&quot;supermarket&quot;}},\r\n\r\n```\r\n\r\nThe expected output is as given below:\r\n\r\n```&quot;54.4249414,24.5382557&quot;, &quot;Abu Dhabi&quot;,&quot;St. Regis Saadiyat Island&quot;,&quot;St. Regis Saadiyat&quot;,&quot;contact:email&quot;:&quot;spnstregis@spinneysauh.com&quot;,etc```\r\n\r\nAny help on how to get the desired result would be much appreciated ",
        "link": "https://stackoverflow.com/questions/68594397/cannot-iterate-over-string-error-on-converting-json-to-csv-using-jq",
        "title": "&quot;Cannot iterate over string&quot; error on converting .json to csv using jq"
    },
    {
        "tags": [
            "kubernetes",
            "jq",
            "metrics"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1627819453,
                "creation_date": 1627819453,
                "answer_id": 68610233,
                "question_id": 68610117,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can leverage the `select` function for this:\r\n\r\n    cat kubernetes.txt | jq &#39;fromjson.kubernetes.pod | select(.cpu.usage.nanocores != null) | .name, .cpu.usage.nanocores&#39;\r\n\r\n\r\nhttps://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions",
                "title": "How to output only necessary information in jq request"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1627819453,
        "creation_date": 1627818593,
        "question_id": 68610117,
        "body_markdown": "I&#39;m writing this jq request to output info about cpu:\r\n\r\n    cat kubernetes.txt | jq &#39;fromjson.kubernetes.pod | .name, .cpu.usage.nanocores&#39;\r\n\r\nMy output is:\r\n\r\n    &quot;podname&quot;\r\n    null\r\n    &quot;podname1&quot;\r\n    null\r\n    &quot;podname2&quot;\r\n    null\r\n    &quot;podname3&quot;\r\n    3345678\r\n    &quot;podname3&quot;\r\n    123456\r\n\r\nHow to output only strings with values",
        "link": "https://stackoverflow.com/questions/68610117/how-to-output-only-necessary-information-in-jq-request",
        "title": "How to output only necessary information in jq request"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1627903197,
                "creation_date": 1627903197,
                "answer_id": 68620687,
                "question_id": 68619636,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Looks like you&#39;re looking for something like this:\r\n```\r\n&quot;\\(.queue_id) \\(.recipients[].address)&quot;\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/8i4od9GIDA)&lt;/sup&gt;",
                "title": "Output values in multiple lines with same key in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1627910243,
        "creation_date": 1627898302,
        "last_edit_date": 1627910243,
        "question_id": 68619636,
        "body_markdown": "I&#39;ve got an example json:\r\n\r\n    {\r\n      &quot;queue_id&quot;: &quot;ABCD12345&quot;,\r\n      &quot;sender&quot;: &quot;sender@example.com&quot;,\r\n      &quot;recipients&quot;: [\r\n        {\r\n          &quot;address&quot;: &quot;recipient1@example.com&quot;\r\n        },\r\n        {\r\n          &quot;address&quot;: &quot;recipient2@example.com&quot;\r\n        },\r\n        {\r\n          &quot;address&quot;: &quot;recipient3@example.com&quot;\r\n        },\r\n        {\r\n          &quot;address&quot;: &quot;recipient3@example.com&quot;\r\n        }\r\n      ]\r\n    }\r\nI would like to get output that looks something like:\r\n\r\n    ABCD12345 recipient1@example.com\r\n    ABCD12345 recipient2@example.com\r\n    ABCD12345 recipient3@example.com\r\n    ABCD12345 recipient4@example.com\r\nStarting with having sender address, currently i parse file to get the multiple queue_id for sender address, then with multiple queue_id I loop through them to get addresses, then loop through the addresses and then finaly getting other values from .json for current address/queue_id pair.\r\nIs there a way to format this kind of output directly in jq or something easier than above mentioned double for loops? \r\n\r\n**EDIT:**\r\nmore data\r\n\r\n    {\r\n      &quot;queue_id&quot;: &quot;ABCD12345&quot;,\r\n      &quot;sender&quot;: &quot;sender@example.com&quot;,\r\n      &quot;recipients&quot;: [\r\n        {\r\n          &quot;address&quot;: &quot;recipient1@example.com&quot;,\r\n          &quot;something&quot;: &quot;output1&quot;\r\n        },\r\n        {\r\n          &quot;address&quot;: &quot;recipient2@example.com&quot;,\r\n          &quot;something&quot;: &quot;output2&quot;\r\n        },\r\n        {\r\n          &quot;address&quot;: &quot;recipient3@example.com&quot;,\r\n          &quot;something&quot;: &quot;output3&quot;\r\n        },\r\n        {\r\n          &quot;address&quot;: &quot;recipient3@example.com&quot;,\r\n          &quot;something&quot;: &quot;output4&quot;\r\n        }\r\n      ]\r\n    }\r\nDesired output:\r\n\r\n    ABCD12345 sender@example.com recipient1@example.com output1\r\n    ABCD12345 sender@example.com recipient2@example.com output2\r\n    ABCD12345 sender@example.com recipient3@example.com output3\r\n    ABCD12345 sender@example.com recipient4@example.com output4",
        "link": "https://stackoverflow.com/questions/68619636/output-values-in-multiple-lines-with-same-key-in-jq",
        "title": "Output values in multiple lines with same key in JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3520895,
                    "reputation": 27048,
                    "user_id": 2943218,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/OoyGW.jpg?s=256",
                    "display_name": "Carsten L&#248;vbo Andersen",
                    "link": "https://stackoverflow.com/users/2943218/carsten-l%c3%b8vbo-andersen"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1627908039,
                "post_id": 68621762,
                "comment_id": 121273505,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1421751,
                    "reputation": 43712,
                    "user_id": 1346234,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://i.sstatic.net/2y3FX.png?s=256",
                    "display_name": "Justinas",
                    "link": "https://stackoverflow.com/users/1346234/justinas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1627908101,
                "post_id": 68621762,
                "comment_id": 121273538,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20634358,
                    "reputation": 55,
                    "user_id": 15148439,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ce126bfe164406bad5fb1573576e0002?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "igaro4ak337",
                    "link": "https://stackoverflow.com/users/15148439/igaro4ak337"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1627908277,
                "post_id": 68621762,
                "comment_id": 121273620,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1627997187,
                "last_edit_date": 1627997187,
                "creation_date": 1627908315,
                "answer_id": 68621835,
                "question_id": 68621762,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The pipeline you&#39;re looking for is\r\n\r\n```\r\njq &#39;fromjson | .[&quot;@timestamp&quot;]&#39;\r\n```\r\n\r\nYou cannot use the `.foo` syntax to access fields with special characters such as &quot;@&quot;.",
                "title": "how to out timestamp with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -4,
        "last_activity_date": 1627997187,
        "creation_date": 1627907992,
        "last_edit_date": 1627908321,
        "question_id": 68621762,
        "body_markdown": "I&#39;m trying to out data with jq request\r\n\r\n\r\n    &quot;{\\&quot;@timestamp\\&quot;:\\&quot;2019-03-13T00:11:03.123Y\\&quot;\r\n\r\nI&#39;m typing: `cat myfile.txt | jq fromjson.timestamp`\r\n\r\nBut it&#39;s incorrect",
        "link": "https://stackoverflow.com/questions/68621762/how-to-out-timestamp-with-jq",
        "title": "how to out timestamp with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1627933748,
                "creation_date": 1627933748,
                "answer_id": 68627222,
                "question_id": 68627056,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input JSON fixed to take keys/values in double-quotes, your expression could be written as\r\n\r\n```none\r\n[ {key1}, (.key2[] | { (.key4): .key3} ) ] | add\r\n```",
                "title": "How to merge keys in inner object with its parent (unnesting)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1628014572,
        "creation_date": 1627932613,
        "last_edit_date": 1628014572,
        "question_id": 68627056,
        "body_markdown": "This is an example input:\r\n\r\n```json\r\n{\r\n  &quot;key1&quot;: &quot;value&quot;,      \r\n  &quot;key2&quot;: [\r\n    {&quot;key3&quot;: 5, &quot;key4&quot;: &quot;value1&quot;},  \r\n    {&quot;key3&quot;: null, &quot;key4&quot;: &quot;value2&quot;},  \r\n    {&quot;key3&quot;: 9, &quot;key4&quot;: &quot;value3&quot;}\r\n  ]\r\n}\r\n```\r\n\r\nExample output:\r\n\r\n```json\r\n{\r\n  &quot;key1&quot;: &quot;value&quot;,\r\n  &quot;value1&quot;: 5,\r\n  &quot;value2&quot;: null,\r\n  &quot;value3&quot;: 9\r\n}\r\n```\r\n\r\nThis was generated with the following Python code:\r\n```python\r\nnew = {x[&#39;key4&#39;]: x[&#39;key3&#39;] for x in old}\r\nnew[&#39;key1&#39;] = old[&#39;key1&#39;]\r\n```\r\n\r\nI attempted to do this with jq, but this is far as I got:\r\n\r\n```\r\n[.[] | {k1: .key1, k2: .key2 | map({ (.key4): .key3}) | add}]\r\n```\r\n\r\nWhich gives me\r\n\r\n```json\r\n{\r\n  &quot;key1&quot;: &quot;value&quot;,\r\n  &quot;key2&quot;: {\r\n    &quot;value1&quot;: 5,\r\n    &quot;value2&quot;: null,\r\n    &quot;value3&quot;: 9\r\n  }\r\n}\r\n```\r\n\r\nI&#39;d say that what&#39;s missing is how to &quot;merge&quot; keys in the object with the top-level. How can I do that?",
        "link": "https://stackoverflow.com/questions/68627056/how-to-merge-keys-in-inner-object-with-its-parent-unnesting",
        "title": "How to merge keys in inner object with its parent (unnesting)"
    },
    {
        "tags": [
            "json",
            "conditional-statements",
            "iteration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1628042477,
                "creation_date": 1628042477,
                "answer_id": 68644577,
                "question_id": 68643008,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way:\r\n\r\n```\r\nmap( (.mount \r\n      | if . == &quot;/&quot; then &quot;root&quot; \r\n        elif . == &quot;/opt&quot; then &quot;opt&quot; \r\n        else &quot;tmp&quot; end) as $type\r\n      | {key: &quot;val1&quot;,\r\n         mnt:  &quot;\\(.mount)-\\($type)FS&quot;,\r\n         key3: {key4: &quot;val4&quot;}} )\r\n```",
                "title": "conditional transformation on json doc"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1628061447,
        "creation_date": 1628026288,
        "last_edit_date": 1628061447,
        "question_id": 68643008,
        "body_markdown": "I have the following json doc (file.json):\r\n\r\n    [{\r\n      &quot;mount&quot;: &quot;/&quot;,\r\n      &quot;size&quot;: &quot;45G&quot;,\r\n      &quot;usedperc&quot;: &quot;26&quot;\r\n    },\r\n    {\r\n      &quot;mount&quot;: &quot;/opt&quot;,\r\n      &quot;size&quot;: &quot;197G&quot;,\r\n      &quot;usedperc&quot;: &quot;20&quot;\r\n    },\r\n    {\r\n      &quot;mount&quot;: &quot;/tmp&quot;,\r\n      &quot;size&quot;: &quot;5.0G&quot;,\r\n      &quot;usedperc&quot;: &quot;8&quot;\r\n    }]\r\n\r\nGiven this doc , I would like to transform into a different doc, with this structure:\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;val1&quot;,\r\n        &quot;mnt&quot;: &quot;/-rootFS&quot;,\r\n        &quot;key3&quot;: {\r\n          &quot;key4&quot;: &quot;val4&quot;\r\n        }\r\n      },\r\n     {\r\n        &quot;key&quot;: &quot;val1&quot;,\r\n        &quot;mnt&quot;: &quot;/opt-optFS&quot;,\r\n        &quot;key3&quot;: {\r\n          &quot;key4&quot;: &quot;val4&quot;\r\n        }\r\n      },\r\n     {\r\n        &quot;key&quot;: &quot;val1&quot;,\r\n        &quot;mnt&quot;: &quot;/tmp-tmpFS&quot;,\r\n        &quot;key3&quot;: {\r\n          &quot;key4&quot;: &quot;val4&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nHOwever, when trying to apply the transformation with js, it stops on the first iteration of the document , and does not process the rest of the doc:\r\n\r\n    jq  &#39; [{\r\n          &quot;key&quot;:&quot;val1&quot;,\r\n          &quot;mnt&quot;: .[]|(if select(.mount == &quot;/&quot;) then  &quot;/-rootFS&quot; elif select(.mount == &quot;/opt&quot;) then &quot;/opt-optFS&quot; elif select(.mount == &quot;/tmp&quot;) then &quot;/tmp-tmpFS&quot; else . end ) ,\r\n          &quot;key3&quot;:{\r\n             &quot;key4&quot;: &quot;val4&quot;\r\n          }}]&#39; &lt; file.json\r\n\r\n#output\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;val1&quot;,\r\n        &quot;mnt&quot;: &quot;/-rootFS&quot;,\r\n        &quot;key3&quot;: {\r\n          &quot;key4&quot;: &quot;val4&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nNot sure how to do it , I have tried in many different ways, mostly getting a &quot;Cannot index array with string &quot;mount&quot;&quot; error. Btw this is actually just a test case from a bigger jq expression, so I would like to do it with jq if that is possible",
        "link": "https://stackoverflow.com/questions/68643008/conditional-transformation-on-json-doc",
        "title": "conditional transformation on json doc"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1628044312,
                "post_id": 68644504,
                "comment_id": 121314326,
                "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": 1628067744,
                "post_id": 68644504,
                "comment_id": 121320254,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 151,
                    "reputation": 35679,
                    "user_id": 188,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/833bfbcc9940cfcf0af6def751c23b05?s=256&d=identicon&r=PG",
                    "display_name": "Matthew Schinckel",
                    "link": "https://stackoverflow.com/users/188/matthew-schinckel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628131207,
                "post_id": 68644504,
                "comment_id": 121340661,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1628137188,
                "post_id": 68644504,
                "comment_id": 121341639,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1628136995,
                "last_edit_date": 1628136995,
                "creation_date": 1628058915,
                "answer_id": 68646436,
                "question_id": 68644504,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following:\r\n\r\n```sh\r\njq --rawfile to_keep_file to_keep.txt &#39;\r\n   ( [ $to_keep_file | match(&quot;.+&quot;; &quot;g&quot;).string | { (.): true } ] | add ) as $to_keep_lkup |\r\n   map(select($to_keep_lkup[.key]))\r\n&#39; to_filter.json\r\n```\r\n\r\nor\r\n\r\n```sh\r\n(\r\n   jq -sR . to_keep.txt\r\n   cat to_filter.json\r\n) | jq -n &#39;\r\n   ( [ input | match(&quot;.+&quot;; &quot;g&quot;).string | { (.): true } ] | add ) as $to_keep_lkup |\r\n   inputs | map(select($to_keep_lkup[.key]))\r\n&#39;\r\n```\r\n\r\nThe former requires jq v1.6, the first version to provide `--rawfile`.\r\n\r\n[jqplay](https://jqplay.org/s/88XwbPkPe4)\r\n\r\n",
                "title": "Is there a way to filter a JSON object using jq to only include those with a key matching a value from a known list?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1628136995,
        "creation_date": 1628041731,
        "last_edit_date": 1628131107,
        "question_id": 68644504,
        "body_markdown": "I have a JSON array, and another text file that contains a list of values.\r\n\r\n```json\r\n[\r\n    {\r\n      &quot;key&quot;: &quot;foo&quot;,\r\n      &quot;detail&quot;: &quot;bar&quot;\r\n    },\r\n    ...\r\n]\r\n```\r\n\r\nI need to filter the array elements to only those that have a &quot;key&quot; value that is found in the list of values.\r\n\r\nThe list of values is a text file containing a single item per-line.\r\n\r\n```\r\nfoo\r\nbaz\r\n```\r\n\r\nIs this possible to do using `jq`?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68644504/is-there-a-way-to-filter-a-json-object-using-jq-to-only-include-those-with-a-key",
        "title": "Is there a way to filter a JSON object using jq to only include those with a key matching a value from a known list?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628064940,
                "post_id": 68647601,
                "comment_id": 121319121,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1628065025,
                "post_id": 68647601,
                "comment_id": 121319158,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1628071307,
                "post_id": 68647601,
                "comment_id": 121321744,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3101154,
                    "reputation": 391,
                    "user_id": 2625247,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3acdb901b9566297ceadd85d10c8b5fb?s=256&d=identicon&r=PG",
                    "display_name": "user2625247",
                    "link": "https://stackoverflow.com/users/2625247/user2625247"
                },
                "reply_to_user": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628141884,
                "post_id": 68647601,
                "comment_id": 121342611,
                "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": 1628141917,
                "post_id": 68647601,
                "comment_id": 121342618,
                "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": 1628142045,
                "post_id": 68647601,
                "comment_id": 121342664,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1628066871,
                "creation_date": 1628066871,
                "answer_id": 68648192,
                "question_id": 68647601,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When you do `export PASSPHRASE=$(cat /home/x/secret)` in the shell, it interpretes the `$()` expression, executes the command within and puts the output of it inside of the variable PASSPHRASE.\r\n\r\nWhen you place `$()` in the json file, however, it is read by jq and treated as a normal string, which is the equivalent of doing `export PASSPHRASE=\\$(cat /home/x/secret)` (notice the slash, which causes the dollar sign to be escaped and treated as a literal character, instead of creating a new shell). If you do that instead and try to echo the contents of the variable it will have similar results as running your script.\r\n\r\nIf you want to force bash to interpret the string as a command you could use `sh -c &lt;command&gt;` instead, for example like this:\r\n\r\ntest.json:\r\n```\r\n{\r\n    &quot;PASSPHRASE&quot;: &quot;cat /home/x/secret&quot;\r\n}\r\n```\r\n\r\ntest.sh:\r\n```\r\nIFS=$&#39;\\n&#39;\r\nfor s in $(echo $values | jq -r &quot;to_entries|map(\\&quot;\\(.value|tostring)\\&quot;)|.[]&quot; $1); do\r\n    echo $(sh -c $s)\r\ndone\r\nunset IFS\r\n```\r\n\r\nThis prints out the contents of /home/x/secret. It does not solve your problem directly but should give you an idea of how you could change your original code to achieve what you need.",
                "title": "Processing command substitutions in strings embedded in a .json file with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1628141639,
                "creation_date": 1628141639,
                "answer_id": 68661082,
                "question_id": 68647601,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks to Maciej I changed the script and got it working:\r\n\r\n    IFS=$&#39;\\n&#39;\r\n    for line in $(jq -r &quot;to_entries|map(\\&quot;\\(.key)=\\(.value|tostring)\\&quot;)|.[]&quot; &quot;$1&quot;); do\r\n        lineExecuted=$(sh -c &quot;echo $line&quot;)\r\n        export &quot;$lineExecuted&quot;\r\n        echo &quot;$lineExecuted&quot;\r\n    done\r\n    unset IFS",
                "title": "Processing command substitutions in strings embedded in a .json file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1628141877,
        "creation_date": 1628064359,
        "last_edit_date": 1628141877,
        "question_id": 68647601,
        "body_markdown": "I want to read environment variables from .json-file:\r\n \r\n\r\n    {\r\n        &quot;PASSPHRASE&quot;: &quot;$(cat /home/x/secret)&quot;,\r\n    }\r\n\r\n\r\nWith the following script:\r\n\r\n    IFS=$&#39;\\n&#39;\r\n    for s in $(echo $values | jq -r &quot;to_entries|map(\\&quot;\\(.key)=\\(.value|tostring)\\&quot;)|.[]&quot; $1); do\r\n        export $s\r\n        echo $s\r\n    done\r\n    unset IFS\r\n\r\nBut the I got `$(cat /home/x/secret)` in `PASSPHRASE`, and `cat` is not executed. When I execute the line `export PASSPHRASE=$(cat /home/x/secret)`, I got the correct result (content of file in environment variable). What do I have to change on my script, to get it working? ",
        "link": "https://stackoverflow.com/questions/68647601/processing-command-substitutions-in-strings-embedded-in-a-json-file-with-jq",
        "title": "Processing command substitutions in strings embedded in a .json file with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1628231066,
                "last_edit_date": 1628231066,
                "creation_date": 1628081390,
                "answer_id": 68651556,
                "question_id": 68649725,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq -r &#39;\r\n  reduce(.audits[] | {generator} * .results[]) as $item ({}; \r\n    (.[$item.generator]?) as $left\r\n    | . * {($item.generator):\r\n             (if ($left | has(&quot;metadata&quot;))\r\n              then $left else $item end) })\r\n  | .[]\r\n  | &quot;\\(.generator),\\(.payload)&quot;&#39;\r\n```\r\nOutput:\r\n```\r\nagentinfo,3p95ouql5QgiZ2M7MBBQH5\r\nlog-audit,dWdVpfCCm44ax4KCyTEmhL\r\nconfig,1gi1QRjxme267adKl7Kqzn\r\n```\r\n\r\nBreaking that down a bit:\r\n- `.audits[] | {generator} * .results[]` produces a flat list of &quot;results&quot; objects that know which generator produced them\r\n- We `reduce` that list with the following logic. Reducing will start with the seed state (an empty object) and evaluate the expression with `.` set to the intermediate state and `$item` to an element of the flattened list. The output of the expression becomes the new intermediate state. At the end, the state is returned to the next step in the pipeline.\r\n  - `(.[$item.generator]?) as $left`: we look up the generator in the intermediate state. If it is not yet there, this expression produces `null`\r\n  - `. * {($item.generator): ...}`: we extend the intermediate state with an entry for `$item.generator`\r\n  - `if ($left | has(&quot;metadata&quot;)) then $left else $item end`: we select the item that has a metadata key and otherwise select the incoming item. If this is the first time we see that key, `$left` is `null` and will not have a metadata key.\r\n- `.[]`: get only the values from the resulting object\r\n- `&quot;\\(.generator),\\(.payload)&quot;`: produce a nice string.",
                "title": "json parsing - Get values only under conditions"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1628230783,
                "creation_date": 1628230783,
                "answer_id": 68677003,
                "question_id": 68649725,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward approach using `group_by`:\r\n```\r\njq -r &#39;\r\n  [ .audits[]\r\n    | .generator as $generator\r\n    | .results\r\n    | (map(select(.payload)) | length) as $npayloads\r\n    | (if $npayloads == 1 then (.[] | select(.payload).payload)\r\n       else first(.[] | select(.metadata).payload)\r\n       end)  as $payload\r\n    | {$generator, $payload} ]\r\n  | group_by(.generator)\r\n  | map(.[0])[]\r\n  | &quot;\\(.generator),\\(.payload)&quot;\r\n&#39;\r\n```\r\nThis produces the desired output, though you might wish to consider using `@csv` to be sure the output is valid as CSV.",
                "title": "json parsing - Get values only under conditions"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1628231066,
        "creation_date": 1628073348,
        "question_id": 68649725,
        "body_markdown": "I&#39;m trying to parse this JSON file to get some specific values. \r\nWhat I want to achieve is to get &quot;generator&quot; and &quot;payload&quot; values. The tricky thing is that some items contain two results and some generators have two items too. In that case, I am only interested on payload value of the one with metadata info.\r\n\r\nDesired output:\r\n```\r\nagentinfo, 3p95ouql5QgiZ2M7MBBQH5\r\nlog-audit, dWdVpfCCm44ax4KCyTEmhL\r\nconfig, 1gi1QRjxme267adKl7Kqzn\r\n```\r\n\r\nI managed to get generator and results with ```jq  &#39;.audits[] | .generator, .results[].payload&#39; manifest.json```, but the output is not exactly what I expect. Also tried ```select``` and ```unique_by``` but I didn&#39;t manage to get what I want.\r\n\r\n```\r\n{\r\n    &quot;type&quot;: &quot;audit_manifest&quot;,\r\n    &quot;version&quot;: &quot;1.0&quot;,\r\n    &quot;audits&quot;: [\r\n\r\n        {\r\n            &quot;id&quot;: &quot;&quot;,\r\n            &quot;generator&quot;: &quot;agentinfo&quot;,\r\n            &quot;generatorVersion&quot;: &quot;1.0.0.0&quot;,\r\n            &quot;results&quot;: [\r\n                {\r\n                    &quot;payload&quot;: &quot;3p95ouql5QgiZ2M7MBBQH5&quot;,\r\n                    &quot;type&quot;: &quot;application/json&quot;\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;&quot;,\r\n            &quot;generator&quot;: &quot;log-audit&quot;,\r\n            &quot;generatorVersion&quot;: &quot;1.0.0.0&quot;,\r\n            &quot;results&quot;: [\r\n                {\r\n                    &quot;payload&quot;: &quot;m3q1IVhgNk59VySdnvEXgk&quot;,\r\n                    &quot;type&quot;: &quot;application/json&quot;\r\n                },\r\n                {\r\n                    &quot;payload&quot;: &quot;dWdVpfCCm44ax4KCyTEmhL&quot;,\r\n                    &quot;type&quot;: &quot;application/octet-stream&quot;,\r\n                    &quot;metadata&quot;: [\r\n                        {\r\n                            &quot;name&quot;: &quot;name&quot;,\r\n                            &quot;value&quot;: &quot;agent.log&quot;\r\n                        }\r\n                    ]\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;&quot;,\r\n            &quot;generator&quot;: &quot;log-audit&quot;,\r\n            &quot;generatorVersion&quot;: &quot;1.0.0.0&quot;,\r\n            &quot;results&quot;: [\r\n                {\r\n                    &quot;payload&quot;: &quot;80iINCJwFFjcLp3BUf9Tec&quot;,\r\n                    &quot;type&quot;: &quot;application/json&quot;\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;&quot;,\r\n            &quot;generator&quot;: &quot;config&quot;,\r\n            &quot;generatorVersion&quot;: &quot;1.0.0.0&quot;,\r\n            &quot;results&quot;: [\r\n                {\r\n                    &quot;payload&quot;: &quot;hRUiHto5JpcjnbD3tJQMx1&quot;,\r\n                    &quot;type&quot;: &quot;application/json&quot;\r\n                },\r\n                {\r\n                    &quot;payload&quot;: &quot;1gi1QRjxme267adKl7Kqzn&quot;,\r\n                    &quot;type&quot;: &quot;application/octet-stream&quot;,\r\n                    &quot;metadata&quot;: [\r\n                        {\r\n                            &quot;name&quot;: &quot;name&quot;,\r\n                            &quot;value&quot;: &quot;config.json&quot;\r\n                        }\r\n                    ]\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;&quot;,\r\n            &quot;generator&quot;: &quot;config&quot;,\r\n            &quot;generatorVersion&quot;: &quot;1.0.0.0&quot;,\r\n            &quot;results&quot;: [\r\n                {\r\n                    &quot;payload&quot;: &quot;SGf26By1b174bCLD0YYx01&quot;,\r\n                    &quot;type&quot;: &quot;application/json&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nAs always, thanks for any advice!\r\n",
        "link": "https://stackoverflow.com/questions/68649725/json-parsing-get-values-only-under-conditions",
        "title": "json parsing - Get values only under conditions"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1628085273,
                "last_edit_date": 1628085273,
                "creation_date": 1628084937,
                "answer_id": 68652443,
                "question_id": 68652292,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It seems like you&#39;re first trying to get all the `keys`, then loop over then to show the `key` with the relevant `value`.\r\n\r\n\r\n----------\r\n\r\n\r\nWe can simplify this using just [tag:JQ] like so:\r\n```\r\nto_entries[] | &quot;\\(.key): \\(.value.value)&quot;\r\n```\r\n\r\nThis will produce the following output:\r\n```json\r\nmy_db_instance_class: db.t3.medium\r\nmy_db_instance_test: db.t4.medium\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\n##### [JqPlay Demo](https://jqplay.org/s/Y8ZG-bxNBO)\r\n\r\n\r\n----------\r\n\r\n* `to_entires` [documentation](https://stedolan.github.io/jq/manual/#example27)\r\n* String interpolation (`\\()`) [documentation](https://stedolan.github.io/jq/manual/#example69)",
                "title": "Not able to get value from json using jq when I replace one of the elements with variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1628085273,
        "creation_date": 1628084337,
        "last_edit_date": 1628085079,
        "question_id": 68652292,
        "body_markdown": "Using jq if I try to get the value of an element using string I am able to get the value. But to make it flexible if I replace it with a variable then it throws error.\r\n\r\n    data=$(cat &lt;&lt;EOF\r\n    {\r\n        &quot;my_db_instance_class&quot;: {\r\n          &quot;sensitive&quot;: false,\r\n          &quot;type&quot;: &quot;string&quot;,\r\n          &quot;value&quot;: &quot;db.t3.medium&quot;\r\n        },\r\n        &quot;my_db_instance_test&quot;: {\r\n          &quot;sensitive&quot;: false,\r\n          &quot;type&quot;: &quot;string&quot;,\r\n          &quot;value&quot;: &quot;db.t4.medium&quot;\r\n        }\r\n    }\r\n    EOF\r\n    )\r\n    \r\n    #echo $data\r\n    keys=$(echo $data | jq -r &#39;. |=keys&#39; | jq &#39;.[]&#39;)\r\n    \r\n    #echo $keys\r\n    \r\n    for key in $keys\r\n    do\r\n      value=$(echo $data | jq --arg k &quot;$key&quot; &#39;.my_db_instance_class.value&#39;)\r\n      final_value=&quot;${final_value}${key}: ${value}&quot;\r\n    done\r\n\r\nThe above code works but it not very static. Below I have replaced my_db_instance_class with a variable \r\n\r\n    for key in $keys\r\n    do\r\n      value=$(echo $data | jq --arg k &quot;$key&quot; &#39;.$k.value&#39;)\r\n      final_value=&quot;${final_value}${key}: ${value}&quot;\r\n    done\r\n\r\nError message\r\n\r\n    jq: error: syntax error, unexpected &#39;$&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .$k.value \r\n    jq: error: try .[&quot;field&quot;] instead of .field for unusually named fields at &lt;top-level&gt;, line 1:\r\n    .$k.value\r\n    jq: 2 compile errors\r\n    jq: error: syntax error, unexpected &#39;$&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .$k.value \r\n    jq: error: try .[&quot;field&quot;] instead of .field for unusually named fields at &lt;top-level&gt;, line 1:\r\n    .$k.value\r\n    jq: 2 compile errors\r\n\r\nExpected final output of the whole script\r\n\r\n&gt; &quot;my_db_instance_class&quot;: &quot;db.t3.medium&quot;&quot;my_db_instance_test&quot;:\r\n&gt; &quot;db.t3.medium&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68652292/not-able-to-get-value-from-json-using-jq-when-i-replace-one-of-the-elements-with",
        "title": "Not able to get value from json using jq when I replace one of the elements with variable"
    },
    {
        "tags": [
            "jq",
            "iso8601",
            "timestamp-with-timezone",
            "localtime"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628141471,
                "post_id": 68660343,
                "comment_id": 121342509,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628147195,
                "post_id": 68660343,
                "comment_id": 121344160,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1628196599,
                "last_edit_date": 1628196599,
                "creation_date": 1628196065,
                "answer_id": 68673260,
                "question_id": 68660343,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The first problem here is that jq&#39;s handling of timezones (TZ) is buggy; the second is that jq&#39;s built-ins do not recognize timezone offsets.\r\n\r\nUnfortunately, there is to my knowledge not much that can easily be\r\ndone about jq&#39;s TZ-related bugginess other than using `gojq`, the Go\r\nimplementation of jq, instead.\r\n\r\nFortunately, time offsets can be handled quite easily, e.g. using the `datetime_to_seconds` filter as defined below.\r\n\r\nSo, for the time being, the following solution to the stated problem assumes the use of `gojq` rather than stedolan/jq. It has two main steps:\r\n1. Use the generic filter `datetime_to_seconds` to convert the timestamp with an offset to &quot;seconds since the epoch&quot;;\r\n2. Use `strflocaltime`, which recognizes the environment variable TZ.\r\n\r\nThe solution is embedded in a bash script to facilitate a comparison between different versions of jq and gojq.\r\n\r\n### bash script\r\n```\r\n#!/bin/bash\r\n\r\n# Syntax: go TZ\r\n\r\nfunction go {\r\n\r\nTZ=&quot;$1&quot; $jq -Rr &#39;\r\n\r\n# Convert a timestamp with a possibly empty timezone offset to seconds since the Epoch.\r\n# Input should be a string of the form yyyy-mm-ddThh:mm:ss or yyyy-mm-ddThh:mm:ss&lt;OFFSET&gt;\r\n# where &lt;OFFSET&gt; is Z, or has the form [-+]hh:mm or [-+]hhmm \r\n# If no timezone offset is explicitly given, it is taken to be Z.\r\ndef datetime_to_seconds: \r\n  if test(&quot;[-+]&quot;)\r\n  then\r\n    sub(&quot;(?&lt;s&gt;[-+])(?&lt;d1&gt;[0-9]{2})(?&lt;d2&gt;[0-9]{2})$&quot;; &quot;\\(.s)\\(.d1):\\(.d2)&quot;)\r\n    | capture(&quot;(?&lt;datetime&gt;^.*T[0-9:]+)(?&lt;s&gt;[-+])(?&lt;hh&gt;[0-9]+):?(?&lt;mm&gt;[0-9]*)&quot;)\r\n    | (.datetime +&quot;Z&quot; | fromdateiso8601) as $seconds\r\n    | (if .s == &quot;+&quot; then -1 else 1 end) as $plusminus\r\n    | (.mm | if . == &quot;&quot; then 0 else . end) as $mm\r\n    | ([.hh,$mm] | map(tonumber) |.[0] *= 60 | add * 60 * $plusminus) as $offset\r\n    | ($seconds + $offset)\r\n  else . + (if test(&quot;Z&quot;) then &quot;&quot; else &quot;Z&quot; end) | fromdateiso8601\r\n       end;\r\n\r\ndatetime_to_seconds\r\n| strflocaltime(&quot;%Y-%m-%dT%H:%M:%S %Z&quot;)\r\n&#39;\r\n}\r\n\r\nfor jq in jq-1.6 jqMaster gojq ; do\r\n    echo $jq is $($jq --version)\r\ndone\r\necho\r\n\r\nfor TZ in America/New_York  Europe/Madrid  ;do\r\n    for jq in jq-1.6 jqMaster gojq  ; do\r\n\tfor time in 2021-08-04T22:55:12+0000 ; do\r\n\t    echo $jq $TZ $time\r\n\t    echo $time | go $TZ\r\n\t    echo\r\n\t done\r\n    done\r\ndone\r\n```\r\n### Output\r\n\r\nHere is the output with some &quot;#&quot; annotations.\r\n```\r\njq-1.6 is jq-master-2e01ff1\r\njqMaster is jq-1.6-129-g80052e5-dirty\r\ngojq is gojq 0.12.4 (rev: 244f9f7/go1.16.4)\r\n\r\njq-1.6 America/New_York 2021-08-04T22:55:12+0000\r\n2021-08-04T19:55:12 EST # wrong\r\n\r\njqMaster America/New_York 2021-08-04T22:55:12+0000\r\n2021-08-04T18:55:12 EST # wrong\r\n\r\ngojq America/New_York 2021-08-04T22:55:12+0000\r\n2021-08-04T18:55:12 EDT # correct\r\n\r\njq-1.6 Europe/Madrid 2021-08-04T22:55:12+0000\r\n2021-08-05T01:55:12 CET # wrong\r\n\r\njqMaster Europe/Madrid 2021-08-04T22:55:12+0000\r\n2021-08-05T00:55:12 CET # wrong\r\n\r\ngojq Europe/Madrid 2021-08-04T22:55:12+0000\r\n2021-08-05T00:55:12 CEST # correct\r\n```\r\n\r\n",
                "title": "How to convert datestring to local time?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1628220658,
        "creation_date": 1628134957,
        "last_edit_date": 1628220658,
        "question_id": 68660343,
        "body_markdown": "`2021-08-04T22:55:12+0000`\r\n\r\nI want to convert the above string to local time.\r\n\r\nBut fromdateiso8601 does not work on this format. What is the best way to convert this kind of string to local time?\r\n\r\nEDIT: I tried the following but the part of `23:55:12` does not change when the timezone is changed. I&#39;d expect that this should be changed as TZ is changed.\r\n\r\n```\r\n$ TZ=America/New_York jq &#39;.x | gsub(&quot;[+]0000&quot;; &quot;Z&quot;) | fromdateiso8601| gmtime | strftime(&quot;%Y-%m-%dT%H:%M:%S%Z&quot;)&#39; &lt;&lt;&lt; &#39;{&quot;x&quot;: &quot;2021-08-04T22:55:12+0000&quot; }&#39;\r\n&quot;2021-08-04T23:55:12EST&quot;\r\n$ TZ=Europe/Madrid jq &#39;.x | gsub(&quot;[+]0000&quot;; &quot;Z&quot;) | fromdateiso8601| gmtime | strftime(&quot;%Y-%m-%dT%H:%M:%S%Z&quot;)&#39; &lt;&lt;&lt; &#39;{&quot;x&quot;: &quot;2021-08-04T22:55:12+0000&quot; }&#39;\r\n&quot;2021-08-04T23:55:12CET&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/68660343/how-to-convert-datestring-to-local-time",
        "title": "How to convert datestring to local time?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "environment-variables",
            "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": 1628159007,
                "post_id": 68664722,
                "comment_id": 121348702,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6378595,
                    "reputation": 2138,
                    "user_id": 4948798,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/22d4136f53e83a7f48424ac3354def47?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user4948798",
                    "link": "https://stackoverflow.com/users/4948798/user4948798"
                },
                "reply_to_user": {
                    "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": 1628159340,
                "post_id": 68664722,
                "comment_id": 121348818,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1628159466,
                "post_id": 68664722,
                "comment_id": 121348867,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6378595,
                    "reputation": 2138,
                    "user_id": 4948798,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/22d4136f53e83a7f48424ac3354def47?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user4948798",
                    "link": "https://stackoverflow.com/users/4948798/user4948798"
                },
                "reply_to_user": {
                    "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": 1628165344,
                "post_id": 68664722,
                "comment_id": 121351139,
                "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": 1628173992,
                "post_id": 68664722,
                "comment_id": 121355177,
                "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": 1628174058,
                "post_id": 68664722,
                "comment_id": 121355216,
                "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": 1628174257,
                "post_id": 68664722,
                "comment_id": 121355315,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1628176588,
                "creation_date": 1628176588,
                "answer_id": 68669296,
                "question_id": 68664722,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By using --arg with jq you can pass paremeter and use as a variables \r\n   ( more info https://stedolan.github.io/jq/manual/v1.5/#Invokingjq ) \r\n\r\nby using `map` and `+`  you can iterate over the array and add a new property for each associative  array \r\n\r\nin you case :\r\n\r\n    curl --user $USERID:$PASSWORD http://198.98.99.12:46567/$PORT/protects/$u  \\\r\n       | jq --arg a_port $PORT  --arg $u  $USER &#39;map(.+{&quot;userid&quot;:$a_userid}+{&quot;port&quot;:$a_port|tonumber})&#39;  &gt; m4-$u.json\r\n\r\nsee `addition` and `map`  in \r\nhttps://stedolan.github.io/jq/manual/v1.5/#Builtinoperatorsandfunctions",
                "title": "Shell variables as additional fields in json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1628241865,
        "creation_date": 1628158618,
        "last_edit_date": 1628241865,
        "question_id": 68664722,
        "body_markdown": "I&#39;m able to retrieve each user&#39;s data into `m4-$u.json` file with the below shell script \r\n\r\n```\r\n#!/bin/bash\r\n\r\nUSERID=ricardo.sanchez\r\nPASSWORD=password\r\nPORT=2728\r\n\r\nfor u in `cat user-list.txt`;\r\n   do echo $u; \r\n   curl --user $USERID:$PASSWORD http://198.98.99.12:46567/$PORT/protects/$u | jq &#39;.&#39; &gt; m4-$u.json\r\ndone\r\n```\r\nOne for the user&#39;s output of `m4-daniel.json` file few lines as follows.\r\n\r\n```\r\n[\r\n  {\r\n    &quot;depotFile&quot;: &quot;//ABND/JJEB/...&quot;,\r\n    &quot;host&quot;: &quot;*&quot;,\r\n    &quot;isgroup&quot;: &quot;&quot;,\r\n    &quot;line&quot;: &quot;16&quot;,\r\n    &quot;perm&quot;: &quot;open&quot;,\r\n    &quot;user&quot;: &quot;5G_USER_GROUP&quot;\r\n  },\r\n  {\r\n    &quot;depotFile&quot;: &quot;//LIB/...&quot;,\r\n    &quot;host&quot;: &quot;*&quot;,\r\n    &quot;isgroup&quot;: &quot;&quot;,\r\n    &quot;line&quot;: &quot;19&quot;,\r\n    &quot;perm&quot;: &quot;write&quot;,\r\n    &quot;user&quot;: &quot;6G_USER_GROUP&quot;\r\n  },\r\n  {\r\n    &quot;depotFile&quot;: &quot;//AND/RIO/...&quot;,\r\n    &quot;host&quot;: &quot;*&quot;,\r\n    &quot;isgroup&quot;: &quot;&quot;,\r\n    &quot;line&quot;: &quot;20&quot;,\r\n    &quot;perm&quot;: &quot;write&quot;,\r\n    &quot;user&quot;: &quot;AND_USER_GROUP&quot;\r\n  },\r\n```\r\nDuring shell script run time additionally `$PORT` &amp; `$u` variable values need to be added in output of each `json` file. \r\n\r\n**Expected json output:-**\r\n```\r\n  {\r\n    &quot;depotFile&quot;: &quot;//ABND/JJEB/...&quot;,\r\n    &quot;host&quot;: &quot;*&quot;,\r\n    &quot;isgroup&quot;: &quot;&quot;,\r\n    &quot;line&quot;: &quot;16&quot;,\r\n    &quot;perm&quot;: &quot;open&quot;,\r\n    &quot;user&quot;: &quot;5G_USER_GROUP&quot;,\r\n    &quot;port&quot;: &quot;2728&quot;,\r\n    &quot;userid&quot;: &quot;daniel&quot;\r\n  },\r\n```\r\nTo achieve this any help will be appreciated.",
        "link": "https://stackoverflow.com/questions/68664722/shell-variables-as-additional-fields-in-json",
        "title": "Shell variables as additional fields in json"
    },
    {
        "tags": [
            "json",
            "yaml",
            "jq",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1628204055,
                "last_edit_date": 1628204055,
                "creation_date": 1628202947,
                "answer_id": 68674206,
                "question_id": 68674042,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The piece you are missing is `from_entries` which can build a JSON object from an array of keys and values.\r\n\r\nInstead of:\r\n\r\n```\r\njq &#39;. | group_by(.externalGroup)[] | {(.[0].externalGroup): map(.groupId)}&#39;\r\n```\r\n\r\nTry:\r\n\r\n```\r\njq &#39;group_by(.externalGroup) | map({key:.[0].externalGroup, value:map(.groupId)}) | from_entries&#39;\r\n```\r\n\r\n```\r\n{\r\n  &quot;another group admins&quot;: [\r\n    &quot;da2e42c8-6423-4d32-99b5-5fc58f9f80b8&quot;\r\n  ],\r\n  &quot;another group users&quot;: [\r\n    &quot;7c69cac1-4a70-4170-8251-cde3762fe498&quot;\r\n  ],\r\n  &quot;my group admin&quot;: [\r\n    &quot;e08a1d9d-f108-4e87-bdb3-ee4f10c6752a&quot;\r\n  ],\r\n  &quot;my group users&quot;: [\r\n    &quot;8370821e-edfa-4615-ac2e-47815b740f40&quot;\r\n  ],\r\n  &quot;some group&quot;: [\r\n    &quot;e08a1d9d-f108-4e87-bdb3-ee4f10c6752a&quot;,\r\n    &quot;8370821e-edfa-4615-ac2e-47815b740f40&quot;,\r\n    &quot;7c69cac1-4a70-4170-8251-cde3762fe498&quot;\r\n  ]\r\n}\r\n```\r\n\r\nI made the following changes:\r\n\r\n* Removed the `. |` at the beginning because it doesn&#39;t change anything.\r\n* Removed the `[]` and used `map(...)` instead, because we want to keep things in an array to feed to `from_entries`.\r\n* Instead of assembling a one-entry object, we create `{key:..., value:...}` pairs to feed to `from_entries`.\r\n\r\n---\r\n\r\nActually, I just checked and was slightly surprised to discover that `add` is actually a bit faster than `from_entries` even for very long lists. If you use `add` you need to change even less of your solution.\r\n\r\n```\r\njq &#39;group_by(.externalGroup) | map({(.[0].externalGroup):map(.groupId)}) | add&#39;\r\n```\r\n\r\nAdding together objects combines their contents together. I tested with  a 250,000 element list and it was slightly faster than `from_entries`. Given that it&#39;s also shorter and in my opinion pretty much just as clear, I think it&#39;s worthy of consideration.",
                "title": "how to group json using jq and then convert to yaml"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1628216283,
                "creation_date": 1628216283,
                "answer_id": 68675348,
                "question_id": 68674042,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. An alternative worth considering for producing yaml is `gojq`, the Go implementation of jq, e.g.\r\n```\r\n   gojq --yaml-output &#39;\r\n     group_by(.externalGroup) \r\n    | map({(.[0].externalGroup):map(.groupId)}) | add&#39;\r\n```\r\n2. To avoid the overhead of `map`, you could use the following generic stream-oriented `add` that works for objects or arrays just as well as for numbers:\r\n```\r\n    gojq --yaml-output &#39;\r\n      def add(s): reduce s as $x (null; . + $x);\r\n      add( group_by(.externalGroup)[] \r\n           | {(.[0].externalGroup):map(.groupId)})&#39;\r\n```",
                "title": "how to group json using jq and then convert to yaml"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1628216283,
        "creation_date": 1628201434,
        "question_id": 68674042,
        "body_markdown": "I have this json that i want to convert.\r\n```json\r\n[\r\n  {\r\n    &quot;externalGroup&quot;: &quot;another group admins&quot;,\r\n    &quot;groupId&quot;: &quot;da2e42c8-6423-4d32-99b5-5fc58f9f80b8&quot;\r\n  },\r\n  {\r\n    &quot;externalGroup&quot;: &quot;another group users&quot;,\r\n    &quot;groupId&quot;: &quot;7c69cac1-4a70-4170-8251-cde3762fe498&quot;\r\n  },\r\n  {\r\n    &quot;externalGroup&quot;: &quot;my group admin&quot;,\r\n    &quot;groupId&quot;: &quot;e08a1d9d-f108-4e87-bdb3-ee4f10c6752a&quot;\r\n  },\r\n  {\r\n    &quot;externalGroup&quot;: &quot;my group users&quot;,\r\n    &quot;groupId&quot;: &quot;8370821e-edfa-4615-ac2e-47815b740f40&quot;\r\n  },\r\n  {\r\n    &quot;externalGroup&quot;: &quot;some group&quot;,\r\n    &quot;groupId&quot;: &quot;e08a1d9d-f108-4e87-bdb3-ee4f10c6752a&quot;\r\n  },\r\n  {\r\n    &quot;externalGroup&quot;: &quot;some group&quot;,\r\n    &quot;groupId&quot;: &quot;8370821e-edfa-4615-ac2e-47815b740f40&quot;\r\n  },\r\n  {\r\n    &quot;externalGroup&quot;: &quot;some group&quot;,\r\n    &quot;groupId&quot;: &quot;7c69cac1-4a70-4170-8251-cde3762fe498&quot;\r\n  }\r\n]\r\n```\r\n\r\nI have tried this, which is pretty close:\r\n`jq &#39;. | group_by(.externalGroup)[] | {(.[0].externalGroup): map(.groupId)}&#39;`\r\n\r\nI get this:\r\n```json\r\n{\r\n  &quot;another group admins&quot;: [\r\n    &quot;da2e42c8-6423-4d32-99b5-5fc58f9f80b8&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;another group users&quot;: [\r\n    &quot;7c69cac1-4a70-4170-8251-cde3762fe498&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;my group admin&quot;: [\r\n    &quot;e08a1d9d-f108-4e87-bdb3-ee4f10c6752a&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;my group users&quot;: [\r\n    &quot;8370821e-edfa-4615-ac2e-47815b740f40&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;some group&quot;: [\r\n    &quot;e08a1d9d-f108-4e87-bdb3-ee4f10c6752a&quot;,\r\n    &quot;8370821e-edfa-4615-ac2e-47815b740f40&quot;,\r\n    &quot;7c69cac1-4a70-4170-8251-cde3762fe498&quot;\r\n  ]\r\n}\r\n```\r\n\r\nBut this doesn&#39;t convert properly with yq. It would need to look something like this instead:\r\n```json\r\n{\r\n  &quot;another group admins&quot;: [\r\n    &quot;da2e42c8-6423-4d32-99b5-5fc58f9f80b8&quot;\r\n  ],\r\n  &quot;another group users&quot;: [\r\n    &quot;7c69cac1-4a70-4170-8251-cde3762fe498&quot;\r\n  ],\r\n  &quot;my group admin&quot;: [\r\n    &quot;e08a1d9d-f108-4e87-bdb3-ee4f10c6752a&quot;\r\n  ],\r\n  &quot;my group users&quot;: [\r\n    &quot;8370821e-edfa-4615-ac2e-47815b740f40&quot;\r\n  ],\r\n  &quot;some group&quot;: [\r\n    &quot;e08a1d9d-f108-4e87-bdb3-ee4f10c6752a&quot;,\r\n    &quot;8370821e-edfa-4615-ac2e-47815b740f40&quot;,\r\n    &quot;7c69cac1-4a70-4170-8251-cde3762fe498&quot;\r\n  ]\r\n}\r\n```\r\n\r\nIn order to get something like:\r\n\r\n```yaml\r\n&quot;another group admins&quot;:\r\n  - &quot;da2e42c8-6423-4d32-99b5-5fc58f9f80b8&quot;\r\n&quot;another group users&quot;:\r\n  - &quot;7c69cac1-4a70-4170-8251-cde3762fe498&quot;\r\n&quot;my group admin&quot;:\r\n  - &quot;e08a1d9d-f108-4e87-bdb3-ee4f10c6752a&quot;\r\n&quot;my group users&quot;:\r\n  - &quot;8370821e-edfa-4615-ac2e-47815b740f40&quot;\r\n&quot;some group&quot;:\r\n  - &quot;e08a1d9d-f108-4e87-bdb3-ee4f10c6752a&quot;,\r\n  - &quot;8370821e-edfa-4615-ac2e-47815b740f40&quot;,\r\n  - &quot;7c69cac1-4a70-4170-8251-cde3762fe498&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/68674042/how-to-group-json-using-jq-and-then-convert-to-yaml",
        "title": "how to group json using jq and then convert to yaml"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1628247606,
                "creation_date": 1628247606,
                "answer_id": 68680497,
                "question_id": 68680455,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use string interpolation (`\\()`) &lt;sup&gt;[docs](https://stedolan.github.io/jq/manual/#example69)&lt;/sup&gt; to concat that variable to the rest like so:\r\n```none\r\n&#39;.&quot;kubernetes.io/cluster/\\($clusterName)&quot; == &quot;owned&quot;&#39;\r\n```\r\n```\r\necho $TAGS | jq --arg clusterName $CLUSTER_NAME &#39;.&quot;kubernetes.io/cluster/\\($clusterName)&quot; == &quot;owned&quot;&#39;\r\n```\r\n\r\nShows `true` when testing with the supplied variables.\r\n\r\n\r\n----------\r\n\r\nThat said, I&#39;d recommend using here-string (`&lt;&lt;&lt;`) instead off `echo |` like so:\r\n```bash\r\n$ TAGS=&#39;{&quot;kubernetes.io/cluster/my-cluster&quot;:&quot;owned&quot;}&#39;\r\n$ CLUSTER_NAME=&quot;my-cluster&quot;\r\n$\r\n$ jq --arg clusterName $CLUSTER_NAME &#39;.&quot;kubernetes.io/cluster/\\($clusterName)&quot; == &quot;owned&quot;&#39; &lt;&lt;&lt; &quot;$TAGS&quot;\r\ntrue\r\n$\r\n```\r\n&lt;sup&gt;&lt;https://stackoverflow.com/questions/47105490/can-i-pass-a-string-variable-to-jq-not-the-file&gt;&lt;/sup&gt;",
                "title": "JQ filter returns &#39;false&#39; when key is not hardcoded"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1628252034,
        "creation_date": 1628247469,
        "last_edit_date": 1628252034,
        "question_id": 68680455,
        "body_markdown": "When using JQ to test the value of a key, the filter is unexpectantly returning `false` when it expected to instead return `true`.\r\n\r\nAssume the following variables -\r\n\r\n    TAGS=&#39;{&quot;kubernetes.io/cluster/my-cluster&quot;:&quot;owned&quot;}\r\n    CLUSTER_NAME=&quot;my-cluster&quot;\r\n\r\nWhen testing `$TAGS` using a hardcoded value the filter returns `true`, as expected.\r\n\r\n    echo $TAGS | jq &#39;.&quot;kubernetes.io/cluster/my-cluster&quot; == &quot;owned&quot;&#39;\r\n\r\nHowever, after introducing `clusterName` as a JQ argument, the filter now returns `false`.\r\n\r\n    echo $TAGS | jq --arg clusterName $CLUSTER_NAME &#39;.&quot;kubernetes.io/cluster/&quot; + $clusterName == &quot;owned&quot;&#39;\r\n\r\nI first wondered if the `-` in the `$CLUSTER_NAME` was the issue, but removing that (and updating `$TAGS` to match) yields the same result.\r\n\r\nI&#39;ve tried the following in the filter, all of which also yield the same result.\r\n\r\n    .&quot;kubernetes.io/cluster/&quot; + &quot;$clusterName&quot;\r\n    .&quot;kubernetes.io/cluster/ + $clusterName&quot;\r\n    .&quot;kubernetes.io/cluster/$clusterName&quot;\r\n\r\nHow can the filter be amended to work as expected?",
        "link": "https://stackoverflow.com/questions/68680455/jq-filter-returns-false-when-key-is-not-hardcoded",
        "title": "JQ filter returns &#39;false&#39; when key is not hardcoded"
    },
    {
        "tags": [
            "arrays",
            "json",
            "filter",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1628604632,
                "last_edit_date": 1628604632,
                "creation_date": 1628254557,
                "answer_id": 68681933,
                "question_id": 68681462,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try using `first(&lt;expression&gt;)` to get only the first matching value. In case there are no matching values at all, you can use `first(&lt;expression&gt;, &lt;default_value&gt;)`.\r\n\r\n```\r\njq -r &#39;.[] | .tags[].key |= ascii_downcase | .env = first((.tags[] | select(.key == &quot;env&quot;).values[0]),null)|[.accountid,.name,.env] | @csv&#39; test.json\r\n```\r\n\r\nAlternatively, if you are going to want to extract other tags similarly, you might prefer to extract them all into one object like this. I&#39;m using `reverse` to meet your requirement of keeping the first match for any given key, otherwise the last match would win.\r\n\r\n```\r\njq -r &#39;.[] | .tags |= ( map({(.key|ascii_downcase): .values[0]}) | reverse | add ) | [.accountid, .name, .tags.env] | @csv&#39;\r\n```\r\n",
                "title": "How to use JQ to copy a single value from a nested array which has duplicate keys"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1628604632,
        "creation_date": 1628252302,
        "question_id": 68681462,
        "body_markdown": "I have an array of json objects, each with an array of tags.  Specific tags can appear multiple times in the child array but I only want the first matching tag (key+value) copied up onto the parent object.  I&#39;ve come up with a filter-set but it gives me multiple outputs if the given tag appears more than once in the child array ... I only want the first one.\r\n\r\n**Sample Json Input:**   \r\n```\r\n[  \r\n  {  \r\n    &quot;name&quot;:&quot;integration1&quot;,  \r\n    &quot;accountid&quot;:111,  \r\n    &quot;tags&quot;:[  \r\n      { &quot;key&quot;: &quot;env&quot;,  \r\n        &quot;values&quot;:[&quot;prod&quot;]  \r\n      },  \r\n      { &quot;key&quot;: &quot;team&quot;,  \r\n        &quot;values&quot;:[&quot;cougar&quot;]  \r\n      }  \r\n    ]  \r\n  },  \r\n  {  \r\n    &quot;name&quot;:&quot;integration2&quot;,  \r\n    &quot;accountid&quot;:222,  \r\n    &quot;tags&quot;:[  \r\n      { &quot;key&quot;: &quot;env&quot;,  \r\n        &quot;values&quot;:[&quot;prod&quot;]  \r\n      },  \r\n      { &quot;key&quot;: &quot;team&quot;,  \r\n        &quot;values&quot;:[&quot;bear&quot;]  \r\n      }  \r\n    ]  \r\n  },  \r\n  {  \r\n    &quot;name&quot;:&quot;integration3&quot;,  \r\n    &quot;accountid&quot;:333,  \r\n    &quot;tags&quot;:[  \r\n      { &quot;key&quot;: &quot;env&quot;,  \r\n        &quot;values&quot;:[&quot;test&quot;]  \r\n      },  \r\n      { &quot;key&quot;: &quot;team&quot;,  \r\n        &quot;values&quot;:[&quot;lemur&quot;]  \r\n      },  \r\n      { &quot;key&quot;: &quot;Env&quot;,  \r\n        &quot;values&quot;:[&quot;qa&quot;]  \r\n      }  \r\n    ]  \r\n  }  \r\n]  \r\n```\r\n\r\n**Filter-set that I came up with:**  \r\n```\r\njq -r &#39;.[] | .tags[].key |= ascii_downcase | .env = (.tags[] | select(.key == &quot;env&quot;).values[0])|[.accountid,.name,.env] | @csv&#39; test.json\r\n```\r\n\r\n**Example output with undesirable extra line:**  \r\n```\r\n111,&quot;integration1&quot;,&quot;prod&quot;  \r\n222,&quot;integration2&quot;,&quot;prod&quot;  \r\n333,&quot;integration3&quot;,&quot;test&quot;  \r\n333,&quot;integration3&quot;,&quot;qa&quot;  &lt;&lt;&lt;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/68681462/how-to-use-jq-to-copy-a-single-value-from-a-nested-array-which-has-duplicate-key",
        "title": "How to use JQ to copy a single value from a nested array which has duplicate keys"
    },
    {
        "tags": [
            "json",
            "yaml",
            "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": 1628296225,
                "post_id": 68684609,
                "comment_id": 121390446,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9589062,
                    "reputation": 2764,
                    "user_id": 7120667,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/0UC4R.jpg?s=256",
                    "display_name": "Rushabh Patel",
                    "link": "https://stackoverflow.com/users/7120667/rushabh-patel"
                },
                "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": 1628515701,
                "post_id": 68684609,
                "comment_id": 121434271,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1628272621,
                "creation_date": 1628272621,
                "answer_id": 68685779,
                "question_id": 68684609,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Iterate over keys of the first object and check whether they exist in the second and have the same value in both objects. Delete those that do, and leave the rest intact.\r\n``` none\r\ninputs as $a\r\n| reduce keys_unsorted[] as $k (.;\r\n  if ($k | in($a)) and (.[$k] == $a[$k]) then del(.[$k]) else . end\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/N7YaZuWIAZ)&lt;/sup&gt;",
                "title": "Comparing two JSON files using jq and keeping the key-value pair from the first file on matching key"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1628532424,
                "last_edit_date": 1628532424,
                "creation_date": 1628296111,
                "answer_id": 68688564,
                "question_id": 68684609,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is just a variant of @oguzismail&#39;s perfectly fine answer. Besides using `reduce` constructively rather than using `del`, it is to my eye at least a bit more readable, e.g. with respect to the respective roles of the two files:\r\n\r\n```\r\njq -n &#39;\r\n  input as $f1 | input as $f2\r\n  | reduce ($f1|keys_unsorted[]) as $k ({};\r\n      if $f2 | has($k) and $f1[$k] != $f2[$k] then .[$k]=$f1[$k] else . end)\r\n&#39; file1.json file2.json\r\n```",
                "title": "Comparing two JSON files using jq and keeping the key-value pair from the first file on matching key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1628532424,
        "creation_date": 1628266074,
        "question_id": 68684609,
        "body_markdown": "I have these two `json` files and I am trying to find the elements with same `keys` but different `values` using `jq`. Please see expected output for more clarity.\r\n\r\n**JSON File 1:**   \r\n\r\n    {\r\n      &quot;COMMON-VAR&quot;: &quot;ABC&quot;,\r\n      &quot;LASTNAME&quot;: &quot;D&quot;,\r\n      &quot;FIRSTNAME&quot;: &quot;JOHN&quot;\r\n    }\r\n\r\n**JSON File 2:**   \r\n\r\n    {\r\n      &quot;COMMON-VAR&quot;: &quot;DEF&quot;,\r\n      &quot;LASTNAME&quot;: &quot;S&quot;,\r\n      &quot;FIRSTNAME&quot;: &quot;JOHN&quot;,\r\n      &quot;ADDRESS&quot;: &quot;SanJose, CA&quot;,\r\n      &quot;ZIP&quot;: &quot;09817&quot;\r\n    }\r\n\r\n**Expected output:**\r\n\r\n    {\r\n      &quot;COMMON-VAR&quot;: &quot;ABC&quot;,\r\n      &quot;LASTNAME&quot;: &quot;D&quot;,\r\n    }\r\n\r\nAny help/suggestions will be greatly appreciated.\r\n",
        "link": "https://stackoverflow.com/questions/68684609/comparing-two-json-files-using-jq-and-keeping-the-key-value-pair-from-the-first",
        "title": "Comparing two JSON files using jq and keeping the key-value pair from the first file on matching key"
    },
    {
        "tags": [
            "json",
            "path",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1628270344,
                "last_edit_date": 1628270344,
                "creation_date": 1628268933,
                "answer_id": 68685135,
                "question_id": 68684696,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to convert each `.path` to a form [`setpath`](https://stedolan.github.io/jq/manual/v1.6/#setpath(PATHS;VALUE)) can understand. The rest is straightforward.\r\n``` none\r\nreduce .[] as {$path, $value} (null;\r\n  setpath($path / &quot;/&quot; | map(tonumber? // .); $value)\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/lhJF0tenpE)&lt;/sup&gt;",
                "title": "How to convert array of object into expected json key value object based on the path value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1628314964,
        "creation_date": 1628266551,
        "last_edit_date": 1628314964,
        "question_id": 68684696,
        "body_markdown": "This is my sample input\r\nInput\r\n```json\r\n[\r\n  {\r\n    &quot;label&quot;: &quot;test1&quot;,\r\n    &quot;value&quot;: 1,\r\n    &quot;path&quot;: &quot;data/testData/testDataLevel3/testDataLevel3_1/0/testDataLevel3_1_a2&quot;\r\n  },\r\n  {\r\n    &quot;label&quot;: &quot;test2&quot;,\r\n    &quot;value&quot;: 2,\r\n    &quot;path&quot;: &quot;data/testData/testDataLevel1/testDataLevel1_1&quot;\r\n  }\r\n]\r\n```\r\nThis input needs to be converted like this using jq\r\n\r\nExpected output: \r\n\r\n```json\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;testData&quot;: {\r\n      &quot;testDataLevel1&quot;: { //object\r\n        &quot;testDataLevel1_1&quot;: 2\r\n      },\r\n      &quot;testDataLevel3&quot;: {\r\n        &quot;testDataLevel3_1&quot;: [ //array\r\n          {\r\n            &quot;testDataLevel3_1_a2&quot;: 1\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nThe path will contain the array index as path, and sometimes the keys will be combined in the path as well \r\n",
        "link": "https://stackoverflow.com/questions/68684696/how-to-convert-array-of-object-into-expected-json-key-value-object-based-on-the",
        "title": "How to convert array of object into expected json key value object based on the path value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1628273712,
                "creation_date": 1628273712,
                "answer_id": 68685955,
                "question_id": 68685806,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you just want the relevant JSON objects:\r\n\r\n```\r\njq &#39;.[] | select(.Field.FieldId | IN(83,84,85))&#39; input.json\r\n\r\n```\r\n\r\n---\r\nFor future reference, please follow the http://stackoverflow.com/help/mcve guidelines as much as possible.  It also usually helps if you show some evidence of the &quot;research&quot; you&#39;ve completed, e.g. in the form of a failing program.\r\n\r\n",
                "title": "Parsing the correct fields with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1628274042,
                "creation_date": 1628274042,
                "answer_id": 68686020,
                "question_id": 68685806,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the file is too large to fit comfortably in memory, you could use the --stream option:\r\n```\r\n&lt; input.json jq -n --stream &#39;\r\n  fromstream(1|truncate_stream(inputs)) | select(.Field.FieldId | IN(83,84,85))&#39;\r\n```",
                "title": "Parsing the correct fields with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1628274042,
        "creation_date": 1628272751,
        "question_id": 68685806,
        "body_markdown": "I have a very long JSON that I&#39;m trying to parse using JQ. Basically, the only fields I really need is the data that is contained within FieldId: 83, FieldId: 84, and FieldId: 85. All the other fields are basically irrelevant for the purposes of this exercise. So just the data from those three fields.  \r\n\r\nHow would I do that?     \r\n\r\n    [\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 54,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;What school did you attend?&quot;,\r\n                    &quot;FieldGroupId&quot;: 12,\r\n                    &quot;FieldGroupName&quot;: &quot;College&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;T&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: 75,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 54,\r\n                &quot;FieldGroupId&quot;: 12,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 63,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;What year did you graduate?&quot;,\r\n                    &quot;FieldGroupId&quot;: 12,\r\n                    &quot;FieldGroupName&quot;: &quot;College&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;S&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: null,\r\n                    &quot;availableValues&quot;: [\r\n                        {\r\n                            &quot;id&quot;: 1,\r\n                            &quot;name&quot;: &quot;2017&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 2,\r\n                            &quot;name&quot;: &quot;2018&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 3,\r\n                            &quot;name&quot;: &quot;2019&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 4,\r\n                            &quot;name&quot;: &quot;2020&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 5,\r\n                            &quot;name&quot;: &quot;2021&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 6,\r\n                            &quot;name&quot;: &quot;2022&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 7,\r\n                            &quot;name&quot;: &quot;2023&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 8,\r\n                            &quot;name&quot;: &quot;2024&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 11,\r\n                            &quot;name&quot;: &quot;2025&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 12,\r\n                            &quot;name&quot;: &quot;2026&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 9,\r\n                            &quot;name&quot;: &quot;Already graduated&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 10,\r\n                            &quot;name&quot;: &quot;Not applicable&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        }\r\n                    ],\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 63,\r\n                &quot;FieldGroupId&quot;: 12,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 81,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;School Organization&quot;,\r\n                    &quot;FieldGroupId&quot;: 12,\r\n                    &quot;FieldGroupName&quot;: &quot;College&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;S&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: null,\r\n                    &quot;availableValues&quot;: [\r\n                        {\r\n                            &quot;id&quot;: 1,\r\n                            &quot;name&quot;: &quot;Administration/Administrators&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 2,\r\n                            &quot;name&quot;: &quot;Class Representatives&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 3,\r\n                            &quot;name&quot;: &quot;Greek Life&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 4,\r\n                            &quot;name&quot;: &quot;Other&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 5,\r\n                            &quot;name&quot;: &quot;Student Clubs&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        }\r\n                    ],\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 81,\r\n                &quot;FieldGroupId&quot;: 12,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 82,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;School Organization Name&quot;,\r\n                    &quot;FieldGroupId&quot;: 12,\r\n                    &quot;FieldGroupName&quot;: &quot;College&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;T&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: 75,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 82,\r\n                &quot;FieldGroupId&quot;: 12,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 83,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Gender&quot;,\r\n                    &quot;FieldGroupId&quot;: 36,\r\n                    &quot;FieldGroupName&quot;: &quot;Demographics&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;T&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: 75,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 83,\r\n                &quot;FieldGroupId&quot;: 36,\r\n                &quot;assignedValue&quot;: &quot;Male&quot;\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 84,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Race&quot;,\r\n                    &quot;FieldGroupId&quot;: 36,\r\n                    &quot;FieldGroupName&quot;: &quot;Demographics&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;T&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: 75,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 84,\r\n                &quot;FieldGroupId&quot;: 36,\r\n                &quot;assignedValue&quot;: &quot;Caucasian&quot;\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 85,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Age&quot;,\r\n                    &quot;FieldGroupId&quot;: 36,\r\n                    &quot;FieldGroupName&quot;: &quot;Demographics&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;T&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: 75,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 85,\r\n                &quot;FieldGroupId&quot;: 36,\r\n                &quot;assignedValue&quot;: &quot;31&quot;\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 70,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Are you over 21?&quot;,\r\n                    &quot;FieldGroupId&quot;: 16,\r\n                    &quot;FieldGroupName&quot;: &quot;RSVPs&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;S&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: null,\r\n                    &quot;availableValues&quot;: [\r\n                        {\r\n                            &quot;id&quot;: 1,\r\n                            &quot;name&quot;: &quot;no&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 2,\r\n                            &quot;name&quot;: &quot;yes&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        }\r\n                    ],\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 70,\r\n                &quot;FieldGroupId&quot;: 16,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 12,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Opt-in to SMS messages&quot;,\r\n                    &quot;FieldGroupId&quot;: 9,\r\n                    &quot;FieldGroupName&quot;: &quot;SMS OPT&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;B&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: null,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: false\r\n                },\r\n                &quot;FieldId&quot;: 12,\r\n                &quot;FieldGroupId&quot;: 9,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 75,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Instagram Handle&quot;,\r\n                    &quot;FieldGroupId&quot;: 34,\r\n                    &quot;FieldGroupName&quot;: &quot;Social Media&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;T&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: 75,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 75,\r\n                &quot;FieldGroupId&quot;: 34,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 79,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Facebook Username&quot;,\r\n                    &quot;FieldGroupId&quot;: 34,\r\n                    &quot;FieldGroupName&quot;: &quot;Social Media&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;T&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: 75,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 79,\r\n                &quot;FieldGroupId&quot;: 34,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 66,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Upload &quot;,\r\n                    &quot;FieldGroupId&quot;: 31,\r\n                    &quot;FieldGroupName&quot;: &quot;Story Collection&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;S&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: null,\r\n                    &quot;availableValues&quot;: [\r\n        \r\n                    ],\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 66,\r\n                &quot;FieldGroupId&quot;: 31,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 65,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Story Collection &quot;,\r\n                    &quot;FieldGroupId&quot;: 31,\r\n                    &quot;FieldGroupName&quot;: &quot;Story Collection&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;B&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: null,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 65,\r\n                &quot;FieldGroupId&quot;: 31,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 64,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Story Upload&quot;,\r\n                    &quot;FieldGroupId&quot;: 31,\r\n                    &quot;FieldGroupName&quot;: &quot;Story Collection&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;T&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: 75,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 64,\r\n                &quot;FieldGroupId&quot;: 31,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 13,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;I would like to volunteer.&quot;,\r\n                    &quot;FieldGroupId&quot;: 10,\r\n                    &quot;FieldGroupName&quot;: &quot;Volunteer&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;B&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: null,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: false\r\n                },\r\n                &quot;FieldId&quot;: 13,\r\n                &quot;FieldGroupId&quot;: 10,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 38,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Text Opt-in (old)&quot;,\r\n                    &quot;FieldGroupId&quot;: 10,\r\n                    &quot;FieldGroupName&quot;: &quot;Volunteer&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;B&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: null,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 38,\r\n                &quot;FieldGroupId&quot;: 10,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 62,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Are you a high school student?&quot;,\r\n                    &quot;FieldGroupId&quot;: 10,\r\n                    &quot;FieldGroupName&quot;: &quot;Volunteer&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;B&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: null,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 62,\r\n                &quot;FieldGroupId&quot;: 10,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 67,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Are you a fan?&quot;,\r\n                    &quot;FieldGroupId&quot;: 10,\r\n                    &quot;FieldGroupName&quot;: &quot;Volunteer&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;S&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: null,\r\n                    &quot;availableValues&quot;: [\r\n                        {\r\n                            &quot;id&quot;: 1,\r\n                            &quot;name&quot;: &quot;No&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 2,\r\n                            &quot;name&quot;: &quot;Yes&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        }\r\n                    ],\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 67,\r\n                &quot;FieldGroupId&quot;: 10,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 68,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Check here if you are a Spanish speaker&quot;,\r\n                    &quot;FieldGroupId&quot;: 10,\r\n                    &quot;FieldGroupName&quot;: &quot;Volunteer&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;B&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: null,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 68,\r\n                &quot;FieldGroupId&quot;: 10,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 69,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Did you purchase?&quot;,\r\n                    &quot;FieldGroupId&quot;: 10,\r\n                    &quot;FieldGroupName&quot;: &quot;Volunteer&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;S&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: null,\r\n                    &quot;availableValues&quot;: [\r\n                        {\r\n                            &quot;id&quot;: 1,\r\n                            &quot;name&quot;: &quot;Email&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 2,\r\n                            &quot;name&quot;: &quot;Phone call&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        },\r\n                        {\r\n                            &quot;id&quot;: 3,\r\n                            &quot;name&quot;: &quot;Text&quot;,\r\n                            &quot;parentValueId&quot;: null\r\n                        }\r\n                    ],\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 69,\r\n                &quot;FieldGroupId&quot;: 10,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 76,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Contact 1&quot;,\r\n                    &quot;FieldGroupId&quot;: 35,\r\n                    &quot;FieldGroupName&quot;: &quot;I don&#39;t know&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;T&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: 75,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 76,\r\n                &quot;FieldGroupId&quot;: 35,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 77,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Test 2&quot;,\r\n                    &quot;FieldGroupId&quot;: 35,\r\n                    &quot;FieldGroupName&quot;: &quot;I don&#39;t know&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;T&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: 75,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 77,\r\n                &quot;FieldGroupId&quot;: 35,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 78,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Test 3&quot;,\r\n                    &quot;FieldGroupId&quot;: 35,\r\n                    &quot;FieldGroupName&quot;: &quot;I don&#39;t know&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;T&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: 75,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 78,\r\n                &quot;FieldGroupId&quot;: 35,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 71,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Test 4&quot;,\r\n                    &quot;FieldGroupId&quot;: 32,\r\n                    &quot;FieldGroupName&quot;: &quot;I don&#39;t know&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;B&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: null,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 71,\r\n                &quot;FieldGroupId&quot;: 32,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 72,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Test 5&quot;,\r\n                    &quot;FieldGroupId&quot;: 32,\r\n                    &quot;FieldGroupName&quot;: &quot;I don&#39;t know&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;T&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: 75,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 72,\r\n                &quot;FieldGroupId&quot;: 32,\r\n                &quot;assignedValue&quot;: null\r\n            },\r\n            {\r\n                &quot;Field&quot;: {\r\n                    &quot;FieldId&quot;: 80,\r\n                    &quot;FieldParentId&quot;: null,\r\n                    &quot;FieldName&quot;: &quot;Test 6&quot;,\r\n                    &quot;FieldGroupId&quot;: 32,\r\n                    &quot;FieldGroupName&quot;: &quot;I don&#39;t know&quot;,\r\n                    &quot;FieldGroupType&quot;: &quot;Contacts&quot;,\r\n                    &quot;FieldTypeId&quot;: &quot;B&quot;,\r\n                    &quot;isEditable&quot;: true,\r\n                    &quot;maxTextboxCharacters&quot;: null,\r\n                    &quot;availableValues&quot;: null,\r\n                    &quot;isExportable&quot;: true\r\n                },\r\n                &quot;FieldId&quot;: 80,\r\n                &quot;FieldGroupId&quot;: 32,\r\n                &quot;assignedValue&quot;: null\r\n            }\r\n        ]",
        "link": "https://stackoverflow.com/questions/68685806/parsing-the-correct-fields-with-jq",
        "title": "Parsing the correct fields with jq"
    },
    {
        "tags": [
            "r",
            "jq",
            "jsonlite",
            "rjson",
            "rjsonio"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6861438,
                    "reputation": 676,
                    "user_id": 5468495,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://www.gravatar.com/avatar/d6a3833d2643bc2831b59e8f0d370abe?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "wizkids121",
                    "link": "https://stackoverflow.com/users/5468495/wizkids121"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628282512,
                "post_id": 68686847,
                "comment_id": 121387937,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4601727,
                    "reputation": 889921,
                    "user_id": 3732271,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/4WkGW.jpg?s=256",
                    "display_name": "akrun",
                    "link": "https://stackoverflow.com/users/3732271/akrun"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628282585,
                "post_id": 68686847,
                "comment_id": 121387955,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6861438,
                    "reputation": 676,
                    "user_id": 5468495,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://www.gravatar.com/avatar/d6a3833d2643bc2831b59e8f0d370abe?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "wizkids121",
                    "link": "https://stackoverflow.com/users/5468495/wizkids121"
                },
                "reply_to_user": {
                    "account_id": 4601727,
                    "reputation": 889921,
                    "user_id": 3732271,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/4WkGW.jpg?s=256",
                    "display_name": "akrun",
                    "link": "https://stackoverflow.com/users/3732271/akrun"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628283080,
                "post_id": 68686847,
                "comment_id": 121388095,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4601727,
                    "reputation": 889921,
                    "user_id": 3732271,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/4WkGW.jpg?s=256",
                    "display_name": "akrun",
                    "link": "https://stackoverflow.com/users/3732271/akrun"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628283854,
                "post_id": 68686847,
                "comment_id": 121388313,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6861438,
                    "reputation": 676,
                    "user_id": 5468495,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://www.gravatar.com/avatar/d6a3833d2643bc2831b59e8f0d370abe?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "wizkids121",
                    "link": "https://stackoverflow.com/users/5468495/wizkids121"
                },
                "reply_to_user": {
                    "account_id": 4601727,
                    "reputation": 889921,
                    "user_id": 3732271,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/4WkGW.jpg?s=256",
                    "display_name": "akrun",
                    "link": "https://stackoverflow.com/users/3732271/akrun"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628285996,
                "post_id": 68686847,
                "comment_id": 121388829,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4601727,
                    "reputation": 889921,
                    "user_id": 3732271,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/4WkGW.jpg?s=256",
                    "display_name": "akrun",
                    "link": "https://stackoverflow.com/users/3732271/akrun"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628286163,
                "post_id": 68686847,
                "comment_id": 121388858,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6861438,
                    "reputation": 676,
                    "user_id": 5468495,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://www.gravatar.com/avatar/d6a3833d2643bc2831b59e8f0d370abe?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "wizkids121",
                    "link": "https://stackoverflow.com/users/5468495/wizkids121"
                },
                "reply_to_user": {
                    "account_id": 4601727,
                    "reputation": 889921,
                    "user_id": 3732271,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/4WkGW.jpg?s=256",
                    "display_name": "akrun",
                    "link": "https://stackoverflow.com/users/3732271/akrun"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628286643,
                "post_id": 68686847,
                "comment_id": 121388955,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4601727,
                    "reputation": 889921,
                    "user_id": 3732271,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/4WkGW.jpg?s=256",
                    "display_name": "akrun",
                    "link": "https://stackoverflow.com/users/3732271/akrun"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628287123,
                "post_id": 68686847,
                "comment_id": 121389060,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6861438,
                    "reputation": 676,
                    "user_id": 5468495,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://www.gravatar.com/avatar/d6a3833d2643bc2831b59e8f0d370abe?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "wizkids121",
                    "link": "https://stackoverflow.com/users/5468495/wizkids121"
                },
                "reply_to_user": {
                    "account_id": 4601727,
                    "reputation": 889921,
                    "user_id": 3732271,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/4WkGW.jpg?s=256",
                    "display_name": "akrun",
                    "link": "https://stackoverflow.com/users/3732271/akrun"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628287227,
                "post_id": 68686847,
                "comment_id": 121389070,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6861438,
                    "reputation": 676,
                    "user_id": 5468495,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://www.gravatar.com/avatar/d6a3833d2643bc2831b59e8f0d370abe?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "wizkids121",
                    "link": "https://stackoverflow.com/users/5468495/wizkids121"
                },
                "reply_to_user": {
                    "account_id": 4601727,
                    "reputation": 889921,
                    "user_id": 3732271,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/4WkGW.jpg?s=256",
                    "display_name": "akrun",
                    "link": "https://stackoverflow.com/users/3732271/akrun"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1628287299,
                "post_id": 68686847,
                "comment_id": 121389083,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1628287264,
                "creation_date": 1628287264,
                "answer_id": 68687883,
                "question_id": 68686847,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "We can change the syntax to as the structure was slightly different compared to the one OP run it on the site\r\n\r\n```\r\n&gt; capture_jq %&gt;% jq(&#39;.&quot;assignedValue&quot;&#39;)\r\n[\r\n    &quot;Male&quot;,\r\n    &quot;Caucasian&quot;,\r\n    &quot;31&quot;\r\n]\r\n```",
                "title": "jqr package not matching results from jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1628287264,
        "creation_date": 1628279381,
        "last_edit_date": 1628286671,
        "question_id": 68686847,
        "body_markdown": "    person &lt;- GET(\r\n      &quot;https://api.secure.com/v4/people/111322450?$expand=customFields&quot;,\r\n      accept_json(),\r\n      add_headers(Accept = &#39;application/json&#39;,\r\n        Authorization = APIKey)\r\n    )\r\n    \r\n    capture &lt;- content(person)\r\n\r\n    dput(capture)\r\n\r\n    capture &lt;- list(vanId = 111322450L, firstName = &quot;Joe&quot;, lastName = &quot;Smith&quot;, \r\n        middleName = NULL, suffix = NULL, title = &quot;Mr.&quot;, contactMode = &quot;Person&quot;, \r\n        organizationContactCommonName = NULL, organizationContactOfficialName = NULL, \r\n        salutation = &quot;Joe&quot;, formalSalutation = &quot;Mr. Smith&quot;, additionalSalutation = NULL, \r\n        preferredPronoun = NULL, envelopeName = &quot;Joe Smith&quot;, formalEnvelopeName = &quot;Mr. Joe Smith&quot;, \r\n        additionalEnvelopeName = NULL, contactMethodPreferenceCode = NULL, \r\n        nickname = NULL, website = NULL, professionalSuffix = NULL, \r\n        party = NULL, employer = NULL, occupation = NULL, sex = NULL, \r\n        dateOfBirth = NULL, selfReportedRace = NULL, selfReportedEthnicity = NULL, \r\n        selfReportedRaces = NULL, selfReportedEthnicities = NULL, \r\n        selfReportedGenders = NULL, selfReportedSexualOrientations = NULL, \r\n        selfReportedLanguagePreference = NULL, emails = NULL, phones = NULL, \r\n        addresses = NULL, recordedAddresses = NULL, identifiers = NULL, \r\n        codes = NULL, customFields = list(list(customField = list(\r\n            customFieldId = 54L, customFieldParentId = NULL, customFieldName = &quot;If you&#39;re in college, which college?&quot;, \r\n            customFieldGroupId = 12L, customFieldGroupName = &quot;College&quot;, \r\n            customFieldGroupType = &quot;Contacts&quot;, customFieldTypeId = &quot;T&quot;, \r\n            isEditable = TRUE, maxTextboxCharacters = 75L, availableValues = NULL, \r\n            isExportable = TRUE), customFieldId = 54L, customFieldGroupId = 12L, \r\n            assignedValue = NULL), list(customField = list(customFieldId = 63L, \r\n            customFieldParentId = NULL, customFieldName = &quot;Graduation Year&quot;, \r\n            customFieldGroupId = 12L, customFieldGroupName = &quot;College&quot;, \r\n            customFieldGroupType = &quot;Contacts&quot;, customFieldTypeId = &quot;S&quot;, \r\n            isEditable = TRUE, maxTextboxCharacters = NULL, availableValues = list(\r\n                list(id = 1L, name = &quot;2017&quot;, parentValueId = NULL), \r\n                list(id = 2L, name = &quot;2018&quot;, parentValueId = NULL), \r\n                list(id = 3L, name = &quot;2019&quot;, parentValueId = NULL), \r\n                list(id = 4L, name = &quot;2020&quot;, parentValueId = NULL), \r\n                list(id = 5L, name = &quot;2021&quot;, parentValueId = NULL), \r\n                list(id = 6L, name = &quot;2022&quot;, parentValueId = NULL), \r\n                list(id = 7L, name = &quot;2023&quot;, parentValueId = NULL), \r\n                list(id = 8L, name = &quot;2024&quot;, parentValueId = NULL), \r\n                list(id = 11L, name = &quot;2025&quot;, parentValueId = NULL), \r\n                list(id = 12L, name = &quot;2026&quot;, parentValueId = NULL), \r\n                list(id = 9L, name = &quot;Already graduated&quot;, parentValueId = NULL), \r\n                list(id = 10L, name = &quot;Not applicable&quot;, parentValueId = NULL)), \r\n            isExportable = TRUE), customFieldId = 63L, customFieldGroupId = 12L, \r\n            assignedValue = NULL), list(customField = list(customFieldId = 81L, \r\n            customFieldParentId = NULL, customFieldName = &quot;School Organization&quot;, \r\n            customFieldGroupId = 12L, customFieldGroupName = &quot;College&quot;, \r\n            customFieldGroupType = &quot;Contacts&quot;, customFieldTypeId = &quot;S&quot;, \r\n            isEditable = TRUE, maxTextboxCharacters = NULL, availableValues = list(\r\n                list(id = 1L, name = &quot;Administration/Administrators&quot;, \r\n                    parentValueId = NULL), list(id = 2L, name = &quot;Class Representatives&quot;, \r\n                    parentValueId = NULL), list(id = 3L, name = &quot;Greek Life&quot;, \r\n                    parentValueId = NULL), list(id = 4L, name = &quot;Other&quot;, \r\n                    parentValueId = NULL), list(id = 5L, name = &quot;Student Clubs&quot;, \r\n                    parentValueId = NULL)), isExportable = TRUE), \r\n            customFieldId = 81L, customFieldGroupId = 12L, assignedValue = NULL), \r\n            list(customField = list(customFieldId = 82L, customFieldParentId = NULL, \r\n                customFieldName = &quot;School Organization Name&quot;, customFieldGroupId = 12L, \r\n                customFieldGroupName = &quot;College&quot;, customFieldGroupType = &quot;Contacts&quot;, \r\n                customFieldTypeId = &quot;T&quot;, isEditable = TRUE, maxTextboxCharacters = 75L, \r\n                availableValues = NULL, isExportable = TRUE), customFieldId = 82L, \r\n                customFieldGroupId = 12L, assignedValue = NULL), \r\n            list(customField = list(customFieldId = 83L, customFieldParentId = NULL, \r\n                customFieldName = &quot;Gender&quot;, customFieldGroupId = 36L, \r\n                customFieldGroupName = &quot;Demographics&quot;, customFieldGroupType = &quot;Contacts&quot;, \r\n                customFieldTypeId = &quot;T&quot;, isEditable = TRUE, maxTextboxCharacters = 75L, \r\n                availableValues = NULL, isExportable = TRUE), customFieldId = 83L, \r\n                customFieldGroupId = 36L, assignedValue = &quot;Male&quot;), \r\n            list(customField = list(customFieldId = 84L, customFieldParentId = NULL, \r\n                customFieldName = &quot;Race&quot;, customFieldGroupId = 36L, \r\n                customFieldGroupName = &quot;Demographics&quot;, customFieldGroupType = &quot;Contacts&quot;, \r\n                customFieldTypeId = &quot;T&quot;, isEditable = TRUE, maxTextboxCharacters = 75L, \r\n                availableValues = NULL, isExportable = TRUE), customFieldId = 84L, \r\n                customFieldGroupId = 36L, assignedValue = &quot;Caucasian&quot;), \r\n            list(customField = list(customFieldId = 85L, customFieldParentId = NULL, \r\n                customFieldName = &quot;Age&quot;, customFieldGroupId = 36L, \r\n                customFieldGroupName = &quot;Demographics&quot;, customFieldGroupType = &quot;Contacts&quot;, \r\n                customFieldTypeId = &quot;T&quot;, isEditable = TRUE, maxTextboxCharacters = 75L, \r\n                availableValues = NULL, isExportable = TRUE), customFieldId = 85L, \r\n                customFieldGroupId = 36L, assignedValue = &quot;31&quot;), \r\n            list(customField = list(customFieldId = 70L, customFieldParentId = NULL, \r\n                customFieldName = &quot;Are you over 21?&quot;, customFieldGroupId = 16L, \r\n                customFieldGroupName = &quot;RSVPs&quot;, customFieldGroupType = &quot;Contacts&quot;, \r\n                customFieldTypeId = &quot;S&quot;, isEditable = TRUE, maxTextboxCharacters = NULL, \r\n                availableValues = list(list(id = 1L, name = &quot;no&quot;, \r\n                    parentValueId = NULL), list(id = 2L, name = &quot;yes&quot;, \r\n                    parentValueId = NULL)), isExportable = TRUE), \r\n                customFieldId = 70L, customFieldGroupId = 16L, assignedValue = NULL), \r\n            list(customField = list(customFieldId = 12L, customFieldParentId = NULL, \r\n                customFieldName = &quot;Opt-in to SMS messages&quot;, customFieldGroupId = 9L, \r\n                customFieldGroupName = &quot;SMS OPT&quot;, customFieldGroupType = &quot;Contacts&quot;, \r\n                customFieldTypeId = &quot;B&quot;, isEditable = TRUE, maxTextboxCharacters = NULL, \r\n                availableValues = NULL, isExportable = FALSE), customFieldId = 12L, \r\n                customFieldGroupId = 9L, assignedValue = NULL), list(\r\n                customField = list(customFieldId = 75L, customFieldParentId = NULL, \r\n                    customFieldName = &quot;Instagram Handle&quot;, customFieldGroupId = 34L, \r\n                    customFieldGroupName = &quot;Social Media&quot;, customFieldGroupType = &quot;Contacts&quot;, \r\n                    customFieldTypeId = &quot;T&quot;, isEditable = TRUE, maxTextboxCharacters = 75L, \r\n                    availableValues = NULL, isExportable = TRUE), \r\n                customFieldId = 75L, customFieldGroupId = 34L, assignedValue = NULL), \r\n            list(customField = list(customFieldId = 79L, customFieldParentId = NULL, \r\n                customFieldName = &quot;Facebook Username&quot;, customFieldGroupId = 34L, \r\n                customFieldGroupName = &quot;Social Media&quot;, customFieldGroupType = &quot;Contacts&quot;, \r\n                customFieldTypeId = &quot;T&quot;, isEditable = TRUE, maxTextboxCharacters = 75L, \r\n                availableValues = NULL, isExportable = TRUE), customFieldId = 79L, \r\n                customFieldGroupId = 34L, assignedValue = NULL), \r\n            list(customField = list(customFieldId = 66L, customFieldParentId = NULL, \r\n                customFieldName = &quot;Upload &quot;, customFieldGroupId = 31L, \r\n                customFieldGroupName = &quot;Story Collection&quot;, customFieldGroupType = &quot;Contacts&quot;, \r\n                customFieldTypeId = &quot;S&quot;, isEditable = TRUE, maxTextboxCharacters = NULL, \r\n                availableValues = list(), isExportable = TRUE), customFieldId = 66L, \r\n                customFieldGroupId = 31L, assignedValue = NULL), \r\n            list(customField = list(customFieldId = 65L, customFieldParentId = NULL, \r\n                customFieldName = &quot;Story Collection &quot;, customFieldGroupId = 31L, \r\n                customFieldGroupName = &quot;Story Collection&quot;, customFieldGroupType = &quot;Contacts&quot;, \r\n                customFieldTypeId = &quot;B&quot;, isEditable = TRUE, maxTextboxCharacters = NULL, \r\n                availableValues = NULL, isExportable = TRUE), customFieldId = 65L, \r\n                customFieldGroupId = 31L, assignedValue = NULL), \r\n            list(customField = list(customFieldId = 64L, customFieldParentId = NULL, \r\n                customFieldName = &quot;Story Upload&quot;, customFieldGroupId = 31L, \r\n                customFieldGroupName = &quot;Story Collection&quot;, customFieldGroupType = &quot;Contacts&quot;, \r\n                customFieldTypeId = &quot;T&quot;, isEditable = TRUE, maxTextboxCharacters = 75L, \r\n                availableValues = NULL, isExportable = TRUE), customFieldId = 64L, \r\n                customFieldGroupId = 31L, assignedValue = NULL), \r\n            list(customField = list(customFieldId = 13L, customFieldParentId = NULL, \r\n                customFieldName = &quot;I would like to volunteer.&quot;, customFieldGroupId = 10L, \r\n                customFieldGroupName = &quot;Volunteer&quot;, customFieldGroupType = &quot;Contacts&quot;, \r\n                customFieldTypeId = &quot;B&quot;, isEditable = TRUE, maxTextboxCharacters = NULL, \r\n                availableValues = NULL, isExportable = FALSE), customFieldId = 13L, \r\n                customFieldGroupId = 10L, assignedValue = NULL), \r\n            list(customField = list(customFieldId = 38L, customFieldParentId = NULL, \r\n                customFieldName = &quot;Text Opt-in (old)&quot;, customFieldGroupId = 10L, \r\n                customFieldGroupName = &quot;Volunteer&quot;, customFieldGroupType = &quot;Contacts&quot;, \r\n                customFieldTypeId = &quot;B&quot;, isEditable = TRUE, maxTextboxCharacters = NULL, \r\n                availableValues = NULL, isExportable = TRUE), customFieldId = 38L, \r\n                customFieldGroupId = 10L, assignedValue = NULL), \r\n            list(customField = list(customFieldId = 62L, customFieldParentId = NULL, \r\n                customFieldName = &quot;Are you a high school student?&quot;, \r\n                customFieldGroupId = 10L, customFieldGroupName = &quot;Volunteer&quot;, \r\n                customFieldGroupType = &quot;Contacts&quot;, customFieldTypeId = &quot;B&quot;, \r\n                isEditable = TRUE, maxTextboxCharacters = NULL, availableValues = NULL, \r\n                isExportable = TRUE), customFieldId = 62L, customFieldGroupId = 10L, \r\n                assignedValue = NULL), list(customField = list(customFieldId = 67L, \r\n                customFieldParentId = NULL, customFieldName = &quot;Have you done any sort of calling, texting, or door-knocking for a political or issue campaign?&quot;, \r\n                customFieldGroupId = 10L, customFieldGroupName = &quot;Volunteer&quot;, \r\n                customFieldGroupType = &quot;Contacts&quot;, customFieldTypeId = &quot;S&quot;, \r\n                isEditable = TRUE, maxTextboxCharacters = NULL, availableValues = list(\r\n                    list(id = 1L, name = &quot;No&quot;, parentValueId = NULL), \r\n                    list(id = 2L, name = &quot;Yes&quot;, parentValueId = NULL)), \r\n                isExportable = TRUE), customFieldId = 67L, customFieldGroupId = 10L, \r\n                assignedValue = NULL), list(customField = list(customFieldId = 68L, \r\n                customFieldParentId = NULL, customFieldName = &quot;Check here if you are a Spanish speaker&quot;, \r\n                customFieldGroupId = 10L, customFieldGroupName = &quot;Volunteer&quot;, \r\n                customFieldGroupType = &quot;Contacts&quot;, customFieldTypeId = &quot;B&quot;, \r\n                isEditable = TRUE, maxTextboxCharacters = NULL, availableValues = NULL, \r\n                isExportable = TRUE), customFieldId = 68L, customFieldGroupId = 10L, \r\n                assignedValue = NULL), list(customField = list(customFieldId = 69L, \r\n                customFieldParentId = NULL, customFieldName = &quot;Best way to remind you of your shift?&quot;, \r\n                customFieldGroupId = 10L, customFieldGroupName = &quot;Volunteer&quot;, \r\n                customFieldGroupType = &quot;Contacts&quot;, customFieldTypeId = &quot;S&quot;, \r\n                isEditable = TRUE, maxTextboxCharacters = NULL, availableValues = list(\r\n                    list(id = 1L, name = &quot;Email&quot;, parentValueId = NULL), \r\n                    list(id = 2L, name = &quot;Phone call&quot;, parentValueId = NULL), \r\n                    list(id = 3L, name = &quot;Text&quot;, parentValueId = NULL)), \r\n                isExportable = TRUE), customFieldId = 69L, customFieldGroupId = 10L, \r\n                assignedValue = NULL), list(customField = list(customFieldId = 76L, \r\n                customFieldParentId = NULL, customFieldName = &quot;Vote Tripling Contact 1&quot;, \r\n                customFieldGroupId = 35L, customFieldGroupName = &quot;Vote Tripling&quot;, \r\n                customFieldGroupType = &quot;Contacts&quot;, customFieldTypeId = &quot;T&quot;, \r\n                isEditable = TRUE, maxTextboxCharacters = 75L, availableValues = NULL, \r\n                isExportable = TRUE), customFieldId = 76L, customFieldGroupId = 35L, \r\n                assignedValue = NULL), list(customField = list(customFieldId = 77L, \r\n                customFieldParentId = NULL, customFieldName = &quot;Vote Tripling Contact 2&quot;, \r\n                customFieldGroupId = 35L, customFieldGroupName = &quot;Vote Tripling&quot;, \r\n                customFieldGroupType = &quot;Contacts&quot;, customFieldTypeId = &quot;T&quot;, \r\n                isEditable = TRUE, maxTextboxCharacters = 75L, availableValues = NULL, \r\n                isExportable = TRUE), customFieldId = 77L, customFieldGroupId = 35L, \r\n                assignedValue = NULL), list(customField = list(customFieldId = 78L, \r\n                customFieldParentId = NULL, customFieldName = &quot;Vote Tripling Contact 3&quot;, \r\n                customFieldGroupId = 35L, customFieldGroupName = &quot;Vote Tripling&quot;, \r\n                customFieldGroupType = &quot;Contacts&quot;, customFieldTypeId = &quot;T&quot;, \r\n                isEditable = TRUE, maxTextboxCharacters = 75L, availableValues = NULL, \r\n                isExportable = TRUE), customFieldId = 78L, customFieldGroupId = 35L, \r\n                assignedValue = NULL), list(customField = list(customFieldId = 71L, \r\n                customFieldParentId = NULL, customFieldName = &quot;Yes, send me a text on election day to remind me to vote&quot;, \r\n                customFieldGroupId = 32L, customFieldGroupName = &quot;Voting&quot;, \r\n                customFieldGroupType = &quot;Contacts&quot;, customFieldTypeId = &quot;B&quot;, \r\n                isEditable = TRUE, maxTextboxCharacters = NULL, availableValues = NULL, \r\n                isExportable = TRUE), customFieldId = 71L, customFieldGroupId = 32L, \r\n                assignedValue = NULL), list(customField = list(customFieldId = 72L, \r\n                customFieldParentId = NULL, customFieldName = &quot;how do you plan on voting?&quot;, \r\n                customFieldGroupId = 32L, customFieldGroupName = &quot;Voting&quot;, \r\n                customFieldGroupType = &quot;Contacts&quot;, customFieldTypeId = &quot;T&quot;, \r\n                isEditable = TRUE, maxTextboxCharacters = 75L, availableValues = NULL, \r\n                isExportable = TRUE), customFieldId = 72L, customFieldGroupId = 32L, \r\n                assignedValue = NULL), list(customField = list(customFieldId = 80L, \r\n                customFieldParentId = NULL, customFieldName = &quot;I&#39;m a first-time voter!&quot;, \r\n                customFieldGroupId = 32L, customFieldGroupName = &quot;Voting&quot;, \r\n                customFieldGroupType = &quot;Contacts&quot;, customFieldTypeId = &quot;B&quot;, \r\n                isEditable = TRUE, maxTextboxCharacters = NULL, availableValues = NULL, \r\n                isExportable = TRUE), customFieldId = 80L, customFieldGroupId = 32L, \r\n                assignedValue = NULL)), primaryCustomField = NULL, \r\n        contributionSummary = NULL, suppressions = NULL, caseworkCases = NULL, \r\n        caseworkIssues = NULL, caseworkStories = NULL, notes = NULL, \r\n        scores = NULL, customProperties = NULL, electionRecords = NULL, \r\n        membershipStatus = NULL, organizationRoles = NULL, districts = NULL, \r\n        surveyQuestionResponses = NULL, finderNumber = NULL, biographyImageUrl = NULL, \r\n        primaryContact = NULL)\r\n\r\nFirst I convert it to a JSON:\r\n\r\n    capture_json &lt;- rjson::toJSON(capture)\r\n\r\nThen I narrow it to only include `.customFields` and then I filter it on which `customFieldId`&#39;s I want:\r\n\r\n    capture_jq &lt;- capture_json %&gt;% jqr::jq(&#39;.customFields&#39;) %&gt;% jq(&#39;.[] | select(.customField.customFieldId | IN(83,84,85))&#39;)\r\n\r\nUsing that JSON data, I&#39;m trying to extract the values listed in the `assignedValue` field. When I use the jq tool and filter by `.[]|.assignedValue` it returns the values I want:\r\n\r\n    &quot;Male&quot;\r\n    &quot;Caucasian&quot;\r\n    &quot;31&quot;\r\n\r\n[You can see for yourself in this link.][1]\r\n\r\nIn my R script, the JSON data is stored in a variable called `capture_jq` and then I run this script:\r\n\r\n    assigned_values &lt;- capture_jq %&gt;% jq(&#39;.[]|.&quot;assignedValue&quot;&#39;) \r\n\r\nBut when I run that script, all it does is return null values that look like this:\r\n\r\n    [\r\n        null,\r\n        null,\r\n        null\r\n    ]\r\n\r\nWhat am I doing wrong? Why is it working fine in the jqplay link I provided above but not using the `jqr` package in R?\r\n\r\n\r\n  [1]: https://jqplay.org/s/ymxW95jr2d\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68686847/jqr-package-not-matching-results-from-jq",
        "title": "jqr package not matching results from jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "logging",
            "jq",
            "metrics"
        ],
        "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": 1628354335,
                "post_id": 68693551,
                "comment_id": 121400251,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20631469,
                    "reputation": 1,
                    "user_id": 15146209,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6f0f40668d24132772d616fe23860faf?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Igor Messi",
                    "link": "https://stackoverflow.com/users/15146209/igor-messi"
                },
                "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": 1628354676,
                "post_id": 68693551,
                "comment_id": 121400333,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1628358254,
                "creation_date": 1628358254,
                "answer_id": 68694792,
                "question_id": 68693551,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You just need to add a pipe after select :\r\n\r\n```\r\ncat testfile.txt | jq &#39;fromjson | select(.kubernetes.pod.memory.usage.bytes != null) | .kubernetes.pod.memory.usage.bytes, .&quot;@timestamp&quot;&#39;\r\n```",
                "title": "How to make request in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1628389270,
                "creation_date": 1628389270,
                "answer_id": 68697349,
                "question_id": 68693551,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a DRYer (as in [tag:DRY]) solution:\r\n```\r\n.[&quot;@timestamp&quot;] as $ts | .kubernetes.pod.memory.usage.bytes // empty | ., $ts\r\n```\r\n\r\nNote that this particular use of `//` assumes that you wish to treat `null`, `false`, and a missing key in the same way. If not, you can still use the same idea to stay DRY.\r\n\r\n",
                "title": "How to make request in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1628389270,
        "creation_date": 1628348704,
        "last_edit_date": 1628359873,
        "question_id": 68693551,
        "body_markdown": "I&#39;m trying to make request in jq:\r\n\r\n    cat testfile.txt | jq &#39;fromjson | select(.kubernetes.pod.memory.usage.bytes != null) .kubernetes.pod.memory.usage.bytes, .&quot;@timestamp&quot;&#39;\r\n\r\nMy output is: \r\n\r\n    &quot;2019-03-15T00:24:21.733Z&quot;\r\n    &quot;2019-03-15T00:25:10.169Z&quot;\r\n    &quot;2019-03-15T00:24:47.908Z&quot;\r\n    105889792\r\n    &quot;2019-03-15T00:25:04.446Z&quot;\r\n    34557952\r\n    &quot;2019-03-15T00:25:04.787Z&quot;\r\n\r\n\r\nHow to delete excess dates?\r\nFor example output only:\r\n\r\n    105889792\r\n    &quot;2019-03-15T00:25:04.446Z&quot;\r\n    34557952\r\n    &quot;2019-03-15T00:25:04.787Z&quot;\r\n\r\n    \r\n\r\n",
        "link": "https://stackoverflow.com/questions/68693551/how-to-make-request-in-jq",
        "title": "How to make request in jq"
    },
    {
        "tags": [
            "bash",
            "shell",
            "curl",
            "jq",
            "url-parameters"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628512939,
                "post_id": 68712132,
                "comment_id": 121433005,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17057944,
                    "reputation": 499,
                    "user_id": 12342019,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/580045a6f96c7b5d4160cf19f682a6db?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "t30_9",
                    "link": "https://stackoverflow.com/users/12342019/t30-9"
                },
                "reply_to_user": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628514546,
                "post_id": 68712132,
                "comment_id": 121433733,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628515122,
                "post_id": 68712132,
                "comment_id": 121433994,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17057944,
                    "reputation": 499,
                    "user_id": 12342019,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/580045a6f96c7b5d4160cf19f682a6db?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "t30_9",
                    "link": "https://stackoverflow.com/users/12342019/t30-9"
                },
                "reply_to_user": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628517414,
                "post_id": 68712132,
                "comment_id": 121435060,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628518191,
                "post_id": 68712132,
                "comment_id": 121435411,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1628524184,
                "last_edit_date": 1628524184,
                "creation_date": 1628523225,
                "answer_id": 68714757,
                "question_id": 68712132,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try changing\r\n\r\n    whitelist=whitelist_tmp.json\r\n\r\nto\r\n\r\n    whitelist=&quot;cat whitelist_tmp.json&quot;\r\n\r\nI think the error was occurring because shell was trying &amp; failing to execute &quot;whitelist_tmp.json&quot; as its own command/function instead of piping the contents of the file to jq.\r\n\r\nYou also want to add the -r option to jq in the variables you are going to pass in curl, like so:\r\n\r\n    ruleId=$($whitelist | jq -r &#39;.[].ruleId&#39;)\r\n    alert=$($whitelist | jq -r &#39;.[].alertName&#39;)\r\n    newLevel=$($whitelist | jq -r &#39;.[].newLevel&#39;)\r\n    url=$($whitelist | jq -r &#39;.[].url&#39;)\r\n    urlIsRegex=$($whitelist | jq -r &#39;.[].urlIsRegex&#39;)\r\n    enabled=$($whitelist | jq -r &#39;.[].enabled&#39;)\r\n    parameter=$($whitelist | jq -r &#39;.[].parameter&#39;)\r\n    evidence=$($whitelist | jq -r &#39;.[].evidence&#39;)\r\n\r\nWithout the -r option, any strings that jq outputs will be quoted, which could be escaping your script&#39;s quotation in the curl command. The -r option tells jq to output the raw string data without any quotation.",
                "title": "Passing Variables in CURL GET"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1628540809,
                "creation_date": 1628540809,
                "answer_id": 68718201,
                "question_id": 68712132,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. jq accepts a filename argument, and it would be better to use that than change `whitelist` to include a call to `cat`:\r\n\r\n```\r\n    jq -r &#39;MYFILTER&#39; &quot;$whitelist&quot;\r\n```\r\n2. Using filters such as `.[].evidence&#39;` makes your script very fragile, as it assumes the top-level array will always have just one entry.  If you want just the first entry in the array, you could specify that, though maybe using `first` would be even more robust:\r\n```\r\n    first(.[].evidence)\r\n```\r\n3. Although jq is fairly light-weight, it is worth noting that all those calls to jq could be reduced to one, though of course your shell script would then have to be modified as well.  See e.g.\r\n* https://stackoverflow.com/questions/66296417/attempting-to-assign-multiple-variables-using-jq\r\n",
                "title": "Passing Variables in CURL GET"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1628540809,
        "creation_date": 1628512272,
        "last_edit_date": 1628518189,
        "question_id": 68712132,
        "body_markdown": "I&#39;m trying to write a sh script that reads data from a JSON, and by parsing, pass the data as variables for a curl request (GET)\r\n\r\nThe parsing is done correctly but the CURL request continues to give problems. \r\n\r\nI parse the variables, after opening the JSON, with the help of JQ: \r\n``` \r\nruleId=$($JSON | jq &#39;.[].ruleId&#39;)\r\nalert=$($JSON | jq &#39;.[].alertName&#39;)\r\n...\r\n``` \r\n\r\n\r\nI&#39;m passing the variables in this way: \r\n\r\n``` \r\ncurl --data-urlencode &quot;ruleId=$ruleId&quot; --data-urlencode &quot;newLevel=$newLevel&quot; --data-urlencode &quot;url=$url&quot; --data-urlencode &quot;urlIsRegex=$urlIsRegex&quot; --data-urlencode &quot;enabled=$enabled&quot; --data-urlencode &quot;parameter=$parameter&quot; --data-urlencode &quot;evidence=$evidence&quot; &quot;http://localhost:8090/JSON/alertFilter/action/addGlobalAlertFilter&quot;\r\n```\r\n\r\nThe error that i get back is: \r\n\r\n``` curl: (3) URL using bad/illegal format or missing URL ```\r\n\r\n\r\nCan you help me?\r\n\r\nHere is my test script:\r\n\r\n```\r\n!/bin/sh\r\n#set -e\r\n\r\n# Info to test this script\r\n# 1. Start docker \r\n# 2. Run this command from terminal: docker run -u zap -p 8080:8090 -i owasp/zap2docker-stable zap.sh -daemon -host 0.0.0.0 -port 8080 -config api.disablekey=true -config api.addrs.addr.name=.* -config api.addrs.addr.regex=true\r\n# 2. Get the JSON from api (test for now)\r\n# 3. bash filter.sh\r\n# 4. Check for filter to be set with browser http://localhost:8080/UI/alertFilter/ =&gt; view global filter\r\n\r\n#open example JSON file (API) and check for alert filter list \r\ncurl -s &#39;https://api.npoint.io/c29e3a68be632f73fc22&#39; &gt; whitelist_tmp.json\r\nwhitelist=whitelist_tmp.json\r\n\r\n#Parser WITOUT loop\r\nruleId=$($whitelist | jq &#39;.[].ruleId&#39;)\r\nalert=$($whitelist | jq &#39;.[].alertName&#39;)\r\nnewLevel=$($whitelist | jq &#39;.[].newLevel&#39;)\r\nurl=$($whitelist | jq &#39;.[].url&#39;)\r\nurlIsRegex=$($whitelist | jq &#39;.[].urlIsRegex&#39;)\r\nenabled=$($whitelist | jq &#39;.[].enabled&#39;)\r\nparameter=$($whitelist | jq &#39;.[].parameter&#39;)\r\nevidence=$($whitelist | jq &#39;.[].evidence&#39;)\r\n\r\n#Fist test-query WITHOUT url-encoding =&gt; not working\r\n#curl -X -4 --retry 2 --retry-connrefused --retry-delay 3 &quot;http://localhost:8080/JSON/alertFilter/action/addGlobalAlertFilter/?ruleId=${ruleId}\\&amp;newLevel=${newLevel}\\&amp;url=${url}\\&amp;urlIsRegex=${urlIsRegex}\\&amp;parameter=${parameter}\\&amp;enabled=${enabled}\\&amp;evidence=${evidence}&quot;\r\n\r\n\r\n#Second test-query WITH url-encoding\r\ncurl --data-urlencode &quot;ruleId=$ruleId&quot; --data-urlencode &quot;newLevel=$newLevel&quot; --data-urlencode &quot;url=$url&quot; --data-urlencode &quot;urlIsRegex=$urlIsRegex&quot; --data-urlencode &quot;enabled=$enabled&quot; --data-urlencode &quot;parameter=$parameter&quot; --data-urlencode &quot;evidence=$evidence&quot; &quot;http://localhost:8080/JSON/alertFilter/action/addGlobalAlertFilter&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/68712132/passing-variables-in-curl-get",
        "title": "Passing Variables in CURL GET"
    },
    {
        "tags": [
            "json",
            "bash",
            "parsing",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1628604807,
                "last_edit_date": 1628604807,
                "creation_date": 1628604427,
                "answer_id": 68728361,
                "question_id": 68728292,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use bash arrays to store your values:\r\n\r\n    ruleId=($($whitelist | jq -r &#39;.[].ruleId&#39;))\r\n    alert=($($whitelist | jq -r &#39;.[].alertName&#39;))\r\n    ...\r\n\r\nand then iterate over them. Example:\r\n\r\n    for (( i = 0; i &lt; &quot;${#ruleId[@]}&quot;; i++ )); do\r\n      id=&quot;${ruleId[i]}&quot;\r\n      al=&quot;${alert[i]}&quot;\r\n      ...\r\n      echo &quot;$(curl --data-urlencode &quot;ruleId=$id&quot; ...\r\n    done\r\n\r\nThis works if and only if the values returned by your commands are single words (no spaces in them) or they are properly quoted. If you have more complex values you cannot simply assign them to an array with `array=($(command))`. You would get more cells than values in your array.",
                "title": "Parse JSON data in variables using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1628608033,
                "last_edit_date": 1628608033,
                "creation_date": 1628607729,
                "answer_id": 68729181,
                "question_id": 68728292,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pulling the comments from your [previous question](https://stackoverflow.com/q/68726678):\r\n\r\n    whitelist=&quot;whitelist_tmp.json&quot;\r\n    listlength=$(jq &#39;. | length&#39; &quot;${whitelist}&quot;)\r\n    \r\n    mapfile -t rule      &lt; &lt;(jq -r &#39;.[].ruleId&#39;      &quot;${whitelist}&quot;)\r\n    mapfile -t alert     &lt; &lt;(jq -r &#39;.[].cwalertName&#39; &quot;${whitelist}&quot;)\r\n    mapfile -t level     &lt; &lt;(jq -r &#39;.[].newLevel&#39;    &quot;${whitelist}&quot;)\r\n    mapfile -t url       &lt; &lt;(jq -r &#39;.[].url | .[]&#39;   &quot;${whitelist}&quot;)\r\n    mapfile -t regex     &lt; &lt;(jq -r &#39;.[].urlIsRegex&#39;  &quot;${whitelist}&quot;)\r\n    mapfile -t parameter &lt; &lt;(jq -r &#39;.[].parameter&#39;   &quot;${whitelist}&quot;)\r\n    mapfile -t evidence  &lt; &lt;(jq -r &#39;.[].evidence&#39;    &quot;${whitelist}&quot;)\r\n    \r\n    for ((i=0; i&lt;${listlength}; i++))\r\n    do\r\n        curl ... &quot;${rule[$i]}&quot; ... &quot;${alert[$i]}&quot; ...\r\n    done\r\n\r\nThe `mapfile` should maintain embedded white space in values returned by `jq`.\r\n",
                "title": "Parse JSON data in variables using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1628608033,
        "creation_date": 1628604189,
        "question_id": 68728292,
        "body_markdown": "I have some problems with my script which collects data from a JSON, stores them in variables which are then used for a CURL request. I need to build a CURL request for EACH JSON entry. \r\n\r\n\r\nMy problem is that I would like to pass parameters to the CURL request, one by one. \r\nI was thinking about a for-loop but this won&#39;t be actually the right workaround. \r\n\r\nThis because  \r\n\r\n```\r\nruleId=$($whitelist | jq -r &#39;.[].ruleId&#39;)\r\n```\r\n\r\ngives: \r\n\r\n```\r\n10055\r\n10098\r\n```\r\n\r\nThis can not be interpreted correctly from CURL. \r\n\r\nSo the question is, how can I pass variables in a proper manner, in a sort of iteration, using JQ? Again, I need to do single calls using CURLs for each entry in the JSON file. \r\n\r\n\r\n\r\nCode: \r\n\r\n```\r\n$!/bin/sh\r\n#set -e\r\n\r\n# Info to test this script\r\n# 1. Start docker \r\n# 2. Run this command from terminal: docker run -u zap -p 8080:8080 -i owasp/zap2docker-stable zap.sh -daemon -host 0.0.0.0 -port 8080 -config api.disablekey=true -config api.addrs.addr.name=.* -config api.addrs.addr.regex=true\r\n# 2. Get the JSON from api (test for now)\r\n# 3. bash filter.sh\r\n# 4. Check for filter to be set with browser http://localhost:8080/UI/alertFilter/ =&gt; view global filter\r\n\r\ncurl -s &#39;https://api.npoint.io/c29e3a68be632f73fc22&#39; &gt; whitelist_tmp.json\r\nwhitelist=&quot;cat whitelist_tmp.json&quot;\r\nlistlength=$(jq &#39;. | length&#39; $whitelist)\r\n\r\n\r\nruleId=$($whitelist | jq -r &#39;.[].ruleId&#39;)\r\nalert=$($whitelist | jq -r &#39;.[].alertName&#39;)\r\nnewLevel=$($whitelist | jq -r &#39;.[].newLevel&#39;)\r\nurl=$($whitelist | jq -r &#39;.[].url | .[]&#39;)\r\nurlIsRegex=$($whitelist | jq -r &#39;.[].urlIsRegex&#39;)\r\nenabled=$($whitelist | jq -r &#39;.[].enabled&#39;)\r\nparameter=$($whitelist | jq -r &#39;.[].parameter&#39;)\r\nevidence=$($whitelist | jq -r &#39;.[].evidence&#39;)\r\necho &quot;Setting Rule for: $ruleId&quot;\r\necho &quot;$(curl --data-urlencode &quot;ruleId=$ruleId&quot; --data-urlencode &quot;newLevel=$newLevel&quot; --data-urlencode &quot;url=$url&quot; --data-urlencode &quot;urlIsRegex=$urlIsRegex&quot; --data-urlencode &quot;enabled=$enabled&quot; --data-urlencode &quot;parameter=$parameter&quot; --data-urlencode &quot;evidence=$evidence&quot; &quot;http://localhost:8090/JSON/alertFilter/action/addGlobalAlertFilter&quot;)&quot;\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/68728292/parse-json-data-in-variables-using-jq",
        "title": "Parse JSON data in variables using JQ"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "amazon-s3",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1628617720,
                "creation_date": 1628617720,
                "answer_id": 68731439,
                "question_id": 68728763,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The variable `$key` will be a quoted string, so you&#39;re basically double quoting the string, and S3 is failing to find `&quot;key_name&quot;` with the quotes.  You could remove the quotes before passing them along:\r\n\r\n```\r\nfor key in $keys;do\r\n  key=&quot;${key%\\&quot;}&quot;\r\n  key=&quot;${key#\\&quot;}&quot;\r\n  aws s3api get-object --bucket &quot;$LOGGING_BUCKET&quot; --key &quot;$key&quot; ouput_file_&quot;$key&quot;\r\ndone\r\n```\r\n\r\nOf course, it would be much more performant to use `aws s3 sync` and avoid this issue altogether.",
                "title": "aws cli command from bash with jq to get S3 logs from logging bucket failing"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1628617720,
        "creation_date": 1628606102,
        "question_id": 68728763,
        "body_markdown": "The below script is intended to get the content of each entry in the S3 logging bucket and save it to a file \r\n\r\n    #!/bin/bash\r\n    #\r\n    # Get the content of each entry in the S3 logging bucket and save it to a file \r\n    #\r\n    \r\n    LOGGING_BUCKET=dtgd-hd00\r\n    \r\n    aws s3api list-objects-v2 --bucket &quot;$LOGGING_BUCKET&quot; | jq &#39;.Contents&#39; &gt;&gt; entries.json &amp;&amp;\r\n    keys=$(jq &#39;.[].Key&#39; entries.json )\r\n    \r\n    for key in $keys;do\r\n      echo $key\r\n      aws s3api get-object --bucket &quot;$LOGGING_BUCKET&quot; --key &quot;$key&quot; ouput_file_&quot;$key&quot;\r\n    done\r\n\r\n\r\nOnce executed I got:\r\n\r\n\r\n&gt; An error occurred (NoSuchKey) when calling the GetObject operation:\r\n&gt; The specified key does not exist.\r\n&gt;\r\n&gt; &quot;dtgd-hd00/logs2021-08-10-05-43-18-01393D975686FA45&quot;\r\n\r\nHowever, if I do it from  the CLI:\r\n\r\n    aws s3api get-object --bucket dtgd-hd00 \\\r\n        --key &quot;dtgd-hd00/logs2021-08-10-05-43-18-01393D975686FA45&quot; \\\r\n        output_file_&quot;$key&quot;\r\n\r\nIt works perfectly, getting the content and saving it to an output file as requested.\r\n\r\nWhat could be wrong ??\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68728763/aws-cli-command-from-bash-with-jq-to-get-s3-logs-from-logging-bucket-failing",
        "title": "aws cli command from bash with jq to get S3 logs from logging bucket failing"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1628622557,
                "post_id": 68732327,
                "comment_id": 121469333,
                "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": 1628622650,
                "post_id": 68732327,
                "comment_id": 121469361,
                "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": 1628623094,
                "post_id": 68732327,
                "comment_id": 121469481,
                "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": 1628623411,
                "post_id": 68732327,
                "comment_id": 121469596,
                "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": 1628623538,
                "post_id": 68732327,
                "comment_id": 121469639,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628632490,
                "post_id": 68732327,
                "comment_id": 121472293,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1628624067,
                "last_edit_date": 1628624067,
                "creation_date": 1628622945,
                "answer_id": 68732410,
                "question_id": 68732327,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d typically calculate the target date in native bash.\r\n\r\n```bash\r\n#!/usr/bin/env bash\r\n# make sure we have bash new enough for printf %(...)T time-formatting\r\n# this makes our script work even without GNU date\r\ncase $BASH_VERSION in\r\n  &#39;&#39;|[123].*|4.[012].*) echo &quot;ERROR: bash 4.3+ required&quot; &gt;&amp;2; exit 1;;\r\nesac\r\n\r\nexport TZ=UTC # force all timestamps to be in UTC (+00:00 / Z)\r\n\r\n# faster, bash-builtin now=$(date +%s)\r\nprintf -v now &#39;%(%s)T&#39; -1\r\n\r\n# faster, bash-builtin start_date_iso8601=$(date +%s -d &#39;30 minutes ago&#39;)\r\nstart_date_epoch=$((now - 60*30))\r\nprintf -v start_date_iso8601 &#39;%(%Y-%m-%dT%H:%M:%S+00:00)T&#39; &quot;$start_date_epoch&quot;\r\n\r\n# read our resulting names into an array (not a string)\r\n# jq -j suppresses newlines so we can use NUL delimiters\r\nwhile IFS= read -r -d &#39;&#39; name; do\r\n  names+=( &quot;$name&quot; )\r\ndone &lt; &lt;(\r\n  jq -j --arg start_date &quot;$start_date_iso8601&quot; &#39;\r\n    .[] |\r\n    select(.properties.lastModified &lt; $start_date) |\r\n    (.name, &quot;\\u0000&quot;)\r\n  &#39; &lt;text.json\r\n)\r\n\r\n# print the content of the array we just read the names into\r\nprintf &#39;Matching name: %q\\n&#39; &quot;${names[@]}&quot;\r\n```",
                "title": "JSON JQ filter by date older than bash"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1628623554,
                "creation_date": 1628623554,
                "answer_id": 68732521,
                "question_id": 68732327,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This seems to work\r\n\r\n\r\n    date=`date +%Y-%m-%d&#39;T&#39;%H:%M&#39;Z&#39; -d &quot;15 min ago&quot;`\r\n\r\n    file_names=`jq -r --arg date &quot;$date&quot; &#39;.[] | select(.properties.lastModified &lt; $date) | .name&#39; &lt; text.json`",
                "title": "JSON JQ filter by date older than bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1628628367,
                "last_edit_date": 1628628367,
                "creation_date": 1628626702,
                "answer_id": 68733037,
                "question_id": 68732327,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let `jq` do all date computations:\r\n\r\nWith bash 4 and above with `mapfile`:\r\n```sh\r\nmapfile -d &#39;&#39; last_modified &lt; &lt;(\r\n  jq --join-output &#39;(now - 1800) as $date | .[] | select((.properties.lastModified | .[:18] + &quot;Z&quot; | fromdate) &lt; $date) | .name + &quot;\\u0000&quot;&#39; input_file.json\r\n)\r\n\r\n# For debug purpose\r\ndeclare -p last_modified\r\n```\r\n\r\nWithout `mapfile`, records are delimited with ASCII `RS` control character rather than a `null` byte:\r\n\r\n```sh\r\nIFS=$&#39;\\36&#39; read -ra last_modified &lt; &lt;(jq -j &#39;(now - 1800) as $date | .[] | select((.properties.lastModified | .[:18] + &quot;Z&quot; | fromdate) &lt; $date) | .name + &quot;\\u001e&quot;&#39; input_file.json)\r\n```\r\n\r\nHere is the stand-alone `jq` script with comments:\r\n\r\n```jq\r\n#!/usr/bin/env -S jq -jf\r\n\r\n# Store current timestamp minus 30 minutes (1800 seconds) as $date\r\n(now - 1800) as $date |\r\n .[] |\r\n#\r\nselect(\r\n  (\r\n    # Strip the numerical timezone offset out from the timestamp\r\n    # and replace it with the Z for UTC iso8601\r\n    # to make it an iso8601 date string that jq understands\r\n    .properties.lastModified | .[:18] + &quot;Z&quot; | fromdate\r\n  ) &lt; $date\r\n) |\r\n.name + &quot;\\u0000&quot;\r\n```",
                "title": "JSON JQ filter by date older than bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1697398957,
        "creation_date": 1628622439,
        "question_id": 68732327,
        "body_markdown": "I have a json with this format of data in a text.json file\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;page/page1.html&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;lastModified&quot;: &quot;2021-08-10T18:00:45+00:00&quot;,\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;page/page2.html&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;lastModified&quot;: &quot;2021-08-10T19:24:23+00:00&quot;,\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;page/page3.html&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;lastModified&quot;: &quot;2021-08-10T20:36:21+00:00&quot;,\r\n        }\r\n      }\r\n    ]\r\n\r\nI want to make a list of all the names of files which are last modified more that 30 minutes ago. This is my query at the moment to get a list of file names as a variable which i can use later.\r\n\r\n    file_names=`cat text.json | jq -r .[].name`\r\n\r\nHow can I use jq to filter for lastModified more than 30 minutes ago based on the timestamp in the properties so I only get the relevant file names?",
        "link": "https://stackoverflow.com/questions/68732327/json-jq-filter-by-date-older-than-bash",
        "title": "JSON JQ filter by date older than bash"
    },
    {
        "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": 1628636298,
                "post_id": 68734190,
                "comment_id": 121473071,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9368912,
                    "reputation": 47,
                    "user_id": 7355559,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f4aa6accf987e6c7e05690bb29b23e15?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sanchu Varkey",
                    "link": "https://stackoverflow.com/users/7355559/sanchu-varkey"
                },
                "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": 1628636525,
                "post_id": 68734190,
                "comment_id": 121473113,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628636558,
                "post_id": 68734190,
                "comment_id": 121473119,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9368912,
                    "reputation": 47,
                    "user_id": 7355559,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f4aa6accf987e6c7e05690bb29b23e15?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sanchu Varkey",
                    "link": "https://stackoverflow.com/users/7355559/sanchu-varkey"
                },
                "reply_to_user": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1628636650,
                "post_id": 68734190,
                "comment_id": 121473133,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1628636646,
                "creation_date": 1628636646,
                "answer_id": 68734301,
                "question_id": 68734190,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following produces the desired result, and is hopefully clear enough to help you formulate the precise solution to your problem:\r\n```\r\nmap_values(\r\n  map(\r\n    if has(&quot;previous&quot;)\r\n    then select( .previous.startDateTime &gt;= 3 and .current.startDateTime &gt;= 3)\r\n    else .\r\n    end\r\n  )\r\n)\r\n```",
                "title": "JQ delete entries based on condtition"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1628637650,
                "creation_date": 1628637650,
                "answer_id": 68734402,
                "question_id": 68734190,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an illustrative program that produces the desired result using `walk`:\r\n```\r\nwalk (if type == &quot;array&quot;\r\n      then map(select(\r\n         if type == &quot;object&quot; and (.previous and .previous.startDateTime&lt;3 or .current.startDateTime&lt;3)\r\n         then empty\r\n\t else . end) )\r\n      else .\r\n      end)\r\n\r\n```",
                "title": "JQ delete entries based on condtition"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1628637650,
        "creation_date": 1628635356,
        "last_edit_date": 1628636673,
        "question_id": 68734190,
        "body_markdown": "My json looks like the following \r\n```\r\n{\r\n  \r\n  &quot;a6acc79a-1776-1719-a400-e78e2cda4dd1&quot;: [\r\n    {\r\n      &quot;previous&quot;: {\r\n        &quot;id&quot;: &quot;cf091d81-d0cb-3b31-ae15-451c551cf2fb&quot;,\r\n        &quot;startDateTime&quot;: 1,\r\n        &quot;endDateTime&quot;:2\r\n      },\r\n      &quot;current&quot;: {\r\n        &quot;id&quot;: &quot;2c05d2ad-ba36-3f61-9c12-5d2294aa4e3a&quot;,\r\n        &quot;startDateTime&quot;: 1,\r\n        &quot;endDateTime&quot;: 3\r\n      }\r\n    },\r\n    {\r\n      &quot;previous&quot;: {\r\n        &quot;id&quot;: &quot;f255daf7-b8fc-3b73-99bf-ec7d26b37748&quot;,\r\n        &quot;startDateTime&quot;: 3,\r\n        &quot;endDateTime&quot;: 3\r\n      },\r\n      &quot;current&quot;: {\r\n        &quot;id&quot;: &quot;9e0f131c-3043-3262-8d26-9c8b3bd0f516&quot;,\r\n        &quot;startDateTime&quot;:3,\r\n        &quot;endDateTime&quot;: 3\r\n      }\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\nI want to delete entries that don&#39;t match this condition `startDateTime &gt;= 3` and the expected output is  \r\n```\r\n{\r\n  \r\n    &quot;a6acc79a-1776-1719-a400-e78e2cda4dd1&quot;: [\r\n      {\r\n        &quot;previous&quot;: {\r\n          &quot;id&quot;: &quot;f255daf7-b8fc-3b73-99bf-ec7d26b37748&quot;,\r\n          &quot;startDateTime&quot;: 3,\r\n          &quot;endDateTime&quot;: 3\r\n        },\r\n        &quot;current&quot;: {\r\n          &quot;id&quot;: &quot;9e0f131c-3043-3262-8d26-9c8b3bd0f516&quot;,\r\n          &quot;startDateTime&quot;:3,\r\n          &quot;endDateTime&quot;: 3\r\n        }\r\n      }\r\n    ]\r\n  }\r\n  ```\r\nAny help is appreciated. I was able to delete some entries but not full objects.\r\nMy attempt so far is \r\njq -r &#39;walk(if type == &quot;object&quot; then with_entries(if ((.key | endswith(&quot;DateTime&quot;)) and (.value | tonumber &gt;= 3))  then empty  end) end) &#39; \r\n",
        "link": "https://stackoverflow.com/questions/68734190/jq-delete-entries-based-on-condtition",
        "title": "JQ delete entries based on condtition"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1628639560,
                "post_id": 68734540,
                "comment_id": 121473562,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1628639588,
                "post_id": 68734540,
                "comment_id": 121473568,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1628639605,
                "post_id": 68734540,
                "comment_id": 121473571,
                "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": 1628639744,
                "post_id": 68734540,
                "comment_id": 121473589,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14347533,
                    "reputation": 289,
                    "user_id": 10363993,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-yjhBqLNug2w/AAAAAAAAAAI/AAAAAAAAJiY/Jm1saNyvDFY/s256-rj/photo.jpg",
                    "display_name": "TooNetCreation",
                    "link": "https://stackoverflow.com/users/10363993/toonetcreation"
                },
                "reply_to_user": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628640003,
                "post_id": 68734540,
                "comment_id": 121473624,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14347533,
                    "reputation": 289,
                    "user_id": 10363993,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-yjhBqLNug2w/AAAAAAAAAAI/AAAAAAAAJiY/Jm1saNyvDFY/s256-rj/photo.jpg",
                    "display_name": "TooNetCreation",
                    "link": "https://stackoverflow.com/users/10363993/toonetcreation"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628640198,
                "post_id": 68734540,
                "comment_id": 121473659,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14347533,
                    "reputation": 289,
                    "user_id": 10363993,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-yjhBqLNug2w/AAAAAAAAAAI/AAAAAAAAJiY/Jm1saNyvDFY/s256-rj/photo.jpg",
                    "display_name": "TooNetCreation",
                    "link": "https://stackoverflow.com/users/10363993/toonetcreation"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628640492,
                "post_id": 68734540,
                "comment_id": 121473700,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3377022,
                    "reputation": 13682,
                    "user_id": 2834978,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ff9af10001f37bc0de566ca2caf2f558?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "LMC",
                    "link": "https://stackoverflow.com/users/2834978/lmc"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1628640658,
                "post_id": 68734540,
                "comment_id": 121473726,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 3377022,
                    "reputation": 13682,
                    "user_id": 2834978,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ff9af10001f37bc0de566ca2caf2f558?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "LMC",
                    "link": "https://stackoverflow.com/users/2834978/lmc"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1628667425,
                "post_id": 68734540,
                "comment_id": 121479252,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1628669230,
                "creation_date": 1628669230,
                "answer_id": 68738235,
                "question_id": 68734540,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "thanks to @Charles Duffy\r\nsolution:\r\n\r\n    select(.criteria.from == &quot;mail2@mail.com&quot;)",
                "title": "How to extract this string with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1628669230,
        "creation_date": 1628639401,
        "question_id": 68734540,
        "body_markdown": "I have a JSON file like this :\r\n\r\n    {\r\n      &quot;filter&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;id_1&quot;,\r\n          &quot;criteria&quot;: {\r\n            &quot;from&quot;: &quot;mail1@mail.com&quot;\r\n          },\r\n          &quot;action&quot;: {\r\n            &quot;addLabelIds&quot;: [\r\n              &quot;Label_1&quot;\r\n            ],\r\n            &quot;removeLabelIds&quot;: [\r\n              &quot;IMPORTANT&quot;,\r\n              &quot;SPAM&quot;\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;id_2&quot;,\r\n          &quot;criteria&quot;: {\r\n            &quot;from&quot;: &quot;mail2@mail.com&quot;\r\n          },\r\n          &quot;action&quot;: {\r\n            &quot;addLabelIds&quot;: [\r\n              &quot;Label_2&quot;\r\n            ],\r\n            &quot;removeLabelIds&quot;: [\r\n              &quot;IMPORTANT&quot;,\r\n              &quot;SPAM&quot;\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nI would like to extract **id value** only where **from = mail2@mail.com**\r\n\r\nI have tried this but does not work :\r\n\r\n    jq &#39;.filter[] | select(.criteria.from | test(&quot;mail2@mail.com&quot;; &quot;i&quot;)) | .id&#39;\r\n\r\nHave you got any idea?\r\n\r\nThanks\r\nL.",
        "link": "https://stackoverflow.com/questions/68734540/how-to-extract-this-string-with-jq",
        "title": "How to extract this string with JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17057944,
                    "reputation": 499,
                    "user_id": 12342019,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/580045a6f96c7b5d4160cf19f682a6db?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "t30_9",
                    "link": "https://stackoverflow.com/users/12342019/t30-9"
                },
                "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": 1628668933,
                "post_id": 68737973,
                "comment_id": 121479853,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628669702,
                "post_id": 68737973,
                "comment_id": 121480157,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1628669863,
                "post_id": 68737973,
                "comment_id": 121480236,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1628671829,
                "creation_date": 1628671829,
                "answer_id": 68738835,
                "question_id": 68737973,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The -s command-line option changes the JSON (essentially, it wraps the original JSON in an array), and is likely the source of your problem. Try omitting it.",
                "title": "Open JSON file locally with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1628671829,
        "creation_date": 1628667957,
        "question_id": 68737973,
        "body_markdown": "i&#39;m messing with jq and opening json files. \r\n\r\nI&#39;m working on a small parser.\r\nSo far I have used (for testing purposes) an api, from which I got the JSON (via curl -s).\r\n\r\n```\r\ncurl -s &#39;https://api.npoint.io/c..fc22&#39; &gt; whitelist_tmp.json\r\nwhitelist=&quot;cat whitelist_tmp.json&quot;\r\n```\r\n\r\nNow I would like to import the exact same JSON from the local directory where my script is located but I believe I am making a mistake.\r\nI created a new file called whitelist.json, located in the same folder. \r\n\r\n```\r\njq -s . whitelist.json &gt; whitelist_tmp.json\r\nwhitelist=&quot;cat whitelist_tmp.json&quot;\r\n\r\n#Parser part\r\nruleId=($($whitelist | jq -r &#39;.[].ruleId&#39;))\r\nalert=($($whitelist | jq -r &#39;.[].alertName&#39;))\r\n```",
        "link": "https://stackoverflow.com/questions/68737973/open-json-file-locally-with-jq",
        "title": "Open JSON file locally with JQ"
    },
    {
        "tags": [
            "json",
            "jq",
            "jsonparser"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1628696162,
                "post_id": 68745002,
                "comment_id": 121492016,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628696238,
                "post_id": 68745002,
                "comment_id": 121492052,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9343103,
                    "reputation": 3701,
                    "user_id": 6935166,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d76f6c7eaa45b7d26214b344e4f4e2fa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Venu S",
                    "link": "https://stackoverflow.com/users/6935166/venu-s"
                },
                "reply_to_user": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628696535,
                "post_id": 68745002,
                "comment_id": 121492204,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628696687,
                "post_id": 68745002,
                "comment_id": 121492254,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1628696948,
                "creation_date": 1628696948,
                "answer_id": 68745220,
                "question_id": 68745002,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In JSON :\r\n- [ .. ] is for array\r\n- { .. } is object\r\n\r\nSo if you put your json to a variable like\r\n\r\n    const jsx = [ {\r\n        &quot;name&quot;: &quot;ACCOUNT-V1&quot;,\r\n        &quot;version&quot;: &quot;1.3.0&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;IDENTIFIER-V1&quot;,\r\n        &quot;version&quot;: &quot;1.1.0&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;LOCATION-V1&quot;,\r\n        &quot;version&quot;: &quot;1.6.0&quot;\r\n      }\r\n    ];\r\n\r\nIt will be :\r\n- jsx[0].name = &quot;ACCOUNT-V1&quot;\r\n- jsx[2].version = &quot;1.6.0&quot;\r\n- and so on",
                "title": "parsing json and print only values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1628697243,
                "creation_date": 1628697243,
                "answer_id": 68745296,
                "question_id": 68745002,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq --raw-output &#39;.[] | &quot;\\(.name) \\(.version)&quot;&#39;\r\n```\r\n\r\nWhere\r\n\r\n* `.[]` Loops over the array\r\n* `&quot;\\(.name) \\(.version)&quot;` creates a string with `name` and `version` key  \r\n    &lt;sup&gt;[Using string interpolation][1]&lt;/sup&gt;\r\n\r\n* `--raw-putput` ensures no quotes on the output\r\n\r\n\r\n----------\r\n\r\n\r\n[Try it online!](https://jqplay.org/s/1Yy_pmsESE)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#example69",
                "title": "parsing json and print only values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1628697243,
        "creation_date": 1628696086,
        "last_edit_date": 1628696399,
        "question_id": 68745002,
        "body_markdown": "I have this json object like this :\r\n\r\n     [ {\r\n        &quot;name&quot;: &quot;ACCOUNT-V1&quot;,\r\n        &quot;version&quot;: &quot;1.3.0&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;IDENTIFIER-V1&quot;,\r\n        &quot;version&quot;: &quot;1.1.0&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;LOCATION-V1&quot;,\r\n        &quot;version&quot;: &quot;1.6.0&quot;\r\n      }\r\n    ]\r\n\r\n\r\n\r\nI&#39;d like to parse and print like this\r\n```\r\nACCOUNT-V1 1.3.0\r\nIDENTIFIER-V1 1.1.0\r\nLOCATION-V1 1.6.0\r\n```\r\n\r\ntried with \r\n\r\n    cat json_content.json | jq &#39; .[] | .name .version&#39;\r\n\r\njust getting empty array [] in output\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68745002/parsing-json-and-print-only-values",
        "title": "parsing json and print only values"
    },
    {
        "tags": [
            "json",
            "dynamic",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1628706121,
                "post_id": 68746172,
                "comment_id": 121495722,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1628715411,
                "creation_date": 1628715411,
                "answer_id": 68748840,
                "question_id": 68746172,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The details of your requirements are unclear, but you could proceed along the lines suggested by this jq filter:\r\n\r\n```\r\n  .data\r\n  | (keys_unsorted|map(select(test(&quot;^Item_[^_]*_Foo$&quot;)))) as $foos\r\n  | ($foos | map(sub(&quot;_Foo$&quot;; &quot;_Bar&quot;))) as $bars\r\n  | [ .[$foos[]].value, .[$bars[]].value]\r\n  | @tsv\r\n```\r\n\r\nThe idea is to determine dynamically which keys to select.",
                "title": "jq: from one json input, construct multiple rows of tsv using an expression against the keys?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1628717630,
        "creation_date": 1628701194,
        "last_edit_date": 1628717630,
        "question_id": 68746172,
        "body_markdown": "Using `jq` I can extract the data in this simple way as follows:\r\n\r\n```\r\nfind . -name &#39;*.jsonl&#39; | xargs -I {} jq &#39;[.data.Item_A_Foo.value, .data.Item_A_Bar.value] | @tsv&#39; &gt;&gt; foobar.tsv\r\nfind . -name &#39;*.jsonl&#39; | xargs -I {} jq &#39;[.data.Item_B_Foo.value, .data.Item_B_Bar.value] | @tsv&#39; &gt;&gt; foobar.tsv\r\nfind . -name &#39;*.jsonl&#39; | xargs -I {} jq &#39;[.data.Item_B_Foo.value, .data.Item_B_Bar.value] | @tsv&#39; &gt;&gt; foobar.tsv\r\n...\r\n# and so on\r\n```\r\n\r\nBut this seems pretty wasteful.  Is there a more advanced way to use JQ, and perhaps:\r\n\r\n - Filter for `.data.Item_*_Foo.value, .data.Item_*_Bar.value`\r\n - OR chain these rows in a single `jq` expression (reasonably readable, compact)\r\n\r\n~~~\r\n# Here is a made up JSON file that can motivate this question. \r\n# Imagine there are 100,000 of these and they are larger.\r\n\r\n{\r\n  &quot;data&quot;: \r\n  {\r\n    &quot;Item_A_Foo&quot;: {\r\n       &quot;adj&quot;: &quot;wild&quot;,\r\n       &quot;adv&quot;: &quot;unruly&quot;,\r\n       &quot;value&quot;: &quot;unknown&quot;\r\n    },\r\n    &quot;Item_A_Bar&quot;: {\r\n       &quot;adj&quot;: &quot;rotund&quot;,\r\n       &quot;quality&quot;: &quot;mighty&quot;,\r\n       &quot;value&quot;: &quot;swing&quot;\r\n    },\r\n    &quot;Item_B_Foo&quot;: {\r\n       &quot;adj&quot;: &quot;nice&quot;,\r\n       &quot;adv&quot;: &quot;heroically&quot;,\r\n       &quot;value&quot;: &quot;medium&quot;\r\n    },\r\n    ... etc. for many Foo&#39;s and Bar&#39;s of A, B, C, ..., Z types\r\n    &quot;Not_an_Item&quot;: {\r\n      &quot;value&quot;: &quot;doesn&#39;t matter&quot;\r\n    }\r\n}\r\n~~~\r\n\r\nAnd the goal is:\r\n\r\n```\r\nunknown, swing # data.Item_A_Foo.value, data.Item_A_Bar.value\r\nmedium, hit # data.Item_B_Foo.value, data.Item_B_Bar.value\r\nwhatever, etc. # data.Item_C_Foo.value, data.Item_C_Bar.value\r\n```",
        "link": "https://stackoverflow.com/questions/68746172/jq-from-one-json-input-construct-multiple-rows-of-tsv-using-an-expression-agai",
        "title": "jq: from one json input, construct multiple rows of tsv using an expression against the keys?"
    },
    {
        "tags": [
            "json",
            "select",
            "bigdata",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1628718577,
                "last_edit_date": 1628718577,
                "creation_date": 1628709184,
                "answer_id": 68747714,
                "question_id": 68747325,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just truncate the top-level array.\r\n``` shell\r\njq -n --stream &#39;fromstream(1 | truncate_stream(inputs)) | select(.type == &quot;user&quot;)&#39;\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/FbXdyy_xkI)&lt;/sup&gt;\r\n\r\n&lt;sup&gt;jqplay does not support the --stream option, so the above demo has the output of --stream as the JSON input.\r\n&lt;/sup&gt;\r\n\r\n",
                "title": "Expand large array and select elements in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1628718577,
        "creation_date": 1628706911,
        "last_edit_date": 1628717449,
        "question_id": 68747325,
        "body_markdown": "This may just not be possible due to how conceptually streaming/filtering JSON works, but let&#39;s suppose I have something like the following JSON:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;account_1&quot;,\r\n    &quot;type&quot;: &quot;account&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;account_2&quot;,\r\n    &quot;type&quot;: &quot;account&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;user_1&quot;,\r\n    &quot;type&quot;: &quot;user&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;user_2&quot;,\r\n    &quot;type&quot;: &quot;user&quot;\r\n  }\r\n]\r\n```\r\n\r\nAnd now I want to print out only the user objects.\r\n\r\nI know I can filter to just the streaming type entities with something like this:\r\n\r\n```\r\ncat file.json | jq --stream &#39;select(.[0][1] == &quot;type&quot; and .[1] == &quot;user&quot; | .)&#39;\r\n```\r\n\r\nWhich would produce:\r\n\r\n```\r\n[\r\n  [\r\n    2,\r\n    &quot;type&quot;\r\n  ],\r\n  &quot;user&quot;\r\n]\r\n[\r\n  [\r\n    3,\r\n    &quot;type&quot;\r\n  ],\r\n  &quot;user&quot;\r\n]\r\n```\r\n\r\nIs there any way I can print out the parent objects of those types instead of the type entities?  E.g. I&#39;d like to get out:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;user_1&quot;,\r\n    &quot;type&quot;: &quot;user&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;user_2&quot;,\r\n    &quot;type&quot;: &quot;user&quot;\r\n  }\r\n]\r\n```\r\n\r\nWithout streaming, this is a pretty straightforward exercise.  E.g.:\r\n```\r\ncat file.json | jq &#39;.[] | select(.type==&quot;user&quot;)&#39;\r\n```\r\n\r\nIn reality the actual input file is around 5GB, so I need to use streaming input, but I can&#39;t seem to get the jq syntax right with `--stream` enabled.  E.g.\r\n\r\n```\r\ncat file.json | jq --stream &#39;.[] | select(.type==&quot;user&quot;)&#39;\r\n```\r\n\r\nProduces:\r\n\r\n```\r\njq: error (at &lt;stdin&gt;:3): Cannot index array with string &quot;type&quot;\r\njq: error (at &lt;stdin&gt;:5): Cannot index array with string &quot;type&quot;\r\n...\r\n```\r\n\r\n(edited to include desired output)\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68747325/expand-large-array-and-select-elements-in-jq",
        "title": "Expand large array and select elements in JQ"
    },
    {
        "tags": [
            "r",
            "jq",
            "httr",
            "jsonlite",
            "rjson"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1628806696,
                "creation_date": 1628806696,
                "answer_id": 68764742,
                "question_id": 68764306,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Reading `?content`, you&#39;ll see\r\n\r\n```\r\n      as: desired type of output: &#39;raw&#39;, &#39;text&#39; or &#39;parsed&#39;. &#39;content&#39;\r\n          attempts to automatically figure out which one is most\r\n          appropriate, based on the content-type.\r\n```\r\n\r\nContinuing with their example,\r\n\r\n```r\r\nlibrary(httr)\r\nr &lt;- POST(&quot;http://httpbin.org/post&quot;, body = list(a = 1, b = 2))\r\nr\r\n# Response [http://httpbin.org/post]\r\n#   Date: 2021-08-12 22:15\r\n#   Status: 200\r\n#   Content-Type: application/json\r\n#   Size: 586 B\r\n# {\r\n#   &quot;args&quot;: {}, \r\n#   &quot;data&quot;: &quot;&quot;, \r\n#   &quot;files&quot;: {}, \r\n#   &quot;form&quot;: {\r\n#     &quot;a&quot;: &quot;1&quot;, \r\n#     &quot;b&quot;: &quot;2&quot;\r\n#   }, \r\n#   &quot;headers&quot;: {\r\n#     &quot;Accept&quot;: &quot;application/json, text/xml, application/xml, */*&quot;, \r\n# ...\r\n```\r\n\r\nThe &quot;normal&quot; use of `content` gives us the named list we&#39;re expecting:\r\n\r\n```r\r\nstr(content(r))\r\n# List of 8\r\n#  $ args   : Named list()\r\n#  $ data   : chr &quot;&quot;\r\n#  $ files  : Named list()\r\n#  $ form   :List of 2\r\n#   ..$ a: chr &quot;1&quot;\r\n#   ..$ b: chr &quot;2&quot;\r\n#  $ headers:List of 7\r\n#   ..$ Accept         : chr &quot;application/json, text/xml, application/xml, */*&quot;\r\n#   ..$ Accept-Encoding: chr &quot;deflate, gzip&quot;\r\n#   ..$ Content-Length : chr &quot;228&quot;\r\n#   ..$ Content-Type   : chr &quot;multipart/form-data; boundary=------------------------99386898172ff715&quot;\r\n#   ..$ Host           : chr &quot;httpbin.org&quot;\r\n#   ..$ User-Agent     : chr &quot;libcurl/7.64.1 r-curl/4.3 httr/1.4.1&quot;\r\n#   ..$ X-Amzn-Trace-Id: chr &quot;Root=1-61159d7a-55ef1d2f553f80fa4773ae03&quot;\r\n#  $ json   : NULL\r\n#  $ origin : chr &quot;172.254.236.28&quot;\r\n#  $ url    : chr &quot;http://httpbin.org/post&quot;\r\n```\r\n\r\nAnd we can use `as=&quot;text&quot;` to get the raw json text:\r\n\r\n```r\r\ncontent(r, as=&quot;text&quot;)\r\n# No encoding supplied: defaulting to UTF-8.\r\n# [1] &quot;{\\n  \\&quot;args\\&quot;: {}, \\n  \\&quot;data\\&quot;: \\&quot;\\&quot;, \\n  \\&quot;files\\&quot;: {}, \\n  \\&quot;form\\&quot;: {\\n    \\&quot;a\\&quot;: \\&quot;1\\&quot;, \\n    \\&quot;b\\&quot;: \\&quot;2\\&quot;\\n  }, \\n  \\&quot;headers\\&quot;: {\\n    \\&quot;Accept\\&quot;: \\&quot;application/json, text/xml, application/xml, */*\\&quot;, \\n    \\&quot;Accept-Encoding\\&quot;: \\&quot;deflate, gzip\\&quot;, \\n    \\&quot;Content-Length\\&quot;: \\&quot;228\\&quot;, \\n    \\&quot;Content-Type\\&quot;: \\&quot;multipart/form-data; boundary=------------------------99386898172ff715\\&quot;, \\n    \\&quot;Host\\&quot;: \\&quot;httpbin.org\\&quot;, \\n    \\&quot;User-Agent\\&quot;: \\&quot;libcurl/7.64.1 r-curl/4.3 httr/1.4.1\\&quot;, \\n    \\&quot;X-Amzn-Trace-Id\\&quot;: \\&quot;Root=1-61159d7a-55ef1d2f553f80fa4773ae03\\&quot;\\n  }, \\n  \\&quot;json\\&quot;: null, \\n  \\&quot;origin\\&quot;: \\&quot;172.254.236.28\\&quot;, \\n  \\&quot;url\\&quot;: \\&quot;http://httpbin.org/post\\&quot;\\n}\\n&quot;\r\n```\r\n\r\nWhile this is not pretty, it is exactly what the remote server returned: from http://httpbin.org, the `/post` endpoint returns:\r\n\r\n[![httpbin &quot;post&quot; return structure][1]][1]\r\n\r\nYou should be able to process this json with anything json-processor, including `jsonlite::fromJSON` (confirmed) and likely `rjson` and `jqr` (or even `jq` on the command-line after saving it to a text file).\r\n\r\n\r\n  [1]: https://i.sstatic.net/WyFBd.png",
                "title": "Best way to convert a list into a JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1629004810,
                "creation_date": 1629004810,
                "answer_id": 68788924,
                "question_id": 68764306,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following is an addendum to the answer given by @r2evans.\r\n\r\nEven though `content(r)` seems to be a JSON-encoded string, the jqr commands recognize it as JSON text, so that (when using jqr), there is no need to run it through jq&#39;s `fromjson` filter.  \r\n\r\nSo for example:\r\n\r\n```\r\n&gt; library(httr)\r\n&gt; library(jqr)\r\n&gt; r &lt;- GET(&quot;https://raw.githubusercontent.com/postmanlabs/httpbin/master/app.json&quot;)\r\n&gt; jq(content(r))\r\n{\r\n    &quot;name&quot;: &quot;httpbin&quot;,\r\n    &quot;description&quot;: &quot;HTTP Request &amp; Response Service, written in Python + Flask.&quot;,\r\n    &quot;repository&quot;: &quot;https://github.com/requests/httpbin&quot;,\r\n    &quot;website&quot;: &quot;https://httpbin.org&quot;,\r\n    &quot;logo&quot;: &quot;https://s3.amazonaws.com/f.cl.ly/items/333Y191Z2C0G2J3m3Y0b/httpbin.svg&quot;,\r\n    &quot;keywords&quot;: [\r\n        &quot;http&quot;,\r\n        &quot;rest&quot;,\r\n        &quot;API&quot;,\r\n        &quot;testing&quot;,\r\n        &quot;integration&quot;,\r\n        &quot;python&quot;,\r\n        &quot;flask&quot;\r\n    ],\r\n    &quot;addons&quot;: &quot;sentry&quot;\r\n}\r\n\r\n&gt; jq(content(r), &quot;.name&quot;)\r\n&quot;httpbin&quot;\r\n```",
                "title": "Best way to convert a list into a JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1629004810,
        "creation_date": 1628803312,
        "last_edit_date": 1628806735,
        "question_id": 68764306,
        "body_markdown": "I have a script that looks something like this (though not exactly because I obviously can&#39;t give my API key and what not to make it fully repoducible)\r\n\r\n    library(tidyverse)\r\n    library(dplyr)\r\n    library(httr)\r\n    library(civis)\r\n    library(rjson)\r\n    library(jqr)\r\n    \r\n    record &lt;- GET(\r\n      &#39;https://api.secure.com/v4/data&#39;,\r\n      accept_json(),\r\n      add_headers(Accept = &#39;application/json&#39;,\r\n                  Authorization = VanAPI)\r\n    )\r\n\r\n`record` then produces a list that looks something like this:\r\n\r\n    Response [https://api.secure.com/v4/data]\r\n      Date: 2021-08-12 20:54\r\n      Status: 200\r\n      Content-Type: application/json; charset=utf-8\r\n      Size: 873 B\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;playerId&quot;: 12827,\r\n          &quot;name&quot;: &quot;Player Tiers&quot;,\r\n          &quot;type&quot;: &quot;Dynamic&quot;,\r\n          &quot;description&quot;: null,\r\n          &quot;points&quot;: 249,\r\n          &quot;areSubgroupsSticky&quot;: false,\r\n          &quot;status&quot;: &quot;Active&quot;,\r\n    ...\r\n\r\nWhat is the best way to convert this to a JSON that I can then apply the `jqr` package to?\r\n\r\nRight now I&#39;m doing:\r\n\r\n    test &lt;- content(record)\r\n\r\nWhich produces this output:\r\n\r\n    $items\r\n    $items[[1]]\r\n    $items[[1]]$playerId\r\n    [1] 12827\r\n    \r\n    $items[[1]]$name\r\n    [1] &quot;Player Tiers&quot;\r\n    \r\n    $items[[1]]$type\r\n    [1] &quot;Dynamic&quot;\r\n    \r\n    $items[[1]]$description\r\n    NULL\r\n    \r\n    $items[[1]]$points\r\n    [1] 249\r\n    \r\n    $items[[1]]$areSubgroupsSticky\r\n    [1] FALSE\r\n    \r\n    $items[[1]]$status\r\n    [1] &quot;Active&quot;\r\n    \r\n    $items[[1]]$subgroups\r\n    NULL\r\n    \r\n    $items[[1]]$markedSubgroup\r\n    NULL\r\n    \r\n    \r\n    $items[[2]]\r\n    $items[[2]]$playerId\r\n    [1] 15723\r\n    \r\n    $items[[2]]$name\r\n    [1] &quot;Team Tiers&quot;\r\n    \r\n    $items[[2]]$type\r\n    [1] &quot;Dynamic&quot;\r\n    \r\n    $items[[2]]$description\r\n    NULL\r\n    \r\n    $items[[2]]$points\r\n    [1] 35\r\n    \r\n    $items[[2]]$areSubgroupsSticky\r\n    [1] FALSE\r\n    \r\n    $items[[2]]$status\r\n    [1] &quot;Active&quot;\r\n    \r\n    $items[[2]]$subgroups\r\n    NULL\r\n    \r\n    $items[[2]]$markedSubgroup\r\n    NULL\r\n    \r\n    \r\n    $items[[3]]\r\n    $items[[3]]$playerId\r\n    [1] 16620\r\n    \r\n    $items[[3]]$name\r\n    [1] &quot;Coaches Tiers&quot;\r\n    \r\n    $items[[3]]$type\r\n    [1] &quot;Dynamic&quot;\r\n    \r\n    $items[[3]]$description\r\n    NULL\r\n    \r\n    $items[[3]]$points\r\n    [1] 12\r\n    \r\n    $items[[3]]$areSubgroupsSticky\r\n    [1] FALSE\r\n    \r\n    $items[[3]]$status\r\n    [1] &quot;Active&quot;\r\n    \r\n    $items[[3]]$subgroups\r\n    NULL\r\n    \r\n    $items[[3]]$markedSubgroup\r\n    NULL\r\n    \r\n    \r\n    \r\n    $nextPageLink\r\n    NULL\r\n    \r\n    $count\r\n    [1] 3\r\n\r\nBut then I try to convert it to a JSON using `test2 &lt;- rjson::toJSON(test)` but that produces this:\r\n\r\n    [1] &quot;{\\&quot;items\\&quot;:[{\\&quot;playerId\\&quot;:12827,\\&quot;name\\&quot;:\\&quot;Player Tiers\\&quot;,\\&quot;type\\&quot;:\\&quot;Dynamic\\&quot;,\\&quot;description\\&quot;:null,\\&quot;points\\&quot;:249,\\&quot;areSubgroupsSticky\\&quot;:false,\\&quot;status\\&quot;:\\&quot;Active\\&quot;,\\&quot;subgroups\\&quot;:null,\\&quot;markedSubgroup\\&quot;:null},{\\&quot;playerId\\&quot;:15723,\\&quot;name\\&quot;:\\&quot;Team Tiers\\&quot;,\\&quot;type\\&quot;:\\&quot;Dynamic\\&quot;,\\&quot;description\\&quot;:null,\\&quot;points\\&quot;:35,\\&quot;areSubgroupsSticky\\&quot;:false,\\&quot;status\\&quot;:\\&quot;Active\\&quot;,\\&quot;subgroups\\&quot;:null,\\&quot;markedSubgroup\\&quot;:null},{\\&quot;playerId\\&quot;:16620,\\&quot;name\\&quot;:\\&quot;Coaches Tiers\\&quot;,\\&quot;type\\&quot;:\\&quot;Dynamic\\&quot;,\\&quot;description\\&quot;:null,\\&quot;points\\&quot;:12,\\&quot;areSubgroupsSticky\\&quot;:false,\\&quot;status\\&quot;:\\&quot;Active\\&quot;,\\&quot;subgroups\\&quot;:null,\\&quot;markedSubgroup\\&quot;:null}],\\&quot;nextPageLink\\&quot;:null,\\&quot;count\\&quot;:3}&quot;\r\n\r\nIs there a better way to get an easy, clean JSON output?",
        "link": "https://stackoverflow.com/questions/68764306/best-way-to-convert-a-list-into-a-json",
        "title": "Best way to convert a list into a JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1629210225,
                "creation_date": 1629210225,
                "answer_id": 68819110,
                "question_id": 68818940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Select objects, not fields.\r\n```\r\n.[] | select(.size &gt; 1000) | [.name, .size] | join(&quot;,&quot;)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/0jQ_nl38Iu)&lt;/sup&gt;",
                "title": "Produce output for values greater than n and ignore the rest in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1629210783,
        "creation_date": 1629209591,
        "last_edit_date": 1629210783,
        "question_id": 68818940,
        "body_markdown": "I am trying to display only lines with second value greater than 1000. The original JQ program I am using to display everything is:\r\n``` shell\r\njq -r &#39;.[] | [.name, .size] | join(&quot;,&quot;)&#39; file.json\r\n```\r\nThis gives me:\r\n```\r\nname1,1024\r\nname2,300\r\nname3,512\r\n```\r\nIf I select values only greater than 1000:\r\n```\r\njq -r &#39;.[] | [.name, .size | select(. &gt; 1000)] | join(&quot;,&quot;)&#39; file.json\r\n```\r\nthen I am getting:\r\n```\r\nname1,1024\r\nname2\r\nname3\r\n```\r\nHow can I discard lines with size less than 1000?",
        "link": "https://stackoverflow.com/questions/68818940/produce-output-for-values-greater-than-n-and-ignore-the-rest-in-jq",
        "title": "Produce output for values greater than n and ignore the rest in JQ"
    },
    {
        "tags": [
            "json",
            "linux",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 5,
                "creation_date": 1629218576,
                "post_id": 68820793,
                "comment_id": 121627141,
                "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": 2,
                "creation_date": 1629221381,
                "post_id": 68820793,
                "comment_id": 121628156,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1629238851,
                "creation_date": 1629238851,
                "answer_id": 68824637,
                "question_id": 68820793,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the absence of further information, you might consider a &quot;global search and replace&quot; on strings (apart from keys):\r\n\r\n    walk(if type == &quot;string&quot; \r\n         then sub(&quot;DB_SERVER_CV02[.]localdomain&quot;; &quot;APP_SERVER_CV02.localdomain&quot;) \r\n         else . end)\r\n\r\nYou may wish to tweak the `sub` command (or change it to `gsub`), depending on your actual requirements.\r\n\r\n(You could include the above `walk` program on the command line, but I&#39;d recommend putting it into a file and using jq with the -f option.)\r\n\r\nIf you want to change all occurrences, even in keys, then you might be able to use `sed`, but you could also use jq with `walk` along the lines shown above but using `with_entries` for the keys. Since you haven&#39;t specifically mentioned this, though, it can perhaps be left as an exercise.",
                "title": "jq + what is the right approach to replace word that retruned 56 times in json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1629238851,
        "creation_date": 1629216880,
        "question_id": 68820793,
        "body_markdown": "we have the following `json` file ( example with `grep` )\r\n\r\n    grep DB_SERVER_CV02.localdomain /home/main.json\r\n\r\n     &quot;hadoop.proxyuser.ambari.hosts&quot;: &quot;DB_SERVER_CV02.localdomain&quot;,\r\n                        &quot;yarn.timeline-service.http-authentication.proxyuser.ambari.hosts&quot;: &quot;DB_SERVER_CV02.localdomain&quot;,\r\n                        &quot;timeline.metrics.service.webapp.address&quot;: &quot;DB_SERVER_CV02.localdomain:6188&quot;,\r\n                        &quot;javax.jdo.option.ConnectionURL&quot;: &quot;jdbc:postgresql://DB_SERVER_CV02.localdomain:5432/hive&quot;,\r\n                        &quot;webhcat.proxyuser.ambari.hosts&quot;: &quot;DB_SERVER_CV02.localdomain&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\t\t.\r\n    \t\t\t\t\t.\r\n    \t\t\t\t\t\r\n\r\n`DB_SERVER_CV02.localdomain` word appears more then 56 times in the `main.json` file\r\n\t\t\t\t\t\r\nand we want to replace the `DB_SERVER_CV02.localdomain` with `APP_SERVER_CV02.localdomain` name\r\n\t\t\t\t\t\r\n\t\t\t\t\t\r\nthe easy way is just to do it with `sed` as\r\n\t\t\t\t\t\r\n\t\t\t\t\t\r\n\t\t\t\tsed -i s&#39;/DB_SERVER_CV02.localdomain/APP_SERVER_CV02.localdomain/g&#39; /home/main.json\r\n\t\t\t\t\t\r\n\t\t\t\t\t\r\nbut as I understand better to works with `jq` when dealing with `json` files\r\n\t\t\t\t\t\r\n\t\t\t\t\t\r\nwhat is the right approach to replace the `DB_SERVER_CV02.localdomain` with `APP_SERVER_CV02.localdomain` with `jq` ?",
        "link": "https://stackoverflow.com/questions/68820793/jq-what-is-the-right-approach-to-replace-word-that-retruned-56-times-in-json",
        "title": "jq + what is the right approach to replace word that retruned 56 times in json"
    },
    {
        "tags": [
            "jenkins",
            "jq",
            "aws-cli",
            "amazon-emr",
            "jenkins-groovy"
        ],
        "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": 1629239054,
                "post_id": 68820930,
                "comment_id": 121633465,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1629239395,
                "creation_date": 1629239395,
                "answer_id": 68824714,
                "question_id": 68820930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is rarely a good idea to pass environment variables using string-interpolation. There are much better ways.\r\n\r\nOne you might consider is modifying your invocation of jq as follows:\r\n\r\n    jq -r --arg env &quot;${ENV}&quot; &#39;.Clusters[] | select (.Name==&quot;\\($env)-emr-cluster&quot;) | .Id&#39;\r\n\r\nHere, `$env` is an ordinary jq variable, or more accurately perhaps, a defined constant.",
                "title": "Cannot render groovy sh script with environmental variable that uses jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1629460100,
                "creation_date": 1629460100,
                "answer_id": 68861740,
                "question_id": 68820930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After realising that the jenkins snippet generator was actually useful I used this:\r\n```\r\nsh &#39;&#39;&#39;jq -r --arg env &quot;${ENV}&quot; \\&#39;.Clusters[] | select (.Name==&quot;\\\\($env)-emr-cluster&quot;) | .Id\\&#39; &#39;&#39;&#39;\r\n```\r\nand it worked!",
                "title": "Cannot render groovy sh script with environmental variable that uses jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1629460100,
        "creation_date": 1629217530,
        "last_edit_date": 1629219164,
        "question_id": 68820930,
        "body_markdown": "I have this line here that is inside of a groovy function and i am trying to return a cluster ID\r\n```\r\nEMR_ID = sh(returnStdout: true, script: &quot;aws emr list-clusters --active --profile \\&#39;${PROFILE}\\&#39; | jq -r &#39;.Clusters[] | select (.Name==&quot;\\&#39;${ENV}\\&#39;-emr-cluster&quot;) | .Id&#39;&quot;)\r\n```\r\n\r\nWithout the environmental variables, this works fine. \r\nso the $PROFILE param is set to dev and the $ENV is set to aws-dev. \r\n\r\nI keep getting the error that complains about the $ENV var, saying that an unexpected bracket is showing up",
        "link": "https://stackoverflow.com/questions/68820930/cannot-render-groovy-sh-script-with-environmental-variable-that-uses-jq",
        "title": "Cannot render groovy sh script with environmental variable that uses jq"
    },
    {
        "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": 1629220123,
                "post_id": 68821217,
                "comment_id": 121627674,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18713405,
                    "reputation": 71,
                    "user_id": 13643010,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e406512908c01c31200d0d70f57017fd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Balu Virigineni",
                    "link": "https://stackoverflow.com/users/13643010/balu-virigineni"
                },
                "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": 1629222582,
                "post_id": 68821217,
                "comment_id": 121628582,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1629224835,
                "creation_date": 1629224835,
                "answer_id": 68822361,
                "question_id": 68821217,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just walk the path from the root and use the update operator `|=` with the filter wrapped around `(..)`\r\n\r\n```none\r\n( \r\n  .spec.rules[]                             | \r\n  select(.host == &quot;test4.analytics.io&quot;)?    | \r\n  .http.paths[].backend                     | \r\n  select(.serviceName == &quot;ca-visual-node&quot;)? |\r\n  .serviceName\r\n)  |= &quot;ca-visual-node-canary&quot;\r\n```\r\n\r\n&lt;sup&gt;[jqplay - demo][1]&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://jqplay.org/s/5WeffO4PAK",
                "title": "How to search for a string inside an object and replace it with another value on a condition"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1629228014,
        "creation_date": 1629218887,
        "last_edit_date": 1629228014,
        "question_id": 68821217,
        "body_markdown": "I have a Json file with below content, I am trying to replace serviceName string from *ca-visual-node* to *ca-visual-node-canary*  if host name matches **test4.analytics.io** using jq utility. How can I get this done so that we will have json file updated with replace string \r\n\r\n```\r\n\r\n{\r\n    &quot;apiVersion&quot;: &quot;extensions/v1beta1&quot;,\r\n    &quot;kind&quot;: &quot;Ingress&quot;,\r\n    &quot;metadata&quot;: {\r\n        &quot;annotations&quot;: {\r\n            &quot;alb.ingress.kubernetes.io/actions.ssl-redirect&quot;: &quot;{\\&quot;Type\\&quot;: \\&quot;redirect\\&quot;, \\&quot;RedirectConfig\\&quot;: { \\&quot;Protocol\\&quot;: \\&quot;HTTPS\\&quot;, \\&quot;Port\\&quot;: \\&quot;443\\&quot;, \\&quot;StatusCode\\&quot;: \\&quot;HTTP_301\\&quot;}}&quot;\r\n     },\r\n        &quot;finalizers&quot;: [\r\n            &quot;ingress.k8s.aws/resources&quot;\r\n        ],\r\n        &quot;name&quot;: &quot;ca-visual&quot;,\r\n        &quot;namespace&quot;: &quot;cloud-anaytics&quot;,\r\n    },\r\n    &quot;spec&quot;: {\r\n        &quot;rules&quot;: [\r\n            {\r\n                &quot;host&quot;: &quot;test.analytics.io&quot;,\r\n                &quot;http&quot;: {\r\n                    &quot;paths&quot;: [\r\n                        {\r\n                            &quot;backend&quot;: {\r\n                                &quot;serviceName&quot;: &quot;ca-visual-play&quot;,\r\n                                &quot;servicePort&quot;: 9443\r\n                            },\r\n                            &quot;path&quot;: &quot;/apii/*&quot;,\r\n                            &quot;pathType&quot;: &quot;ImplementationSpecific&quot;\r\n                        },\r\n                        {\r\n                            &quot;backend&quot;: {\r\n                                &quot;serviceName&quot;: &quot;ssl-redirect&quot;,\r\n                                &quot;servicePort&quot;: &quot;use-annotation&quot;\r\n                            },\r\n                            &quot;path&quot;: &quot;/*&quot;,\r\n                            &quot;pathType&quot;: &quot;ImplementationSpecific&quot;\r\n                        },\r\n                        {\r\n                            &quot;backend&quot;: {\r\n                                &quot;serviceName&quot;: &quot;ca-visual-node&quot;,\r\n                                &quot;servicePort&quot;: 443\r\n                            },\r\n                            &quot;path&quot;: &quot;/*&quot;,\r\n                            &quot;pathType&quot;: &quot;ImplementationSpecific&quot;\r\n                        }\r\n                    ]\r\n                }\r\n            },\r\n            {\r\n                &quot;host&quot;: &quot;test4.analytics.io&quot;,\r\n                &quot;http&quot;: {\r\n                    &quot;paths&quot;: [\r\n                        {\r\n                            &quot;backend&quot;: {\r\n                                &quot;serviceName&quot;: &quot;ca-visual-play&quot;,\r\n                                &quot;servicePort&quot;: 9443\r\n                            },\r\n                            &quot;path&quot;: &quot;/apii/*&quot;,\r\n                            &quot;pathType&quot;: &quot;ImplementationSpecific&quot;\r\n                        },\r\n                        {\r\n                            &quot;backend&quot;: {\r\n                                &quot;serviceName&quot;: &quot;ssl-redirect&quot;,\r\n                                &quot;servicePort&quot;: &quot;use-annotation&quot;\r\n                            },\r\n                            &quot;path&quot;: &quot;/*&quot;,\r\n                            &quot;pathType&quot;: &quot;ImplementationSpecific&quot;\r\n                        },\r\n                        {\r\n                            &quot;backend&quot;: {\r\n                                &quot;serviceName&quot;: &quot;ca-visual-node&quot;,\r\n                                &quot;servicePort&quot;: 443\r\n                            },\r\n                            &quot;path&quot;: &quot;/*&quot;,\r\n                            &quot;pathType&quot;: &quot;ImplementationSpecific&quot;\r\n                        }\r\n                    ]\r\n                }\r\n            }\r\n        ]\r\n    },\r\n    &quot;status&quot;: {\r\n        &quot;loadBalancer&quot;: {\r\n            &quot;ingress&quot;: [\r\n                {\r\n                    &quot;hostname&quot;: &quot;16b3-cloudanaytics.us-xxxx-1.elb.amazonaws.com&quot;\r\n                }\r\n            ]\r\n        }\r\n    }\r\n}\r\n```\r\nI am trying to replace serviceName string from *ca-visual-node* to *ca-visual-node-canary*  if host name matches **test4.analytics.io** using jq utility. How can I get this done so that we will have json file updated with replace string.\r\n",
        "link": "https://stackoverflow.com/questions/68821217/how-to-search-for-a-string-inside-an-object-and-replace-it-with-another-value-on",
        "title": "How to search for a string inside an object and replace it with another value on a condition"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "edit"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1363360,
                    "reputation": 3513,
                    "user_id": 1300307,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/a2dba3553c4bc2a1eb9c73278df0cf66?s=256&d=identicon&r=PG",
                    "display_name": "Friedrich &#39;Fred&#39; Clausen",
                    "link": "https://stackoverflow.com/users/1300307/friedrich-fred-clausen"
                },
                "reply_to_user": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629252750,
                "post_id": 68825303,
                "comment_id": 121635542,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1629250376,
                "creation_date": 1629250376,
                "answer_id": 68825597,
                "question_id": 68825303,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like `map` would do the trick, and you might also consider `keys_unsorted`:\r\n\r\n    with_entries( .key |= ascii_downcase )\r\n    | keys_unsorted | map(sub(&quot;version$&quot;; &quot;&quot;))\r\n\r\nOf course, there are other approaches....\r\n\r\nIf you wanted to retain the original structure:\r\n\r\n    with_entries( .key |= (ascii_downcase | sub(&quot;version$&quot;;&quot;&quot;)))\r\n\r\n\r\n",
                "title": "String substitution on array of strings"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1629265157,
        "creation_date": 1629245976,
        "last_edit_date": 1629265157,
        "question_id": 68825303,
        "body_markdown": "I am trying to strip a substring from an array of strings; this array is obtained as a key set from a map. Some example incoming data:\r\n\r\n```\r\n{\r\n  &quot;appOneVersion&quot;: &quot;1.0&quot;,\r\n  &quot;appTwoVersion&quot;: &quot;1.0&quot;,\r\n  &quot;appThreeVersion&quot;: &quot;1.0&quot;\r\n}\r\n```\r\n\r\nFirst I&#39;m extracting the key set and making lower case which works:\r\n\r\n```\r\n $ jq -r &#39;with_entries( .key |= ascii_downcase) | keys&#39; example.json\r\n[\r\n  &quot;apponeversion&quot;,\r\n  &quot;appthreeversion&quot;,\r\n  &quot;apptwoversion&quot;\r\n]\r\n```\r\n\r\nand then I&#39;m attempting to strip the `version` part of each element with `sub(&quot;version$&quot;; &quot;&quot;)` however I&#39;m not quite understanding how to make it iterate over the array instead of `sub` trying to operate on the array as a whole:\r\n\r\n```\r\n$ jq -r &#39;with_entries( .key |= ascii_downcase) | keys | sub(&quot;version$&quot;; &quot;&quot;)&#39; example.json\r\njq: error (at example.json:5): array ([&quot;apponever...) cannot be matched, as it is not a string\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/68825303/string-substitution-on-array-of-strings",
        "title": "String substitution on array of strings"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1629356081,
                "creation_date": 1629356081,
                "answer_id": 68843257,
                "question_id": 68828666,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward solution that keeps things simple by using two steps:\r\n```\r\n{ region, user_id} + (.event_array[] )\r\n| if .event_attributes|has(&quot;array_within_array&quot;)\r\n  then .event_attributes.array_within_array as $a\r\n  | .event_attributes = $a[]\r\n  else .\r\n  end\r\n``` ",
                "title": "Moving a JSON array which have another array elements to the same LEVEL"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1629356081,
        "creation_date": 1629274007,
        "last_edit_date": 1629288217,
        "question_id": 68828666,
        "body_markdown": "\r\nI have the following JSON which have an element ***array_within_array*** in another array. So I want to pull both ***array_within_array*** element and upper array element(***event_array***) to root level using **jq**.\r\nSo here there are 3 events.\r\n\r\n 1. meal_selection\r\n 2. login\r\n 3. placed_order\r\n\r\nEvent ***placed_order*** have two sub-events in array. So after conversion there should be 4 events(1 from ***meal_selection***, 1 from ***login*** and 2 from ***placed_order***). these all should be on the same level.\r\nHere is the JSON\r\n\r\n    {\r\n    \t&quot;region&quot;: &quot;USA&quot;,\r\n    \t&quot;user_id&quot;: &quot;123&quot;,\r\n    \t&quot;event_array&quot;: [{\r\n    \t\t\t&quot;event_attributes&quot;: {\r\n    \t\t\t\t&quot;date&quot;: &quot;2021-08-17&quot;,\r\n    \t\t\t\t&quot;category&quot;: &quot;lunch&quot;,\r\n    \t\t\t\t&quot;location&quot;: &quot;office&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;event_name&quot;: &quot;meal_selection&quot;,\r\n    \t\t\t&quot;created_at&quot;: &quot;2021-08-13 01:28:57&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;event_name&quot;: &quot;login&quot;,\r\n    \t\t\t&quot;created_at&quot;: &quot;2021-08-13 01:29:02&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;event_attributes&quot;: {\r\n    \t\t\t\t&quot;array_within_array&quot;: [\r\n    \t\t\t\t\t{\r\n    \t\t\t\t&quot;date&quot;: &quot;2021-08-17&quot;,\r\n    \t\t\t\t&quot;category&quot;: &quot;lunch&quot;,\r\n    \t\t\t\t&quot;location&quot;: &quot;office&quot;\r\n    \t\t\t\t\t},\r\n    \t\t\t\t\t{\r\n    \t\t\t\t&quot;date&quot;: &quot;2021-08-18&quot;,\r\n    \t\t\t\t&quot;category&quot;: &quot;dinner&quot;,\r\n    \t\t\t\t&quot;location&quot;: &quot;home&quot;\r\n    \t\t\t\t\t}\r\n    \t\t\t\t]\r\n    \t\t\t},\r\n    \t\t\t&quot;event_name&quot;: &quot;placed_order&quot;,\r\n    \t\t\t&quot;created_at&quot;: &quot;2021-08-13 01:28:08&quot;\r\n    \t\t}\r\n    \t\t]\r\n    }\r\n\r\nand I want to convert to the below one\r\n\r\n    {\r\n      &quot;region&quot;: &quot;USA&quot;,\r\n      &quot;user_id&quot;: &quot;123&quot;,\r\n      &quot;event_attributes&quot;: {\r\n        &quot;date&quot;: &quot;2021-08-17&quot;,\r\n        &quot;category&quot;: &quot;lunch&quot;,\r\n        &quot;location&quot;: &quot;office&quot;\r\n      },\r\n      &quot;event_name&quot;: &quot;meal_selection&quot;,\r\n      &quot;created_at&quot;: &quot;2021-08-13 01:28:57&quot;\r\n    }\r\n    {\r\n      &quot;region&quot;: &quot;USA&quot;,\r\n      &quot;user_id&quot;: &quot;123&quot;,\r\n      &quot;event_name&quot;: &quot;login&quot;,\r\n      &quot;created_at&quot;: &quot;2021-08-13 01:29:02&quot;\r\n    }\r\n    {\r\n      &quot;region&quot;: &quot;USA&quot;,\r\n      &quot;user_id&quot;: &quot;123&quot;,\r\n      &quot;event_attributes&quot;: {\r\n        &quot;date&quot;: &quot;2021-08-17&quot;,\r\n        &quot;category&quot;: &quot;lunch&quot;,\r\n        &quot;location&quot;: &quot;office&quot;\r\n      },\r\n      &quot;event_name&quot;: &quot;placed_order&quot;,\r\n      &quot;created_at&quot;: &quot;2021-08-13 01:28:08&quot;\r\n    }\r\n    {\r\n      &quot;region&quot;: &quot;USA&quot;,\r\n      &quot;user_id&quot;: &quot;123&quot;,\r\n      &quot;event_attributes&quot;: {\r\n        &quot;date&quot;: &quot;2021-08-18&quot;,\r\n        &quot;category&quot;: &quot;dinner&quot;,\r\n        &quot;location&quot;: &quot;home&quot;\r\n      },\r\n      &quot;event_name&quot;: &quot;placed_order&quot;,\r\n      &quot;created_at&quot;: &quot;2021-08-13 01:28:08&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/68828666/moving-a-json-array-which-have-another-array-elements-to-the-same-level",
        "title": "Moving a JSON array which have another array elements to the same LEVEL"
    },
    {
        "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": 1629287212,
                "post_id": 68829796,
                "comment_id": 121645588,
                "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": 1629287254,
                "post_id": 68829796,
                "comment_id": 121645612,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8085207,
                    "reputation": 669,
                    "user_id": 6691469,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c6658a78697364569a8c583818bb4c77?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "DisplayName",
                    "link": "https://stackoverflow.com/users/6691469/displayname"
                },
                "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": 1629288125,
                "post_id": 68829796,
                "comment_id": 121645944,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1629287830,
                "creation_date": 1629287830,
                "answer_id": 68831903,
                "question_id": 68829796,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq -r &#39;[.[] | {name, size}] | sort_by(.size) | [.[][]] | join(&quot;,&quot;)&#39;",
                "title": "Produce output from JSON for values and sort them by number"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1629287830,
        "creation_date": 1629278932,
        "last_edit_date": 1629279185,
        "question_id": 68829796,
        "body_markdown": "I have a jq query to get two values from the JSON file:\r\n`jq -r &#39;.[] | [.name, .size] | join(&quot;,&quot;)&#39; file.json`\r\nThis gives me an output like:\r\n```\r\nname1,1024\r\nname2,300\r\nname3,512\r\n```\r\nWhat I want is to sort them by number. I&#39;ve tried to pipe the query by `| sort_by(.size | tonumber)` but it always fail on `Cannot iterate over string (&quot;name1,1024&quot;)`\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68829796/produce-output-from-json-for-values-and-sort-them-by-number",
        "title": "Produce output from JSON for values and sort them by number"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629279204,
                "post_id": 68829823,
                "comment_id": 121642483,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1738264,
                    "reputation": 97,
                    "user_id": 4190789,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/79852257ecb9260515cf6c8022cacf62?s=256&d=identicon&r=PG",
                    "display_name": "Dave Shaw",
                    "link": "https://stackoverflow.com/users/4190789/dave-shaw"
                },
                "reply_to_user": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629280544,
                "post_id": 68829823,
                "comment_id": 121643021,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629295145,
                "post_id": 68829823,
                "comment_id": 121649249,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1629279004,
        "creation_date": 1629279004,
        "question_id": 68829823,
        "body_markdown": "I&#39;ve searched for this and I while I&#39;m sure its simple, I can&#39;t seem to get this to work.\r\nI need to loop through the JSON below in bash\r\n\r\n    {\r\n        &quot;data&quot;:\r\n        [\r\n            {\r\n                &quot;seen&quot;: true,\r\n                &quot;id&quot;: &quot;2079a988-f856-4adb-bd3d-49ddf775ba16-1629277814281&quot;,\r\n                &quot;tinyId&quot;: &quot;17290&quot;,\r\n                &quot;status&quot;: &quot;closed&quot;,\r\n                &quot;acknowledged&quot;: false,\r\n                &quot;isSeen&quot;: true\r\n            },\r\n            {\r\n                &quot;seen&quot;: false,\r\n                &quot;id&quot;: &quot;0a6e6024-9e80-42d2-ae4f-4b4af4a25fd2-1629277649193&quot;,\r\n                &quot;tinyId&quot;: &quot;17289&quot;,\r\n                &quot;status&quot;: &quot;open&quot;,\r\n                &quot;acknowledged&quot;: false,\r\n                &quot;isSeen&quot;: false\r\n            },\r\n            {\r\n                &quot;seen&quot;: false,\r\n                &quot;id&quot;: &quot;108370f4-f54e-443d-9b7c-eec9d641c69a-1629277622211&quot;,\r\n                &quot;tinyId&quot;: &quot;17288&quot;,\r\n                &quot;status&quot;: &quot;open&quot;,\r\n                &quot;acknowledged&quot;: false,\r\n                &quot;isSeen&quot;: false\r\n            }\r\n        ]\r\n    }\r\n\r\nThe loop needs to read all the fields, so I can pass them to variables and check their values.\r\n\r\nI&#39;ve been trying with JQ and have tried \r\n\r\n    for x in &quot;${json}&quot;; do &lt;something with &quot;${x}&quot;&gt;; done\r\n\r\nand also \r\n\r\n    for x in &quot;$(jq -r . &lt;&lt;&lt; &quot;${json}&quot;); do &lt;something with &quot;${x}&quot;&gt;; done\r\n\r\nbut it seems the output is not splitting.\r\n\r\nThanks,\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68829823/looping-through-json-data-with-bash-to-check-values",
        "title": "Looping through JSON data with bash to check values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1629295912,
                "creation_date": 1629295912,
                "answer_id": 68834055,
                "question_id": 68833834,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try:\r\n```\r\n.Statement|=map(select([.Principal.AWS]|flatten|all(.!=&quot;KEY1&quot;)))\r\n```\r\nThe `[.Principal.AWS]|flatten` bit does what you want to ensure you have a list of strings and not a single string. `all(.!=&quot;KEY1&quot;)` tests to make sure &quot;KEY1&quot; is not in the list. `map(select(...))` keeps only the statements that match the test.",
                "title": "Inner select on json when key is either string or array?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1629298079,
        "creation_date": 1629295109,
        "question_id": 68833834,
        "body_markdown": "I&#39;m working with AWS S3 policy, where I get this JSON back (white washed):\r\n\r\n    {\r\n      &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n      &quot;Statement&quot;: [\r\n        {\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: [\r\n              &quot;arn1&quot;,\r\n              &quot;arn2&quot;,\r\n              &quot;arn3&quot;\r\n            ]\r\n          },\r\n          &quot;Action&quot;: [\r\n            &quot;access1&quot;,\r\n            &quot;access2&quot;,\r\n            &quot;access3&quot;\r\n          ],\r\n          &quot;Resource&quot;: &quot;arn:aws:s3:::bucket1/*&quot;\r\n        },\r\n        {\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: [\r\n              &quot;arn1&quot;,\r\n              &quot;arn2&quot;,\r\n              &quot;arn3&quot;\r\n            ]\r\n          },\r\n          &quot;Action&quot;: &quot;access4&quot;,\r\n          &quot;Resource&quot;: &quot;arn:aws:s3:::bucket1&quot;\r\n        },\r\n        {\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: &quot;KEY1&quot;\r\n          },\r\n          &quot;Action&quot;: [\r\n            &quot;access5&quot;,\r\n            &quot;access4&quot;\r\n          ],\r\n          &quot;Resource&quot;: &quot;arn:aws:s3:::bucket1&quot;\r\n        },\r\n        {\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: &quot;KEY1&quot;\r\n          },\r\n          &quot;Action&quot;: [\r\n            &quot;access2&quot;,\r\n            &quot;access3&quot;,\r\n            &quot;access1&quot;\r\n          ],\r\n          &quot;Resource&quot;: &quot;arn:aws:s3:::bucket1/directory/*&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI need to filter out those two (last) arrays which have &#39;AWS: KEY1&#39;, leaving only the first two (which have &#39;AWS: [arnX]&#39;.\r\n\r\nAs in, this is what I want/need:\r\n\r\n    {\r\n      &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n      &quot;Statement&quot;: [\r\n        {\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: [\r\n              &quot;arn1&quot;,\r\n              &quot;arn2&quot;,\r\n              &quot;arn3&quot;\r\n            ]\r\n          },\r\n          &quot;Action&quot;: [\r\n            &quot;access1&quot;,\r\n            &quot;access2&quot;,\r\n            &quot;access3&quot;\r\n          ],\r\n          &quot;Resource&quot;: &quot;arn:aws:s3:::bucket1/*&quot;\r\n        },\r\n        {\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: [\r\n              &quot;arn1&quot;,\r\n              &quot;arn2&quot;,\r\n              &quot;arn3&quot;\r\n            ]\r\n          },\r\n          &quot;Action&quot;: &quot;access4&quot;,\r\n          &quot;Resource&quot;: &quot;arn:aws:s3:::bucket1&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nBut I can&#39;t figure out how to do this! The &#39;AWS&#39; is *either* a string *or* an array in the same JSON! No idea how to deal with both at the same time..\r\n\r\nI&#39;ve tried converting it to an array using `flatten`, but can&#39;t seem to select() on it. OR, then return the whole JSON (without the part I don&#39;t want).\r\n\r\n    $ cat /tmp/y | jq &#39;.Statement[].Principal.AWS | [.] | flatten&#39;\r\n    [\r\n      &quot;arn1&quot;,\r\n      &quot;arn2&quot;,\r\n      &quot;arn3&quot;\r\n    ]\r\n    [\r\n      &quot;arn1&quot;,\r\n      &quot;arn2&quot;,\r\n      &quot;arn3&quot;\r\n    ]\r\n    [\r\n      &quot;KEY1&quot;\r\n    ]\r\n    [\r\n      &quot;KEY1&quot;\r\n    ]",
        "link": "https://stackoverflow.com/questions/68833834/inner-select-on-json-when-key-is-either-string-or-array",
        "title": "Inner select on json when key is either string or array?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1629313144,
                "creation_date": 1629313144,
                "answer_id": 68837960,
                "question_id": 68837705,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I always end up swearing at jq, too!\r\n\r\nFor me, this jq query works:\r\n\r\n    $ jq &#39;.[&quot;NUTS|/nuts/2010&quot;]&#39; test.json\r\n    {\r\n      &quot;type&quot;: &quot;small&quot;,\r\n      &quot;mfg&quot;: &quot;TSQQ&quot;,\r\n      &quot;colors&quot;: []\r\n    }\r\n\r\nHowever, because you&#39;ve got pipes and slashes in your string, the variable quoting gets a bit funny.\r\n\r\n    NUTS_PATH=&#39;&quot;NUTS|/nuts/2010&quot;&#39; #Note the two sets of quotes\r\n    INPUT_FILE=&quot;test.json&quot;\r\n    RESULT=$(jq &quot;.[$NUTS_PATH]&quot; $INPUT_FILE)\r\n\r\n    echo &quot;Result: $RESULT&quot;\r\n\r\n    Result: {\r\n      &quot;type&quot;: &quot;small&quot;,\r\n      &quot;mfg&quot;: &quot;TSQQ&quot;,\r\n      &quot;colors&quot;: []\r\n    }\r\n\r\nDisclaimer, I&#39;m not a BASH expert, there may (probably is) be a better way to sort out the quoting",
                "title": "Accessing JSON value via jq using variable key"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1629314662,
                "creation_date": 1629314662,
                "answer_id": 68838252,
                "question_id": 68837705,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem isn&#39;t associated with `jq` at all. What you have should work fine, but the issue is with the assignment of the result to an _array_ when you might have intended to store it in a _variable_\r\n\r\n```bash\r\nRESULT=($(jq -r --arg NUTS_PATH_ALIAS &quot;$NUTS_PATH&quot; &#39;.[$NUTS_PATH_ALIAS]&#39; $INPUT_FILE))\r\n#     ^^^ =( .. ) result is stored into an array\r\n```\r\n\r\nA variable like expansion of an array of form `$RESULT` refers to element at index 0, i.e. `${RESULT[0]}`, which contains the `{` character of the raw JSON output\r\n\r\nYou should ideally be doing \r\n\r\n```bash\r\nRESULT=&quot;$(jq -r --arg NUTS_PATH_ALIAS &quot;$NUTS_PATH&quot; &#39;.[$NUTS_PATH_ALIAS]&#39; &quot;$INPUT_FILE&quot;)&quot;\r\n```",
                "title": "Accessing JSON value via jq using variable key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1629314662,
        "creation_date": 1629311778,
        "question_id": 68837705,
        "body_markdown": "I have a file with JSON like: \r\ntest.json\r\n```\r\n{\r\n    &quot;NUTS|/nuts/2010&quot;: {\r\n        &quot;type&quot;: &quot;small&quot;,\r\n        &quot;mfg&quot;: &quot;TSQQ&quot;,\r\n        &quot;colors&quot;: []\r\n    }\r\n}\r\n```\r\nI am getting &quot;NUTS|/nuts/2010&quot; from outside and I am storing it in a shell variable. I am trying to use the below snippet and using jq util, but I am not able to access the corresponding json against the above key.\r\n\r\ntest.sh\r\n```\r\n#!/bin/bash\r\n\r\nNUTS_PATH=&quot;NUTS|/nuts/2010&quot; #Storing in shell variable\r\nINPUT_FILE=&quot;test.json&quot;\r\nRESULT=($(jq -r --arg NUTS_PATH_ALIAS &quot;$NUTS_PATH&quot; &#39;.[$NUTS_PATH_ALIAS]&#39; $INPUT_FILE))\r\n\r\necho &quot;Result: $RESULT&quot;\r\necho $RESULT &gt; item.json\r\n```\r\n\r\nWhen I run this, I am getting:\r\n```\r\nResult: {\r\n```\r\nBut it should return\r\n```\r\n{\r\n        &quot;type&quot;: &quot;small&quot;,\r\n        &quot;mfg&quot;: &quot;TSQQ&quot;,\r\n        &quot;colors&quot;: []\r\n    }\r\n```\r\n\r\nAny help. Thanks",
        "link": "https://stackoverflow.com/questions/68837705/accessing-json-value-via-jq-using-variable-key",
        "title": "Accessing JSON value via jq using variable key"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1629333516,
                "creation_date": 1629333516,
                "answer_id": 68840734,
                "question_id": 68839057,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Put your filter expression inside `(..)`, meaning it to apply to the node structure from root, and not within `.Headers[]` alone. Once under parens, use the update assignment `|=` or the normal assignment to make it work.\r\n\r\n```none\r\n( .HeaderAuthentication.Headers[] | select(.Name == &quot;api-key&quot;) | .Value ) |= &quot;xxx&quot;\r\n```",
                "title": "How to replace a value in json file using jq and returning the whole content"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1629333516,
        "creation_date": 1629319178,
        "last_edit_date": 1629320303,
        "question_id": 68839057,
        "body_markdown": "I have a json like this\r\n```json\r\n{\r\n  &quot;AgentGroupId&quot;: null,\r\n  &quot;AgentId&quot;: null,\r\n  &quot;CreateType&quot;: &quot;Website&quot;,\r\n  &quot;IsPrimary&quot;: true,\r\n  &quot;IsShared&quot;: true,\r\n  &quot;HeaderAuthentication&quot;: {\r\n    &quot;Headers&quot;: [\r\n      {\r\n        &quot;Name&quot;: &quot;api-key&quot;,\r\n        &quot;Value&quot;: &quot;TEST_API_KEY_VALUE-2&quot;,\r\n        &quot;OriginalName&quot;: null,\r\n        &quot;IsReplacedCredentials&quot;: false\r\n      },\r\n      {\r\n        &quot;Name&quot;: &quot;Authorization&quot;,\r\n        &quot;Value&quot;: &quot;&quot;,\r\n        &quot;OriginalName&quot;: null,\r\n        &quot;IsReplacedCredentials&quot;: false\r\n      }\r\n    ],\r\n    &quot;IsEnabled&quot;: true\r\n  },\r\n  &quot;IsTimeWindowEnabled&quot;: false,\r\n  &quot;AdditionalWebsites&quot;: [],\r\n  &quot;BasicAuthenticationApiModel&quot;: {\r\n    &quot;Credentials&quot;: null,\r\n    &quot;IsEnabled&quot;: false,\r\n    &quot;NoChallenge&quot;: false\r\n  },\r\n  &quot;ClientCertificateAuthenticationSetting&quot;: null,\r\n  &quot;Cookies&quot;: null,\r\n  &quot;CrawlAndAttack&quot;: true,\r\n  &quot;EnableHeuristicChecksInCustomUrlRewrite&quot;: true,\r\n  &quot;ExcludedLinks&quot;: [\r\n    {\r\n      &quot;RegexPattern&quot;: &quot;gtm\\\\.js&quot;\r\n    },\r\n    {\r\n      &quot;RegexPattern&quot;: &quot;WebResource\\\\.axd&quot;\r\n    },\r\n    {\r\n      &quot;RegexPattern&quot;: &quot;ScriptResource\\\\.axd&quot;\r\n    }\r\n  ],\r\n  &quot;ExcludedUsageTrackers&quot;: [],\r\n  &quot;DisallowedHttpMethods&quot;: [],\r\n  &quot;ExcludeLinks&quot;: true,\r\n  &quot;ExcludeAuthenticationPages&quot;: false,\r\n  &quot;FindAndFollowNewLinks&quot;: true,\r\n  &quot;FormAuthenticationSettingModel&quot;: {\r\n    &quot;Integrations&quot;: {},\r\n    &quot;CustomScripts&quot;: [],\r\n    &quot;InteractiveLoginRequired&quot;: false,\r\n    &quot;DefaultPersonaValidation&quot;: null,\r\n    &quot;DetectBearerToken&quot;: true,\r\n    &quot;DisableLogoutDetection&quot;: false,\r\n    &quot;IsEnabled&quot;: false,\r\n    &quot;LoginFormUrl&quot;: null,\r\n    &quot;LoginRequiredUrl&quot;: null,\r\n    &quot;LogoutKeywordPatterns&quot;: null,\r\n    &quot;LogoutKeywordPatternsValue&quot;: null,\r\n    &quot;LogoutRedirectPattern&quot;: null,\r\n    &quot;OverrideTargetUrl&quot;: false,\r\n    &quot;Personas&quot;: [],\r\n    &quot;PersonasValidation&quot;: null\r\n  }\r\n}\r\n```\r\n\r\nMy goal is to replace the value of `api-key` under `HeaderAuthentication` (it could be in any index , 0 , 2, 1, ...)\r\n\r\nI did this\r\n```\r\njq &#39;.HeaderAuthentication.Headers[] | select(.Name == &quot;api-key&quot;) | .Value = &quot;xxx&quot;&#39; scanprofile.json &gt; tmp &amp;&amp; mv tmp scanprofile.json\r\n```\r\n\r\nThe issue is seems `jq` is returning only the part that replaced, but I need the whole file, what I am doing wrong?\r\n\r\nthis is the content of file after running the command\r\n```\r\n{\r\n  &quot;Name&quot;: &quot;api-key&quot;,\r\n  &quot;Value&quot;: &quot;xxx&quot;,\r\n  &quot;OriginalName&quot;: null,\r\n  &quot;IsReplacedCredentials&quot;: false\r\n}\r\n\r\n```\r\n\r\nps. I saw some stackoverflow post using sponge, I can&#39;t use sponge in our environment\r\n",
        "link": "https://stackoverflow.com/questions/68839057/how-to-replace-a-value-in-json-file-using-jq-and-returning-the-whole-content",
        "title": "How to replace a value in json file using jq and returning the whole content"
    },
    {
        "tags": [
            "json",
            "stream",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12120947,
                    "reputation": 2111,
                    "user_id": 8852408,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/y2Qmh.jpg?s=256",
                    "display_name": "Joaquin",
                    "link": "https://stackoverflow.com/users/8852408/joaquin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629326061,
                "post_id": 68839614,
                "comment_id": 121660601,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629361027,
                "post_id": 68839614,
                "comment_id": 121667793,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14573326,
                    "reputation": 79,
                    "user_id": 10525981,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/dRjxt.png?s=256",
                    "display_name": "Gabriel",
                    "link": "https://stackoverflow.com/users/10525981/gabriel"
                },
                "reply_to_user": {
                    "account_id": 12120947,
                    "reputation": 2111,
                    "user_id": 8852408,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/y2Qmh.jpg?s=256",
                    "display_name": "Joaquin",
                    "link": "https://stackoverflow.com/users/8852408/joaquin"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1629382263,
                "post_id": 68839614,
                "comment_id": 121676864,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14573326,
                    "reputation": 79,
                    "user_id": 10525981,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/dRjxt.png?s=256",
                    "display_name": "Gabriel",
                    "link": "https://stackoverflow.com/users/10525981/gabriel"
                },
                "reply_to_user": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629382407,
                "post_id": 68839614,
                "comment_id": 121676934,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1629333115,
                "creation_date": 1629333115,
                "answer_id": 68840705,
                "question_id": 68839614,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The data you&#39;ve extracted is a stream of JSON objects. You could extract the .version from the first of these by piping the data to:\r\n\r\n    jq -n input.version\r\n\r\n",
                "title": "Can&#39;t return first value with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1629383247,
        "creation_date": 1629322541,
        "last_edit_date": 1629383247,
        "question_id": 68839614,
        "body_markdown": "A command that I run from my terminal return the following:\r\n\r\n    {\r\n      &quot;attributes&quot;: {\r\n        &quot;env&quot;: &quot;prod&quot;\r\n       },\r\n       &quot;created_by&quot;: &quot;email@email.com&quot;,\r\n       &quot;id&quot;: &quot;612&quot;,\r\n       &quot;state&quot;: &quot;published&quot;,\r\n       &quot;version&quot;: &quot;0.22.0&quot;\r\n    }\r\n    {\r\n      &quot;attributes&quot;: {\r\n        &quot;env&quot;: &quot;prod&quot;\r\n       },\r\n       &quot;created_by&quot;: &quot;email@email.com&quot;,\r\n       &quot;id&quot;: &quot;611&quot;,\r\n       &quot;state&quot;: &quot;published&quot;,\r\n       &quot;version&quot;: &quot;0.22.0&quot;\r\n    }\r\nAnd I just want to get the &quot;version&quot; from the first object. Theres is a way to do that? Everything I tried with Array returns a error...",
        "link": "https://stackoverflow.com/questions/68839614/cant-return-first-value-with-jq",
        "title": "Can&#39;t return first value with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "logfile",
            "recode"
        ],
        "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": 1629390592,
                "post_id": 68848457,
                "comment_id": 121680668,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1629394632,
                "post_id": 68848457,
                "comment_id": 121682165,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629404012,
                "post_id": 68848457,
                "comment_id": 121685202,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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"
                },
                "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": 1629404622,
                "post_id": 68848457,
                "comment_id": 121685364,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1629438030,
                "last_edit_date": 1629438030,
                "creation_date": 1629379104,
                "answer_id": 68848644,
                "question_id": 68848457,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could still use the `inputs` expression and generate the output desired\r\n\r\n```none\r\njq -nr &#39;inputs | (.msg | split(&quot; &quot;)) as $m | &quot;[\\($m[0] | ascii_downcase))] \\(.msg)&quot;&#39;\r\n```\r\n\r\nor if the contents of `.msg` are just an abstraction and you wanted to do a mapping of log levels, you could do\r\n\r\n```none\r\njq -nr --argjson levelMap &#39;{&quot;20&quot;: &quot;debug&quot;, &quot;30&quot;: &quot;info&quot;, &quot;40&quot;: &quot;warn&quot;}&#39; &#39;inputs \r\n     | &quot;[\\($levelMap[.level | tostring])] \\(.msg)&quot;&#39;\r\n```",
                "title": "Use value mapping in raw JSON lines"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1629380318,
                "creation_date": 1629380318,
                "answer_id": 68848953,
                "question_id": 68848457,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Sure, you can just use `as` to declare a mapping object up front, and use it later:\r\n\r\n    jq -rR &#39;{&quot;20&quot;: &quot;debug&quot;, &quot;30&quot;: &quot;info&quot;, &quot;40&quot;: &quot;warn&quot;} as $levelmap\r\n        | fromjson? | &quot;[\\($levelmap[.level | tostring])] \\(.msg)&quot;&#39;",
                "title": "Use value mapping in raw JSON lines"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1629394445,
                "creation_date": 1629394445,
                "answer_id": 68852323,
                "question_id": 68848457,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the input is a JSON stream, then so long as the mapping from .level to the first word of the .msg is consistent, you could go with:\r\n\r\n```\r\n&lt; test.log &#39;jq -sr &#39;\r\n . as $in\r\n | INDEX($in[]; .level|tostring)  as $dict\r\n | ($dict | map_values( . = (.msg | ascii_downcase | sub(&quot; .*&quot;;&quot;&quot;)))) as $kw\r\n | $in[]\r\n | .level |= $kw[tostring]\r\n | &quot;[\\(.level)] \\(.msg)&quot;\r\n&#39;\r\n```",
                "title": "Use value mapping in raw JSON lines"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1629438030,
        "creation_date": 1629378405,
        "last_edit_date": 1629405596,
        "question_id": 68848457,
        "body_markdown": "When input is a JSON array, it&#39;s possible to use `map` to convert values of element properties, such as in this answer: https://stackoverflow.com/a/45887356/1226020.\r\n\r\nBut in my case I have raw lines of JSON objects as input, not a JSON array, and I want to convert values in each object. \r\n\r\nExample input\r\n\r\n```\r\n{&quot;level&quot;: 20, &quot;msg&quot;: &quot;Debug message&quot;}\r\n{&quot;level&quot;: 30, &quot;msg&quot;: &quot;Info message&quot;}\r\n{&quot;level&quot;: 30, &quot;msg&quot;: &quot;Info message&quot;}\r\n{&quot;level&quot;: 40, &quot;msg&quot;: &quot;Warn message&quot;}\r\n{&quot;level&quot;: 20, &quot;msg&quot;: &quot;Debug message&quot;}\r\n```\r\n\r\nI currently do this:\r\n\r\n```\r\ncat test.log  | jq -rR &#39;fromjson? | &quot;[\\(.level)] \\(.msg)&quot;&#39;\r\n```\r\n\r\nWhich gives this:\r\n\r\n```\r\n[20] Debug message\r\n[30] Info message\r\n[30] Info message\r\n[40] Warn message\r\n[20] Debug message\r\n```\r\n\r\nDesired output, after some transforming etc:\r\n\r\n```\r\n[debug] Debug message\r\n[info] Info message\r\n[info] Info message\r\n[warn] Warn message\r\n[debug] Debug message\r\n```\r\n\r\nIs it possible to in JQ transform &quot;enum&quot; values like this?",
        "link": "https://stackoverflow.com/questions/68848457/use-value-mapping-in-raw-json-lines",
        "title": "Use value mapping in raw JSON lines"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1629418768,
                "last_edit_date": 1629418768,
                "creation_date": 1629418452,
                "answer_id": 68855695,
                "question_id": 68853258,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your real `array.json` has other fields in the objects besides the `DataId` one that you want to pass through unchanged (I added one)...\r\n\r\n```sh\r\n$ jq -n &#39;[ inputs ] | transpose | map(.[0] + {DataId: .[1].Id})&#39; array.json input.json\r\n[\r\n  {\r\n    &quot;DataId&quot;: &quot;123456&quot;\r\n  },\r\n  {\r\n    &quot;DataId&quot;: &quot;7890123&quot;,\r\n    &quot;foo&quot;: &quot;bar&quot;\r\n  }\r\n]\r\n```\r\n\r\n---\r\n\r\nThis works by creating an array of arrays of objects, each sub-array holding the corresponding objects from the two input arrays, and then iterating it and for each sub-array, constructing an object with all the fields of the first object (From `array.json`) but the value of `Id` from the second object for the `DataId` field.",
                "title": "jq producing duplicates when I updated/replaced the value in array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1629428434,
                "creation_date": 1629428434,
                "answer_id": 68856513,
                "question_id": 68853258,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d go for simplicity, e.g.:\r\n```\r\n jq -n &#39;\r\n (input| map(.Id)) as $ids\r\n | input\r\n | reduce range(0; length) as $i (.;\r\n    .[$i].DataId = $ids[$i] )\r\n&#39; input.json array.json\r\n```\r\n \r\n",
                "title": "jq producing duplicates when I updated/replaced the value in array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1629485211,
        "creation_date": 1629399476,
        "last_edit_date": 1629485211,
        "question_id": 68853258,
        "body_markdown": "Here are the input JSON files:\r\n\r\n**input.json** \r\n\r\n    [\r\n       {\r\n          &quot;Id&quot;:&quot;123456&quot;\r\n       },\r\n       {\r\n          &quot;Id&quot;:&quot;7890123&quot;\r\n       }\r\n    ]\r\n\r\n**array.json**\r\n\r\n    [\r\n       {\r\n          &quot;DataId&quot;:&quot;{{ID}}&quot;\r\n       },\r\n       {\r\n          &quot;DataId&quot;:&quot;{{ID}}&quot;\r\n       }\r\n    ]\r\n\r\nI try to replace placeholders in array JSON with IDs from the input file and create new array of objects.\r\n\r\nThis is what I have come up with so far:\r\n\r\n    cat input.json | jq &#39;.[] as $inputs |[ $endFile[] + {&quot;DataId&quot;: $inputs[]}] &#39; --argjson endFile &quot;$(&lt;array.json)&quot;\r\n\r\nI am getting the duplicates and I have no clue, why:\r\n&lt;pre&gt;\r\n\r\n    &lt;b&gt;[&lt;/b&gt;\r\n    &lt;b&gt;  {&lt;/b&gt;\r\n    &lt;b&gt;    &lt;/b&gt;&lt;font color=&quot;#729FCF&quot;&gt;&lt;b&gt;&amp;quot;DataId&amp;quot;&lt;/b&gt;&lt;/font&gt;&lt;b&gt;: &lt;/b&gt;&lt;font color=&quot;#4E9A06&quot;&gt;&amp;quot;123456&amp;quot;&lt;/font&gt;\r\n    &lt;b&gt;  },&lt;/b&gt;\r\n    &lt;b&gt;  {&lt;/b&gt;\r\n    &lt;b&gt;    &lt;/b&gt;&lt;font color=&quot;#729FCF&quot;&gt;&lt;b&gt;&amp;quot;DataId&amp;quot;&lt;/b&gt;&lt;/font&gt;&lt;b&gt;: &lt;/b&gt;&lt;font color=&quot;#4E9A06&quot;&gt;&amp;quot;123456&amp;quot;&lt;/font&gt;\r\n    &lt;b&gt;  }&lt;/b&gt;\r\n    &lt;b&gt;]&lt;/b&gt;\r\n    &lt;b&gt;[&lt;/b&gt;\r\n    &lt;b&gt;  {&lt;/b&gt;\r\n    &lt;b&gt;    &lt;/b&gt;&lt;font color=&quot;#729FCF&quot;&gt;&lt;b&gt;&amp;quot;DataId&amp;quot;&lt;/b&gt;&lt;/font&gt;&lt;b&gt;: &lt;/b&gt;&lt;font color=&quot;#4E9A06&quot;&gt;&amp;quot;7890123&amp;quot;&lt;/font&gt;\r\n    &lt;b&gt;  },&lt;/b&gt;\r\n    &lt;b&gt;  {&lt;/b&gt;\r\n    &lt;b&gt;    &lt;/b&gt;&lt;font color=&quot;#729FCF&quot;&gt;&lt;b&gt;&amp;quot;DataId&amp;quot;&lt;/b&gt;&lt;/font&gt;&lt;b&gt;: &lt;/b&gt;&lt;font color=&quot;#4E9A06&quot;&gt;&amp;quot;7890123&amp;quot;&lt;/font&gt;\r\n    &lt;b&gt;  }&lt;/b&gt;\r\n    &lt;b&gt;]&lt;/b&gt;\r\n\r\n&lt;/pre&gt;\r\n\r\nI need to have the same structure as the array.json only with values.\r\n\r\nThank you!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68853258/jq-producing-duplicates-when-i-updated-replaced-the-value-in-array",
        "title": "jq producing duplicates when I updated/replaced the value in array"
    },
    {
        "tags": [
            "json",
            "string",
            "jq",
            "convertto-json"
        ],
        "answers": [
            {
                "up_vote_count": 22,
                "is_accepted": true,
                "score": 22,
                "last_activity_date": 1629452285,
                "last_edit_date": 1629452285,
                "creation_date": 1629451577,
                "answer_id": 68859958,
                "question_id": 68859957,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming that the input is given on stdin, the following command solves the problem:\r\n\r\n```\r\njq -Rn &#39;[inputs]&#39;\r\n```\r\n\r\nThe flag `-R` reads the input as &quot;raw&quot; (i.e. unquoted strings) and `-n` hands over stdin to `inputs` (slurping with `-s` doesn&#39;t work because when combined with `-R`, it reads the whole input a single string). Add `-c` to print the JSON on one line like in the question.\r\n\r\nAny empty lines (like a trailing newline) may be skipped by adding a little filter:\r\n\r\n```\r\njq -Rn &#39;[inputs|select(length&gt;0)]&#39;\r\n```\r\n\r\n---\r\n\r\nIf the strings are separated by other characters like `,`, the string may be split with\r\n\r\n```\r\njq -R &#39;split(&quot;,&quot;)&#39;\r\n```\r\n\r\nThis could be used to split on `\\n` as well for solving the above case, but my (unverified) assumption is that the above solution is more portable with systems using other line terminators.",
                "title": "Transform a list of strings to JSON array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 14,
        "last_activity_date": 1678027938,
        "creation_date": 1629451577,
        "last_edit_date": 1678027938,
        "question_id": 68859957,
        "body_markdown": "Having a list of strings (one per line) like\r\n\r\n```\r\nstr1\r\nstr2\r\n...\r\n```\r\n\r\nhow do I convert these into the JSON list `[&quot;str1&quot;, &quot;str2&quot;, ...]`?",
        "link": "https://stackoverflow.com/questions/68859957/transform-a-list-of-strings-to-json-array-using-jq",
        "title": "Transform a list of strings to JSON array using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1713991369,
                "last_edit_date": 1713991369,
                "creation_date": 1629573649,
                "answer_id": 68876089,
                "question_id": 68876023,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming file #2 may not be empty, you can simply assign `input` to `.b`.\r\n``` shell\r\njq &#39;.b = input&#39; file1 file2\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/sy-yt1M82ly)&lt;/sup&gt;\r\n\r\nOtherwise you&#39;d use the following to retain the original value of `.b` when file #2 is empty.\r\n``` shell\r\njq &#39;.b = first(inputs, .b)&#39; file1 file2\r\n```",
                "title": "Replace nested object with an object from another file in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1713991369,
        "creation_date": 1629573013,
        "last_edit_date": 1629607625,
        "question_id": 68876023,
        "body_markdown": "I have a json file that has the following structures\r\n\r\n    {\r\n      &quot;a&quot;:&quot;aval&quot;,\r\n      &quot;b&quot;:{},\r\n      &quot;c&quot;:&quot;cval&quot;\r\n    }\r\nI have another json file with following content\r\n\r\n    {\r\n      &quot;b1&quot;:&quot;b1val&quot;,&quot;b2&quot;:&quot;b2val&quot;\r\n    }\r\n\r\nI want to shove the json object from file 2 into &quot;b&quot; from file 1\r\n\r\n    {\r\n      &quot;a&quot;:&quot;aval&quot;,\r\n      &quot;b&quot;:{\r\n          &quot;b1&quot;:&quot;b1val&quot;,&quot;b2&quot;:&quot;b2val&quot;\r\n      },\r\n      &quot;c&quot;:&quot;cval&quot;\r\n    }\r\n\r\nhow do i do this with JQ",
        "link": "https://stackoverflow.com/questions/68876023/replace-nested-object-with-an-object-from-another-file-in-jq",
        "title": "Replace nested object with an object from another file in JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629602564,
                "post_id": 68877871,
                "comment_id": 121728091,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24269,
                    "reputation": 68079,
                    "user_id": 61624,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/1e011d13433f12be7dc754180cb38ca8?s=256&d=identicon&r=PG",
                    "display_name": "Daniel Kaplan",
                    "link": "https://stackoverflow.com/users/61624/daniel-kaplan"
                },
                "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": 1629602686,
                "post_id": 68877871,
                "comment_id": 121728100,
                "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": 1629602860,
                "post_id": 68877871,
                "comment_id": 121728122,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24269,
                    "reputation": 68079,
                    "user_id": 61624,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/1e011d13433f12be7dc754180cb38ca8?s=256&d=identicon&r=PG",
                    "display_name": "Daniel Kaplan",
                    "link": "https://stackoverflow.com/users/61624/daniel-kaplan"
                },
                "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": 1629603151,
                "post_id": 68877871,
                "comment_id": 121728151,
                "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": 2,
                "creation_date": 1629605727,
                "post_id": 68877871,
                "comment_id": 121728399,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1629602731,
                "creation_date": 1629602731,
                "answer_id": 68878266,
                "question_id": 68877871,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I figured out how to do this on my own:\r\n\r\nInput:\r\n\r\n    {&quot;posts&quot;: [{&quot;title&quot;: &quot;Frist psot&quot;, &quot;author&quot;: &quot;anon&quot;},\r\n               {&quot;title&quot;: &quot;A well-written article&quot;, &quot;author&quot;: &quot;person1&quot;}],\r\n     &quot;realnames&quot;: [{&quot;id&quot;: &quot;anon&quot;, &quot;name&quot;: &quot;Anonymous Coward&quot;},\r\n                   {&quot;id&quot;: &quot;person1&quot;, &quot;name&quot;: &quot;Person McPherson&quot;}]}\r\n\r\nFilter:\r\n\r\n    .realnames[] as $names | .posts[] | {title, author: (select(.author == $names.id) | $names.name)}\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;title&quot;: &quot;Frist psot&quot;,\r\n      &quot;author&quot;: &quot;Anonymous Coward&quot;\r\n    }\r\n    {\r\n      &quot;title&quot;: &quot;A well-written article&quot;,\r\n      &quot;author&quot;: &quot;Person McPherson&quot;\r\n    }\r\n",
                "title": "How do you match the properties of one array of objects to the properties of another if they are both in arrays?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1629603369,
                "creation_date": 1629603369,
                "answer_id": 68878306,
                "question_id": 68877871,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the spirit of &quot;How to Solve It&quot;, you could simply convert the format for .realnames that you have into the one you know how to use.\r\n\r\nThis could be accomplished via:\r\n\r\n    .realnames |= (map({(.id): .name}) | add)",
                "title": "How do you match the properties of one array of objects to the properties of another if they are both in arrays?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1629603369,
        "creation_date": 1629595867,
        "last_edit_date": 1629598469,
        "question_id": 68877871,
        "body_markdown": "Forgive me for the terrible title. [The jq manual has a section called &quot;Variable / Symbolic Binding Operator&quot;][1] that says this:\r\n\r\nSuppose we have an array of blog posts, with &quot;author&quot; and &quot;title&quot; fields, and another object which is used to map author usernames to real names. Our input looks like:\r\n\r\n    {&quot;posts&quot;: [{&quot;title&quot;: &quot;Frist psot&quot;, &quot;author&quot;: &quot;anon&quot;},\r\n               {&quot;title&quot;: &quot;A well-written article&quot;, &quot;author&quot;: &quot;person1&quot;}],\r\n     &quot;realnames&quot;: {&quot;anon&quot;: &quot;Anonymous Coward&quot;,\r\n                   &quot;person1&quot;: &quot;Person McPherson&quot;}}\r\n\r\nWe want to produce the posts with the author field containing a real name, as in:\r\n\r\n    {&quot;title&quot;: &quot;Frist psot&quot;, &quot;author&quot;: &quot;Anonymous Coward&quot;}\r\n    {&quot;title&quot;: &quot;A well-written article&quot;, &quot;author&quot;: &quot;Person McPherson&quot;}\r\n\r\nWe use a variable, $names, to store the realnames object, so that we can refer to it later when looking up author usernames:\r\n\r\n    .realnames as $names | .posts[] | {title, author: $names[.author]}\r\n\r\nI want to the exact same output with a slightly different input: my &quot;realnames&quot; is an array of objects:\r\n\r\n    {&quot;posts&quot;: [{&quot;title&quot;: &quot;Frist psot&quot;, &quot;author&quot;: &quot;anon&quot;},\r\n               {&quot;title&quot;: &quot;A well-written article&quot;, &quot;author&quot;: &quot;person1&quot;}],\r\n     &quot;realnames&quot;: [{id: &quot;anon&quot;, name: &quot;Anonymous Coward&quot;},\r\n                   {id: &quot;person1&quot;, name: &quot;Person McPherson&quot;}]}\r\n\r\nHow would I get the exact same output from this input?\r\n\r\nI *may* be asking this question, but I honestly can&#39;t tell because the question has so much noise in it: https://stackoverflow.com/questions/51558701/jq-find-a-json-object-based-on-one-of-its-values-and-get-another-value-from-it I think this is different: from what I can tell, the input only has one array)\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Advancedfeatures\r\n",
        "link": "https://stackoverflow.com/questions/68877871/how-do-you-match-the-properties-of-one-array-of-objects-to-the-properties-of-ano",
        "title": "How do you match the properties of one array of objects to the properties of another if they are both in arrays?"
    },
    {
        "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": 0,
                "creation_date": 1629695468,
                "post_id": 68887539,
                "comment_id": 121744768,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18201396,
                    "reputation": 985,
                    "user_id": 13288989,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0c10b1cafdb9c5b07a1b08951e40e3cb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kalib Zen",
                    "link": "https://stackoverflow.com/users/13288989/kalib-zen"
                },
                "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": 1629695724,
                "post_id": 68887539,
                "comment_id": 121744815,
                "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": 2,
                "creation_date": 1629695895,
                "post_id": 68887539,
                "comment_id": 121744843,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1629696026,
                "post_id": 68887539,
                "comment_id": 121744869,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18201396,
                    "reputation": 985,
                    "user_id": 13288989,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0c10b1cafdb9c5b07a1b08951e40e3cb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kalib Zen",
                    "link": "https://stackoverflow.com/users/13288989/kalib-zen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629697222,
                "post_id": 68887539,
                "comment_id": 121745088,
                "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": 1629698725,
                "post_id": 68887539,
                "comment_id": 121745426,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18201396,
                    "reputation": 985,
                    "user_id": 13288989,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0c10b1cafdb9c5b07a1b08951e40e3cb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kalib Zen",
                    "link": "https://stackoverflow.com/users/13288989/kalib-zen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629699088,
                "post_id": 68887539,
                "comment_id": 121745501,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1629751476,
                "creation_date": 1629751476,
                "answer_id": 68898819,
                "question_id": 68887539,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Job with `readarray` (from bash):\r\n\r\n```bash\r\n# 2) create the first list of array from .name\r\nreadarray -t record &lt; &lt;(echo &quot;${json_data}&quot; | jq -r &quot;.records[].name&quot;)\r\n\r\n# 3) create the second list of array from .value\r\nreadarray -t record2 &lt; &lt;(echo &quot;${json_data}&quot; | jq -r &quot;.records[].value&quot;)\r\n\r\n# 4) printout the array\r\nfor i in &quot;${!record[@]}&quot;; do\r\n    # for removing double quotes\r\n    record2[i]=&quot;${record2[i]#\\&quot;}&quot;\r\n    record2[i]=&quot;${record2[i]%\\&quot;}&quot;\r\n    echo &quot;The record [ ${record[i]} ] belongs to [ ${record2[i]} ]&quot;\r\ndone\r\n```\r\n\r\nOutput:\r\n```\r\nThe record [ record1 ] belongs to [ 1.this-is-string-value-of-record-1-with-no-spaces ]\r\nThe record [ record2 ] belongs to [ 2. this is string value of record 2 with spaces ]\r\nThe record [ record3 ] belongs to [ 3. this is string value of record 3 with spaces ]\r\n```\r\n\r\nRemarks:\r\n - `readarray` works on lines (the output of `jq` is also). So, don&#39;t use `-d ` option\r\n - use `-t` option for remove EOL delimiter (&#39;\\n&#39;)",
                "title": "Problem printing array with spaces using bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1629751476,
        "creation_date": 1629695006,
        "last_edit_date": 1629695482,
        "question_id": 68887539,
        "body_markdown": "I&#39;m trying to print array data from json in bash and I use jq for this purpose. The problem is, if the value of the record contain spaces, it will messed up the output. Below is the bash script that demonstrates this problem:\r\n\r\nThis is the full source code (required jq):\r\n\r\n    #!/bin/bash\r\n    \r\n    # 1) Declare a sample json with 3 records:\r\n\r\n    json_data=$(cat &lt;&lt;EOF\r\n    {\r\n       &quot;records&quot;:[\r\n          {\r\n             &quot;name&quot;:&quot;record1&quot;,\r\n             &quot;value&quot;:&quot;\\&quot;1.this-is-string-value-of-record-1-with-no-spaces\\&quot;&quot;\r\n          },\r\n          {\r\n             &quot;name&quot;:&quot;record2&quot;,\r\n             &quot;value&quot;:&quot;\\&quot;2. this is string value of record 2 with spaces\\&quot;&quot;\r\n          },\r\n    \r\n          {\r\n             &quot;name&quot;:&quot;record3&quot;,\r\n             &quot;value&quot;:&quot;\\&quot;3. this is string value of record 3 with spaces\\&quot;&quot;\r\n          }\r\n       ]\r\n    }\r\n    EOF\r\n    )\r\n\r\n    # 2) create the first list of array from .name\r\n\r\n    record=($(echo &quot;${json_data}&quot; | jq -r &quot;.records[].name&quot; | tr &#39;\\n&#39; &#39; &#39;))\r\n\r\n\r\n    # 3) create the second list of array from .value\r\n\r\n     record2=($(echo &quot;${json_data}&quot; | jq -r &quot;.records[].value&quot; | tr &#39;\\n&#39; &#39; &#39;))\r\n\r\n    # 4) printout the array\r\n\r\n    for i in &quot;${!record[@]}&quot;; do\r\n    \r\n     echo &quot;The record [ ${record[i]} ] belongs to [ ${record2[i]} ]&quot;\r\n    \r\n    done\r\n\r\n\r\nOutput:\r\n\r\n    The record [ record1 ] belongs to [ &quot;1.this-is-string-value-of-record-1-with-no-spaces&quot; ]\r\n    The record [ record2 ] belongs to [ &quot;2. ]\r\n    The record [ record3 ] belongs to [ this ]\r\n\r\n\r\nExpected output:\r\n\r\n    The record [ record1 ] belongs to [ 1.this-is-string-value-of-record-1-with-no-spaces ]\r\n    The record [ record2 ] belongs to [ 2. this is string value of record 2 with spaces ]\r\n    The record [ record3 ] belongs to [ 3. this is string value of record 3 with spaces ]\r\n    \r\n\r\nCould you explain why it does not accept spaces value? Thanks.\r\n",
        "link": "https://stackoverflow.com/questions/68887539/problem-printing-array-with-spaces-using-bash",
        "title": "Problem printing array with spaces using bash"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1629709701,
                "creation_date": 1629709701,
                "answer_id": 68890014,
                "question_id": 68889789,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    with_entries(select(.value.x == 2))",
                "title": "how to use jq to filter an object based on it&#39;s key:value pair?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1629711905,
                "creation_date": 1629711905,
                "answer_id": 68890438,
                "question_id": 68889789,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also use map_values :\r\n\r\n```\r\nmap_values(select(.x == 2))\r\n```",
                "title": "how to use jq to filter an object based on it&#39;s key:value pair?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1629711905,
        "creation_date": 1629708789,
        "question_id": 68889789,
        "body_markdown": "Assuming this is the input\r\n\r\n    &gt;echo &#39;{&quot;A&quot;: {&quot;x&quot;: 1}, &quot;B&quot;: {&quot;x&quot;:2}, &quot;C&quot;:{&quot;x&quot;:3}}&#39; | jq &#39;.&#39;\r\n    {\r\n      &quot;A&quot;: {\r\n        &quot;x&quot;: 1\r\n      },\r\n      &quot;B&quot;: {\r\n        &quot;x&quot;: 2\r\n      },\r\n      &quot;C&quot;: {\r\n        &quot;x&quot;: 3\r\n      }\r\n    }\r\n\r\nI would like to get the return object of `&quot;x&quot; == 2`.\r\nThe only way i know of how to achieve that is thru this\r\n\r\n    &gt;echo &#39;{&quot;A&quot;: {&quot;x&quot;: 1}, &quot;B&quot;: {&quot;x&quot;:2}, &quot;C&quot;:{&quot;x&quot;:3}}&#39; | jq &#39;.[] | select(.x==2)&#39;\r\n    {\r\n      &quot;x&quot;: 2\r\n    }\r\n\r\nIs there a way to have jq return me like this instead?\r\n\r\n    {\r\n      &quot;B&quot;: {\r\n        &quot;x&quot;: 2\r\n      },\r\n    }\r\n\r\n     \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68889789/how-to-use-jq-to-filter-an-object-based-on-its-keyvalue-pair",
        "title": "how to use jq to filter an object based on it&#39;s key:value pair?"
    },
    {
        "tags": [
            "json",
            "formatting",
            "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": 1629723613,
                "post_id": 68892871,
                "comment_id": 121754861,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14065478,
                    "reputation": 597,
                    "user_id": 10164669,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/lOki1.jpg?s=256",
                    "display_name": "FedKad",
                    "link": "https://stackoverflow.com/users/10164669/fedkad"
                },
                "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": 1629724216,
                "post_id": 68892871,
                "comment_id": 121755149,
                "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": 1629724240,
                "post_id": 68892871,
                "comment_id": 121755159,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1704436560,
                "last_edit_date": 1704436560,
                "creation_date": 1629724516,
                "answer_id": 68893398,
                "question_id": 68892871,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t mind an empty line at the end of the output, this should work fine:\r\n``` shell\r\njq -r &#39;.[] | (to_entries[] | &quot;\\(.key) : \\(.value)&quot;), &quot;&quot;&#39;\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/ZnKl3RO7Qur)&lt;/sup&gt;",
                "title": "Print a JSON array in human readable format using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1629739565,
                "creation_date": 1629739565,
                "answer_id": 68896694,
                "question_id": 68892871,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to avoid the extra newline is to use `join` twice:\r\n\r\n    [.[]\r\n     | [ (to_entries[] | &quot;\\(.key) : \\(.value)}&quot;) ]\r\n       | join(&quot;\\n&quot;)]\r\n    | join(&quot;\\n\\n&quot;)",
                "title": "Print a JSON array in human readable format using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1704436560,
        "creation_date": 1629722339,
        "last_edit_date": 1629725110,
        "question_id": 68892871,
        "body_markdown": "I am relatively not experienced in `jq`, so the answer may be very simple, but I couldn&#39;t find it on the Internet somehow.\r\n\r\nI have a JSON array like this:\r\n```\r\n[\r\n {\r\n  &quot;key1&quot;: &quot;value1a&quot;,\r\n  &quot;key2&quot;: &quot;value2a&quot;,\r\n  &quot;key3&quot;: &quot;value3a&quot;,\r\n  &quot;keyn&quot;: &quot;valuena&quot;\r\n },\r\n {\r\n  &quot;key1&quot;: &quot;value1b&quot;,\r\n  &quot;key2&quot;: &quot;value2b&quot;,\r\n  &quot;key3&quot;: &quot;value3b&quot;,\r\n  &quot;keyn&quot;: &quot;valuenb&quot;\r\n },\r\n {\r\n  &quot;key1&quot;: &quot;value1z&quot;,\r\n  &quot;key2&quot;: &quot;value2z&quot;,\r\n  &quot;key3&quot;: &quot;value3z&quot;,\r\n  &quot;keyn&quot;: &quot;valuenz&quot;\r\n }\r\n]\r\n```\r\nAnd I want to print it in the following &quot;human-readable&quot; format:\r\n\r\n```\r\nkey1 : value1a\r\nkey2 : value2a\r\nkey3 : value3a\r\nkeyn : valuena\r\n\r\nkey1 : value1b\r\nkey2 : value2b\r\nkey3 : value3b\r\nkeyn : valuenb\r\n\r\nkey1 : value1z\r\nkey2 : value2z\r\nkey3 : value3z\r\nkeyn : valuenz\r\n```\r\nusing preferably `jq` command.\r\n\r\nNote that the number of elements of the array and the number of key/value pairs for each element is variable and not known in advance.",
        "link": "https://stackoverflow.com/questions/68892871/print-a-json-array-in-human-readable-format-using-jq",
        "title": "Print a JSON array in human readable format using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 904170,
                    "reputation": 5454,
                    "user_id": 939457,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/56f2edd7d1cc2cf254fd6a4674c2538b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sorin",
                    "link": "https://stackoverflow.com/users/939457/sorin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629749707,
                "post_id": 68898407,
                "comment_id": 121764677,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1629749416,
                "creation_date": 1629749416,
                "answer_id": 68898481,
                "question_id": 68898407,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Variables aren&#39;t expanded in double quotes. Use the `+` operator to concatenate strings:\r\n\r\n    &#39;(.directory[].file_name |= &quot;AWS_&quot; + $prefix + &quot;_\\(.)_output.json&quot;)&#39;\r\n\r\nor use the string interpolation `\\(...)`:\r\n\r\n    &#39;(.directory[].file_name |= &quot;AWS_\\($prefix)_\\(.)_output.json&quot;)&#39;",
                "title": "How to use jq with argument variable to replace value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1629749416,
        "creation_date": 1629748978,
        "last_edit_date": 1629749248,
        "question_id": 68898407,
        "body_markdown": "I want to add prefix and suffix in the existing value of JSON file.\r\n\r\nHere is sample test.json file -\r\n\r\n         &quot;directory&quot;: [\r\n            {\r\n              &quot;start_datetime&quot;: &quot;1990-07-20 07:45:58&quot;,\r\n              &quot;end_datetime&quot;: &quot;1990-07-20 07:45:58&quot;,\r\n              &quot;file_name&quot;: &quot;N11&quot;,\r\n            },\r\n            {\r\n              &quot;start_datetime&quot;: &quot;1990-07-20 07:45:58&quot;,\r\n              &quot;end_datetime&quot;: &quot;1990-07-20 07:45:58&quot;,\r\n              &quot;file_name&quot;: &quot;N12&quot;,\r\n            }\r\n    ]\r\n\r\nHere is command which I&#39;m executing -\r\n\r\n    export prefix=&quot;sample&quot;\r\n    jq -c  --arg prefix &quot;$prefix&quot; &#39;(.directory[].file_name |= &quot;AWS_$prefix_\\(.)_output.json&quot;)&#39; test.json\r\n\r\n\r\nHere is expected output -\r\n\r\n         &quot;directory&quot;: [\r\n            {\r\n              &quot;start_datetime&quot;: &quot;1990-07-20 07:45:58&quot;,\r\n              &quot;end_datetime&quot;: &quot;1990-07-20 07:45:58&quot;,\r\n              &quot;file_name&quot;: &quot;AWS_sample_N11_output.json&quot;,\r\n            },\r\n            {\r\n              &quot;start_datetime&quot;: &quot;1990-07-20 07:45:58&quot;,\r\n              &quot;end_datetime&quot;: &quot;1990-07-20 07:45:58&quot;,\r\n              &quot;file_name&quot;: &quot;AWS_sample_N12_output.json&quot;,\r\n            }\r\n    ]\r\n\r\nThe command which I&#39;m giving is not working. Please help me to fix this issue.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68898407/how-to-use-jq-with-argument-variable-to-replace-value",
        "title": "How to use jq with argument variable to replace value"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3713621,
                    "reputation": 664,
                    "user_id": 3090323,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/2a16a14a4071ab3eabb1cc35e89331ef?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Tirinoarim",
                    "link": "https://stackoverflow.com/users/3090323/tirinoarim"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629886018,
                "post_id": 68909597,
                "comment_id": 121803409,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1629817477,
                "last_edit_date": 1629817477,
                "creation_date": 1629817372,
                "answer_id": 68909658,
                "question_id": 68909597,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JSON arrays starts from zero. you should use index 0 instead of 1:\r\n`.dog[0]`",
                "title": "Add a single object to an array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1629817752,
                "creation_date": 1629817752,
                "answer_id": 68909753,
                "question_id": 68909597,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of an integer index, use a slice. (Also, the array is 0-indexed, not 1-indexed.)\r\n\r\n    $ jq --argjson i 0 &#39;{dog: .dog[$i:$i+1]}&#39; &lt; tmp.json\r\n    {\r\n      &quot;dog&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;sam&quot;,\r\n          &quot;age&quot;: &quot;2&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nAs you are asking for an object, not a string, the `-r` option doesn&#39;t do anything.",
                "title": "Add a single object to an array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1629817978,
                "creation_date": 1629817978,
                "answer_id": 68909816,
                "question_id": 68909597,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try\r\n\r\n```\r\njq --argjson i 2 &#39;.dog|=[.[$i-1]]&#39;\r\n```\r\n\r\nThe `.dog|=[.[$index]]` part modifies just the array `dog` and replaces it with an array of just the item at position `$index`. This has the benefit of preserving anything else that might be in the top-level object. We use `$i-1` since you indicate you want to provide 1-based indices as input. ",
                "title": "Add a single object to an array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1629817978,
        "creation_date": 1629817116,
        "question_id": 68909597,
        "body_markdown": "So I have this json structure:\r\n\r\n```json\r\n{\r\n  &quot;dog&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;sam&quot;,\r\n      &quot;age&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;billy&quot;,\r\n      &quot;age&quot;: &quot;5&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI&#39;ve found that `.dog[1]` will return me the first object but not in the `dog:[]` array.\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;billy&quot;,\r\n  &quot;age&quot;: &quot;5&quot;\r\n}\r\n```\r\n\r\nand `.[] |= .[$i]` gives me an object:\r\n\r\n```json\r\n{\r\n  &quot;dog&quot;: {\r\n    &quot;name&quot;: &quot;billy&quot;,\r\n    &quot;age&quot;: &quot;5&quot;\r\n  }\r\n}\r\n```\r\n\r\nWhat I want is:\r\n\r\n```json\r\n{\r\n  &quot;dog&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;sam&quot;,\r\n      &quot;age&quot;: &quot;2&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI plan to use this in a bash script, and write out to multiple files like:\r\n\r\n`jq -r --argjson i &quot;$i&quot; &#39;.[] |= .[$i]&#39; &quot;$1&quot;`",
        "link": "https://stackoverflow.com/questions/68909597/add-a-single-object-to-an-array",
        "title": "Add a single object to an array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1629843323,
                "last_edit_date": 1629843323,
                "creation_date": 1629843007,
                "answer_id": 68914632,
                "question_id": 68913642,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "* `to_entries` generates a `.key`, add `1` to that to get the desired &quot;index&quot;\r\n* Use string manipulation (`\\()`) to prevent an &#39;`&quot;&quot; + &quot;&quot; + &quot;&quot;`&#39; spam\r\n\r\n```\r\nto_entries[] | &quot;\\(.key + 1).\\(.value.name)~\\(.value.id)&quot;\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\n```bash\r\njq --raw-output &#39;to_entries[] | &quot;\\(.key + 1).\\(.value.name)~\\(.value.id)&quot;&#39;\r\n```\r\n```none\r\n1.test1~id1\r\n2.test2~id2\r\n```\r\n\r\n\r\n----------\r\n\r\n### [JqPlay Demo](https://jqplay.org/s/_aIIRvJTGM)",
                "title": "Capture array index using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1629869404,
        "creation_date": 1629836336,
        "last_edit_date": 1629869404,
        "question_id": 68913642,
        "body_markdown": "With the data\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;test1&quot;,\r\n    &quot;id&quot;: &quot;id1&quot;,\r\n    &quot;ip&quot;: &quot;10.0.0.0&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;test2&quot;,\r\n    &quot;id&quot;: &quot;id2&quot;,\r\n    &quot;ip&quot;: &quot;10.1.0.0&quot;\r\n  }\r\n]\r\n```\r\n\r\nI am trying to capture some fields with the array index\r\n\r\n```\r\ninstances = ( $( echo $data | jq -r &#39;.[] | (&quot;{something to capture index}&quot; + &quot;.&quot; + .name + &quot;~&quot; + .id)&#39; ) )\r\n```\r\n\r\nExpected output\r\n```\r\n1.test1~id1\r\n2.test2~id2\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/68913642/capture-array-index-using-jq",
        "title": "Capture array index using jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1629905788,
                "last_edit_date": 1629905788,
                "creation_date": 1629842642,
                "answer_id": 68914586,
                "question_id": 68914275,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found it in Weeble&#39;s [answer](https://stackoverflow.com/a/68412440) to my earlier question:\r\n\r\n    &#39;.service.options.attributes |= {name}&#39;",
                "title": "Delete all but one key-value pair from JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1629873360,
                "creation_date": 1629873360,
                "answer_id": 68917938,
                "question_id": 68914275,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A different take on the problem:\r\n\r\n    walk(if type==&quot;object&quot; then with_entries(select(.value!=&quot;&quot;)) else . end)",
                "title": "Delete all but one key-value pair from JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1629950663,
        "creation_date": 1629840523,
        "last_edit_date": 1629950663,
        "question_id": 68914275,
        "body_markdown": "I have this:\r\n\r\n```json\r\n{\r\n  &quot;service&quot; : {\r\n    &quot;category&quot; : &quot;managed-object&quot;,\r\n    &quot;resource&quot; : &quot;attribute&quot;,\r\n    &quot;action&quot; : &quot;delete&quot;,\r\n    &quot;options&quot; : {\r\n      &quot;uuid&quot; : &quot;#VALUE&quot;,\r\n      &quot;attributes&quot; : {\r\n        &quot;name&quot; : {\r\n          &quot;value&quot; : &quot;#VALUE&quot;\r\n        },\r\n        &quot;contactInfo&quot; : &quot;&quot;,\r\n        &quot;activationDate&quot; : &quot;&quot;,\r\n        &quot;deactivationDate&quot; : &quot;&quot;,\r\n        &quot;protectStopDate&quot; : &quot;&quot;,\r\n        &quot;processStartDate&quot; : &quot;&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI need this:\r\n\r\n```json\r\n{\r\n  &quot;service&quot; : {\r\n    &quot;category&quot; : &quot;managed-object&quot;,\r\n    &quot;resource&quot; : &quot;attribute&quot;,\r\n    &quot;action&quot; : &quot;delete&quot;,\r\n    &quot;options&quot; : {\r\n      &quot;uuid&quot; : &quot;#VALUE&quot;,\r\n      &quot;attributes&quot; : {\r\n        &quot;name&quot; : {\r\n          &quot;value&quot; : &quot;#VALUE&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nPreviously I had a similar problem that was a little bit more complicated, and I received this amazingly simple answer from someone here:\r\n\r\n```\r\n.service.options |= (del(.max, .objectGroupMember) | .attributes|={name})\r\n```\r\n\r\nThat jq command works even here, but of course `(.max, .objectGroupMember)` does not make sense because it does not exist.\r\n\r\nHow can I achieve my desired result?",
        "link": "https://stackoverflow.com/questions/68914275/delete-all-but-one-key-value-pair-from-json",
        "title": "Delete all but one key-value pair from JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1629905452,
                "last_edit_date": 1629905452,
                "creation_date": 1629901164,
                "answer_id": 68924625,
                "question_id": 68923838,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JQ doesn&#39;t have a nice merge built-in for such tasks yet, but you can achieve this one using `group_by`.\r\n```\r\ngroup_by(.first, .last, .roll) | map(\r\n  (.[0] | {first, last, roll}) + {subject: map(.subject)}\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/oT40ct2-bR)&lt;/sup&gt;",
                "title": "Group related items then merge them and accumulate some properties into arrays"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1629903929,
                "last_edit_date": 1629903929,
                "creation_date": 1629903083,
                "answer_id": 68925166,
                "question_id": 68923838,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A variation based on Oguz&#39;s excellent answer:\r\n\r\n```\r\n  group_by(.first, .last, .roll)\r\n| map( map(.subject) as $subject\r\n     | .[0]\r\n     | {first, last, roll, $subject})\r\n```\r\n\r\nCollect related items (group by first, last and roll) and reduce each collection into a single item:\r\n\r\n- First we put all subjects into `$subject`\r\n- Take the first item as a &quot;template&quot; but rewrite the `.subject` key with `$subject`.\r\n",
                "title": "Group related items then merge them and accumulate some properties into arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1664702734,
        "creation_date": 1629898091,
        "last_edit_date": 1664702734,
        "question_id": 68923838,
        "body_markdown": "Have a JSON as below,\r\n```\r\n[\r\n  {\r\n    &quot;first&quot;: &quot;foo&quot;,\r\n    &quot;last&quot;: &quot;bar&quot;,\r\n    &quot;roll&quot;: &quot;32&quot;,\r\n    &quot;subject&quot;: &quot;maths&quot;\r\n  },\r\n  {\r\n    &quot;first&quot;: &quot;joe&quot;,\r\n    &quot;last&quot;: &quot;mighty&quot;,\r\n    &quot;roll&quot;: &quot;31&quot;,\r\n    &quot;subject&quot;: &quot;english&quot;\r\n  },\r\n  {\r\n    &quot;first&quot;: &quot;foo&quot;,\r\n    &quot;last&quot;: &quot;bar&quot;,\r\n    &quot;roll&quot;: &quot;32&quot;,\r\n    &quot;subject&quot;: &quot;english&quot;\r\n  },\r\n  {\r\n    &quot;first&quot;: &quot;joe&quot;,\r\n    &quot;last&quot;: &quot;mighty&quot;,\r\n    &quot;roll&quot;: &quot;31&quot;,\r\n    &quot;subject&quot;: &quot;maths&quot;\r\n  },\r\n  {\r\n    &quot;first&quot;: &quot;foo&quot;,\r\n    &quot;last&quot;: &quot;bar&quot;,\r\n    &quot;roll&quot;: &quot;32&quot;,\r\n    &quot;subject&quot;: &quot;science&quot;\r\n  }\r\n]\r\n```\r\nunique_by(.first,.last, .roll) will remove other subject entries. I want convert &#39;subject&#39; to an array with all the values in the source JSON array. How to map using jq for creating nested array of subject as below,\r\n```\r\n[\r\n  {\r\n    &quot;first&quot;: &quot;foo&quot;,\r\n    &quot;last&quot;: &quot;bar&quot;,\r\n    &quot;roll&quot;: &quot;32&quot;,\r\n    &quot;subject&quot;: [&quot;maths&quot;, &quot;english&quot;, &quot;science&quot;]\r\n  },\r\n  {\r\n    &quot;first&quot;: &quot;joe&quot;,\r\n    &quot;last&quot;: &quot;mighty&quot;,\r\n    &quot;roll&quot;: &quot;31&quot;,\r\n    &quot;subject&quot;: [&quot;english&quot;, &quot;maths&quot;]\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/68923838/group-related-items-then-merge-them-and-accumulate-some-properties-into-arrays",
        "title": "Group related items then merge them and accumulate some properties into arrays"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629974058,
                "post_id": 68936535,
                "comment_id": 121831595,
                "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": 1629976045,
                "post_id": 68936535,
                "comment_id": 121832376,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1629977921,
                "last_edit_date": 1629977921,
                "creation_date": 1629977465,
                "answer_id": 68937727,
                "question_id": 68936535,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re willing to specify .address:\r\n\r\n    jq &#39;.address.state = &quot;Bihar&quot;&#39; sample-json.json\r\n\r\nOtherwise:\r\n\r\n    jq &#39;walk(if type == &quot;object&quot; and has(&quot;state&quot;) then .state = &quot;Bihar&quot; else . end)&#39; sample-json.json\r\n\r\n\r\nThis last will replace all `.state` values.  If you only want to replace the first occurrence:\r\n\r\n    jq &#39;first(..|objects|select(has(&quot;state&quot;))).state = &quot;Bihar&quot;&#39; sample-json.json\r\n\r\nAnd so on.  It would really help all concerned if you could make the requirements clear.",
                "title": "Need to find key-value pair and replace key-value pair in JSON using JQ"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1629977921,
        "creation_date": 1629972438,
        "last_edit_date": 1629973203,
        "question_id": 68936535,
        "body_markdown": "I have this JSON\r\n\r\n```json\r\n{\r\n  &quot;firstName&quot;: &quot;Rajesh&quot;,\r\n  &quot;lastName&quot;: &quot;Kumar&quot;,\r\n  &quot;gender&quot;: &quot;man&quot;,\r\n  &quot;age&quot;: 24,\r\n  &quot;address&quot;: {\r\n    &quot;streetAddress&quot;: &quot;126 Udhna&quot;,\r\n    &quot;city&quot;: &quot;Surat&quot;,\r\n    &quot;state&quot;: &quot;WB&quot;,\r\n    &quot;postalCode&quot;: &quot;394221&quot;\r\n  },\r\n  &quot;phoneNumbers&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;home&quot;,\r\n      &quot;number&quot;: &quot;7383627627&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI need to find the value of the &quot;state&quot; key Using JQ and replace the value in JSON. I do not want to fetch it by providing the position of the key, Like \r\n\r\n```bash\r\nfirstName=$(cat sample-json.json | jq -r &#39;.firstName&#39;)\r\n```\r\n\r\nMy expected output\r\n\r\n```json\r\n{\r\n  &quot;firstName&quot;: &quot;Rajesh&quot;,\r\n  &quot;lastName&quot;: &quot;Kumar&quot;,\r\n  &quot;gender&quot;: &quot;man&quot;,\r\n  &quot;age&quot;: 24,\r\n  &quot;address&quot;: {\r\n    &quot;streetAddress&quot;: &quot;126 Udhna&quot;,\r\n    &quot;city&quot;: &quot;Surat&quot;,\r\n    &quot;state&quot;: &quot;Bihar&quot;,\r\n    &quot;postalCode&quot;: &quot;394221&quot;\r\n  },\r\n  &quot;phoneNumbers&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;home&quot;,\r\n      &quot;number&quot;: &quot;7383627627&quot;\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/68936535/need-to-find-key-value-pair-and-replace-key-value-pair-in-json-using-jq",
        "title": "Need to find key-value pair and replace key-value pair in JSON using JQ"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629988475,
                "post_id": 68940509,
                "comment_id": 121837958,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10148693,
                    "reputation": 5086,
                    "user_id": 7496039,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://i.sstatic.net/W7LzR.jpg?s=256",
                    "display_name": "Andreas Hunter",
                    "link": "https://stackoverflow.com/users/7496039/andreas-hunter"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629988510,
                "post_id": 68940509,
                "comment_id": 121837972,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10148693,
                    "reputation": 5086,
                    "user_id": 7496039,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://i.sstatic.net/W7LzR.jpg?s=256",
                    "display_name": "Andreas Hunter",
                    "link": "https://stackoverflow.com/users/7496039/andreas-hunter"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1629988572,
                "post_id": 68940509,
                "comment_id": 121838011,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1629988957,
                "last_edit_date": 1629988957,
                "creation_date": 1629988708,
                "answer_id": 68940610,
                "question_id": 68940509,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pass your strings using `--arg`, then you can create the JSON as expected:\r\n```bash\r\n#!/bin/bash\r\n\r\nserver1_name=&#39;server-1&#39;\r\nserver1_url=&#39;http://server-1.net&#39;\r\n\r\nserver2_name=&#39;server-2&#39;\r\nserver2_url=&#39;http://server-2.net&#39;\r\n\r\nresult=$(jq -n \\\r\n    --arg name1 &quot;$server1_name&quot; \\\r\n    --arg url1 &quot;$server1_url&quot; \\\r\n    --arg name2 &quot;$server2_name&quot; \\\r\n    --arg url2 &quot;$server2_url&quot; \\\r\n    &#39;[ { &quot;name&quot;: $name1, &quot;url&quot;: $url1 }, { &quot;name&quot;: $name2, &quot;url&quot;: $url2 } ]&#39;)\r\n\r\necho &quot;$result&quot;\r\n```\r\n\r\nWill produce:\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;server-1&quot;,\r\n    &quot;url&quot;: &quot;http://server-1.net&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;server-2&quot;,\r\n    &quot;url&quot;: &quot;http://server-2.net&quot;\r\n  }\r\n]\r\n```",
                "title": "How to create array of json objects using jq and set to var in bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1629990013,
                "creation_date": 1629990013,
                "answer_id": 68940982,
                "question_id": 68940509,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can construct two arrays of names and urls, then adapt [this answer](https://stackoverflow.com/a/57283652/1126841) to &quot;zip&quot; the two arrays together into the desired array of objects.\r\n\r\n    jq -n \\\r\n        --arg name1 &quot;$server1_name&quot; \\\r\n        --arg url1 &quot;$server1_url&quot; \\\r\n        --arg name2 &quot;$server2_name&quot; \\\r\n        --arg url2 &quot;$server2_url&quot; \\\r\n    &#39;[$name1, $name2] as $names |\r\n     [$url1, $url2] as $urls |\r\n      [([$names, $urls] | transpose[]) as [$name, $url] |{$name, $url}]&#39;\r\n\r\n \r\nThe benefit is that as the number of name/url pairs grows, you only need to modify the first two filters that define `$names` and `$urls`; the rest of the filter stays the same. You could even separate this into separate uses of `jq`, to facilitate the definition of a large list of servers.\r\n\r\n    names=$(jq -n --arg v1 &quot;$server1_name&quot; --arg v2 &quot;$server2_name&quot; &#39;[$v1, $v2]&#39;)\r\n\r\n    urls=$(jq -n --arg v1 &quot;$server1_url&quot; --arg v2 &quot;$server2_url&quot; &#39;[$v1, $v2]&#39;)\r\n\r\n    jq -n \\\r\n       --argjson names &quot;$names&quot; \\\r\n       --argjson urls &quot;$urls&quot; \\\r\n       &#39;[([$names, $urls] | transpose[]) as [$name, $url] | {$name, $url}]&#39;",
                "title": "How to create array of json objects using jq and set to var in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1629990013,
        "creation_date": 1629988394,
        "question_id": 68940509,
        "body_markdown": "I have like this variables in my bash script:\r\n\r\n    server1_name = &#39;server-1&#39;\r\n    server1_url = &#39;http://server-1.net&#39;\r\n    \r\n    server2_name = &#39;server-2&#39;\r\n    server2_url = &#39;http://server-2.net&#39;\r\n\r\nHow I can create like this json using my variables and set to new var:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;server-1&quot;,\r\n        &quot;url&quot;: &quot;http://server-1.net&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;server-2&quot;,\r\n        &quot;url&quot;: &quot;http://server-2.net&quot;\r\n      }\r\n    ]\r\n\r\nWhat I tried:\r\n\r\n    export jsonArray = $(&quot;[{\\&quot;name\\&quot;:&quot;$server1_name&quot;,\\&quot;url\\&quot;:\\&quot;$server1_url\\&quot;},{\\&quot;name\\&quot;:&quot;$server2_name&quot;,\\&quot;url\\&quot;:\\&quot;$server2_url\\&quot;}]&quot; | jq -rec .)",
        "link": "https://stackoverflow.com/questions/68940509/how-to-create-array-of-json-objects-using-jq-and-set-to-var-in-bash",
        "title": "How to create array of json objects using jq and set to var in bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1630072495,
                "creation_date": 1630072495,
                "answer_id": 68954627,
                "question_id": 68954456,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Discard keys that don&#39;t match `^[a-z]-$` in **B** and add **A** and the resulting object together.\r\n``` shell\r\njq -n &#39;\r\n  input as $A\r\n| input as $B\r\n| $A + ($B | with_entries(select(.key | test(&quot;^[a-z]-$&quot;))))\r\n&#39; fileA fileB\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/r95SDcWbTA)&lt;/sup&gt;",
                "title": "Update values by regex-matched key from another dict"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1630072545,
        "creation_date": 1630071745,
        "question_id": 68954456,
        "body_markdown": "I have JSON `A` \r\n```json\r\n{\r\n  &quot;a-&quot; : {&quot;v&quot; : 1},\r\n  &quot;b-&quot; : {&quot;v&quot; : 2},\r\n  &quot;c&quot; : {&quot;v&quot; : 3}\r\n}\r\n```\r\nwhich I want to update with JSON `B`\r\n```json\r\n{\r\n  &quot;a-&quot; : {&quot;v&quot; : 9},\r\n  &quot;b-&quot; : {&quot;v&quot; : 9},\r\n  &quot;d&quot;  : {&quot;v&quot; : 9}\r\n}\r\n```\r\n\r\nbut only the keys with regex `[a-z]-` in `B` should be updated in `A`:\r\n\r\n**Result**\r\n```json\r\n{\r\n  &quot;a-&quot; : {&quot;v&quot; : 9},\r\n  &quot;b-&quot; : {&quot;v&quot; : 9},\r\n  &quot;c&quot; : {&quot;v&quot; : 3}\r\n}\r\n```\r\n\r\nHow do I do this with `jq`?",
        "link": "https://stackoverflow.com/questions/68954456/update-values-by-regex-matched-key-from-another-dict",
        "title": "Update values by regex-matched key from another dict"
    }
]